diff options
author | Richard Guy Briggs <rgb@redhat.com> | 2016-06-28 12:06:58 -0400 |
---|---|---|
committer | Paul Moore <paul@paul-moore.com> | 2016-06-28 15:40:17 -0400 |
commit | 76a658c20efd541a62838d9ff68ce94170d7a549 (patch) | |
tree | c14c93cbd7f2a74398b7a8be7548d88043eca8e1 | |
parent | 188e3c5cd2b672620291e64a21f1598fe91e40b6 (diff) | |
download | lwn-76a658c20efd541a62838d9ff68ce94170d7a549.tar.gz lwn-76a658c20efd541a62838d9ff68ce94170d7a549.zip |
audit: move calcs after alloc and check when logging set loginuid
Move the calculations of values after the allocation in case the
allocation fails. This avoids wasting effort in the rare case that it
fails, but more importantly saves us extra logic to release the tty
ref.
Signed-off-by: Richard Guy Briggs <rgb@redhat.com>
Signed-off-by: Paul Moore <paul@paul-moore.com>
-rw-r--r-- | kernel/auditsc.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/kernel/auditsc.c b/kernel/auditsc.c index 71e14d836e69..33dafa70229d 100644 --- a/kernel/auditsc.c +++ b/kernel/auditsc.c @@ -1985,14 +1985,15 @@ static void audit_log_set_loginuid(kuid_t koldloginuid, kuid_t kloginuid, if (!audit_enabled) return; + ab = audit_log_start(NULL, GFP_KERNEL, AUDIT_LOGIN); + if (!ab) + return; + uid = from_kuid(&init_user_ns, task_uid(current)); oldloginuid = from_kuid(&init_user_ns, koldloginuid); loginuid = from_kuid(&init_user_ns, kloginuid), tty = audit_get_tty(current); - ab = audit_log_start(NULL, GFP_KERNEL, AUDIT_LOGIN); - if (!ab) - return; audit_log_format(ab, "pid=%d uid=%u", task_pid_nr(current), uid); audit_log_task_context(ab); audit_log_format(ab, " old-auid=%u auid=%u tty=%s old-ses=%u ses=%u res=%d", |