summaryrefslogtreecommitdiffstats
path: root/kernel/auditsc.c
diff options
context:
space:
mode:
authorPaul Moore <paul@paul-moore.com>2016-08-30 17:19:13 -0400
committerPaul Moore <paul@paul-moore.com>2016-08-30 17:19:13 -0400
commitfa2bea2f5cca5b8d4a3e5520d2e8c0ede67ac108 (patch)
treea7f49ec5a58e527f6a50cac7a628561688007629 /kernel/auditsc.c
parent523d939ef98fd712632d93a5a2b588e477a7565e (diff)
audit: consistently record PIDs with task_tgid_nr()
Unfortunately we record PIDs in audit records using a variety of methods despite the correct way being the use of task_tgid_nr(). This patch converts all of these callers, except for the case of AUDIT_SET in audit_receive_msg() (see the comment in the code). Reported-by: Jeff Vander Stoep <jeffv@google.com> Signed-off-by: Paul Moore <paul@paul-moore.com>
Diffstat (limited to 'kernel/auditsc.c')
-rw-r--r--kernel/auditsc.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/kernel/auditsc.c b/kernel/auditsc.c
index 2672d105cffc..3824b1bbeae1 100644
--- a/kernel/auditsc.c
+++ b/kernel/auditsc.c
@@ -455,7 +455,7 @@ static int audit_filter_rules(struct task_struct *tsk,
455 455
456 switch (f->type) { 456 switch (f->type) {
457 case AUDIT_PID: 457 case AUDIT_PID:
458 pid = task_pid_nr(tsk); 458 pid = task_tgid_nr(tsk);
459 result = audit_comparator(pid, f->op, f->val); 459 result = audit_comparator(pid, f->op, f->val);
460 break; 460 break;
461 case AUDIT_PPID: 461 case AUDIT_PPID:
@@ -1993,7 +1993,7 @@ static void audit_log_set_loginuid(kuid_t koldloginuid, kuid_t kloginuid,
1993 loginuid = from_kuid(&init_user_ns, kloginuid), 1993 loginuid = from_kuid(&init_user_ns, kloginuid),
1994 tty = audit_get_tty(current); 1994 tty = audit_get_tty(current);
1995 1995
1996 audit_log_format(ab, "pid=%d uid=%u", task_pid_nr(current), uid); 1996 audit_log_format(ab, "pid=%d uid=%u", task_tgid_nr(current), uid);
1997 audit_log_task_context(ab); 1997 audit_log_task_context(ab);
1998 audit_log_format(ab, " old-auid=%u auid=%u tty=%s old-ses=%u ses=%u res=%d", 1998 audit_log_format(ab, " old-auid=%u auid=%u tty=%s old-ses=%u ses=%u res=%d",
1999 oldloginuid, loginuid, tty ? tty_name(tty) : "(none)", 1999 oldloginuid, loginuid, tty ? tty_name(tty) : "(none)",
@@ -2220,7 +2220,7 @@ void __audit_ptrace(struct task_struct *t)
2220{ 2220{
2221 struct audit_context *context = current->audit_context; 2221 struct audit_context *context = current->audit_context;
2222 2222
2223 context->target_pid = task_pid_nr(t); 2223 context->target_pid = task_tgid_nr(t);
2224 context->target_auid = audit_get_loginuid(t); 2224 context->target_auid = audit_get_loginuid(t);
2225 context->target_uid = task_uid(t); 2225 context->target_uid = task_uid(t);
2226 context->target_sessionid = audit_get_sessionid(t); 2226 context->target_sessionid = audit_get_sessionid(t);
@@ -2245,7 +2245,7 @@ int __audit_signal_info(int sig, struct task_struct *t)
2245 2245
2246 if (audit_pid && t->tgid == audit_pid) { 2246 if (audit_pid && t->tgid == audit_pid) {
2247 if (sig == SIGTERM || sig == SIGHUP || sig == SIGUSR1 || sig == SIGUSR2) { 2247 if (sig == SIGTERM || sig == SIGHUP || sig == SIGUSR1 || sig == SIGUSR2) {
2248 audit_sig_pid = task_pid_nr(tsk); 2248 audit_sig_pid = task_tgid_nr(tsk);
2249 if (uid_valid(tsk->loginuid)) 2249 if (uid_valid(tsk->loginuid))
2250 audit_sig_uid = tsk->loginuid; 2250 audit_sig_uid = tsk->loginuid;
2251 else 2251 else
@@ -2345,7 +2345,7 @@ int __audit_log_bprm_fcaps(struct linux_binprm *bprm,
2345void __audit_log_capset(const struct cred *new, const struct cred *old) 2345void __audit_log_capset(const struct cred *new, const struct cred *old)
2346{ 2346{
2347 struct audit_context *context = current->audit_context; 2347 struct audit_context *context = current->audit_context;
2348 context->capset.pid = task_pid_nr(current); 2348 context->capset.pid = task_tgid_nr(current);
2349 context->capset.cap.effective = new->cap_effective; 2349 context->capset.cap.effective = new->cap_effective;
2350 context->capset.cap.inheritable = new->cap_effective; 2350 context->capset.cap.inheritable = new->cap_effective;
2351 context->capset.cap.permitted = new->cap_permitted; 2351 context->capset.cap.permitted = new->cap_permitted;
@@ -2377,7 +2377,7 @@ static void audit_log_task(struct audit_buffer *ab)
2377 from_kgid(&init_user_ns, gid), 2377 from_kgid(&init_user_ns, gid),
2378 sessionid); 2378 sessionid);
2379 audit_log_task_context(ab); 2379 audit_log_task_context(ab);
2380 audit_log_format(ab, " pid=%d comm=", task_pid_nr(current)); 2380 audit_log_format(ab, " pid=%d comm=", task_tgid_nr(current));
2381 audit_log_untrustedstring(ab, get_task_comm(comm, current)); 2381 audit_log_untrustedstring(ab, get_task_comm(comm, current));
2382 audit_log_d_path_exe(ab, current->mm); 2382 audit_log_d_path_exe(ab, current->mm);
2383} 2383}