Skip to content

Commit f1dc486

Browse files
rgbriggseparis
authored andcommitted
audit: anchor all pid references in the initial pid namespace
Store and log all PIDs with reference to the initial PID namespace and use the access functions task_pid_nr() and task_tgid_nr() for task->pid and task->tgid. Cc: "Eric W. Biederman" <[email protected]> (informed by ebiederman's c776b5d2) Signed-off-by: Richard Guy Briggs <[email protected]>
1 parent c92cdeb commit f1dc486

File tree

6 files changed

+38
-16
lines changed

6 files changed

+38
-16
lines changed

drivers/tty/tty_audit.c

+2-1
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,7 @@ static void tty_audit_log(const char *description, int major, int minor,
6565
{
6666
struct audit_buffer *ab;
6767
struct task_struct *tsk = current;
68+
pid_t pid = task_pid_nr(tsk);
6869
uid_t uid = from_kuid(&init_user_ns, task_uid(tsk));
6970
uid_t loginuid = from_kuid(&init_user_ns, audit_get_loginuid(tsk));
7071
unsigned int sessionid = audit_get_sessionid(tsk);
@@ -74,7 +75,7 @@ static void tty_audit_log(const char *description, int major, int minor,
7475
char name[sizeof(tsk->comm)];
7576

7677
audit_log_format(ab, "%s pid=%u uid=%u auid=%u ses=%u major=%d"
77-
" minor=%d comm=", description, tsk->pid, uid,
78+
" minor=%d comm=", description, pid, uid,
7879
loginuid, sessionid, major, minor);
7980
get_task_comm(name, tsk);
8081
audit_log_untrustedstring(ab, name);

kernel/audit.c

+3-2
Original file line numberDiff line numberDiff line change
@@ -649,6 +649,7 @@ static int audit_log_common_recv_msg(struct audit_buffer **ab, u16 msg_type)
649649
{
650650
int rc = 0;
651651
uid_t uid = from_kuid(&init_user_ns, current_uid());
652+
pid_t pid = task_tgid_nr(current);
652653

653654
if (!audit_enabled && msg_type != AUDIT_USER_AVC) {
654655
*ab = NULL;
@@ -658,7 +659,7 @@ static int audit_log_common_recv_msg(struct audit_buffer **ab, u16 msg_type)
658659
*ab = audit_log_start(NULL, GFP_KERNEL, msg_type);
659660
if (unlikely(!*ab))
660661
return rc;
661-
audit_log_format(*ab, "pid=%d uid=%u", task_tgid_vnr(current), uid);
662+
audit_log_format(*ab, "pid=%d uid=%u", pid, uid);
662663
audit_log_session_info(*ab);
663664
audit_log_task_context(*ab);
664665

@@ -1823,7 +1824,7 @@ void audit_log_task_info(struct audit_buffer *ab, struct task_struct *tsk)
18231824
" euid=%u suid=%u fsuid=%u"
18241825
" egid=%u sgid=%u fsgid=%u tty=%s ses=%u",
18251826
task_ppid_nr(tsk),
1826-
tsk->pid,
1827+
task_pid_nr(tsk),
18271828
from_kuid(&init_user_ns, audit_get_loginuid(tsk)),
18281829
from_kuid(&init_user_ns, cred->uid),
18291830
from_kgid(&init_user_ns, cred->gid),

kernel/auditfilter.c

+16-1
Original file line numberDiff line numberDiff line change
@@ -433,6 +433,19 @@ static struct audit_entry *audit_data_to_entry(struct audit_rule_data *data,
433433
f->val = 0;
434434
}
435435

436+
if ((f->type == AUDIT_PID) || (f->type == AUDIT_PPID)) {
437+
struct pid *pid;
438+
rcu_read_lock();
439+
pid = find_vpid(f->val);
440+
if (!pid) {
441+
rcu_read_unlock();
442+
err = -ESRCH;
443+
goto exit_free;
444+
}
445+
f->val = pid_nr(pid);
446+
rcu_read_unlock();
447+
}
448+
436449
err = audit_field_valid(entry, f);
437450
if (err)
438451
goto exit_free;
@@ -1242,12 +1255,14 @@ static int audit_filter_user_rules(struct audit_krule *rule, int type,
12421255

12431256
for (i = 0; i < rule->field_count; i++) {
12441257
struct audit_field *f = &rule->fields[i];
1258+
pid_t pid;
12451259
int result = 0;
12461260
u32 sid;
12471261

12481262
switch (f->type) {
12491263
case AUDIT_PID:
1250-
result = audit_comparator(task_pid_vnr(current), f->op, f->val);
1264+
pid = task_pid_nr(current);
1265+
result = audit_comparator(pid, f->op, f->val);
12511266
break;
12521267
case AUDIT_UID:
12531268
result = audit_uid_comparator(current_uid(), f->op, f->uid);

kernel/auditsc.c

+9-7
Original file line numberDiff line numberDiff line change
@@ -457,10 +457,12 @@ static int audit_filter_rules(struct task_struct *tsk,
457457
struct audit_field *f = &rule->fields[i];
458458
struct audit_names *n;
459459
int result = 0;
460+
pid_t pid;
460461

461462
switch (f->type) {
462463
case AUDIT_PID:
463-
result = audit_comparator(tsk->pid, f->op, f->val);
464+
pid = task_pid_nr(tsk);
465+
result = audit_comparator(pid, f->op, f->val);
464466
break;
465467
case AUDIT_PPID:
466468
if (ctx) {
@@ -2051,7 +2053,7 @@ static void audit_log_set_loginuid(kuid_t koldloginuid, kuid_t kloginuid,
20512053
audit_log_format(ab, "pid=%d uid=%u"
20522054
" old-auid=%u new-auid=%u old-ses=%u new-ses=%u"
20532055
" res=%d",
2054-
current->pid, uid,
2056+
task_pid_nr(current), uid,
20552057
oldloginuid, loginuid, oldsessionid, sessionid,
20562058
!rc);
20572059
audit_log_end(ab);
@@ -2275,7 +2277,7 @@ void __audit_ptrace(struct task_struct *t)
22752277
{
22762278
struct audit_context *context = current->audit_context;
22772279

2278-
context->target_pid = t->pid;
2280+
context->target_pid = task_pid_nr(t);
22792281
context->target_auid = audit_get_loginuid(t);
22802282
context->target_uid = task_uid(t);
22812283
context->target_sessionid = audit_get_sessionid(t);
@@ -2300,7 +2302,7 @@ int __audit_signal_info(int sig, struct task_struct *t)
23002302

23012303
if (audit_pid && t->tgid == audit_pid) {
23022304
if (sig == SIGTERM || sig == SIGHUP || sig == SIGUSR1 || sig == SIGUSR2) {
2303-
audit_sig_pid = tsk->pid;
2305+
audit_sig_pid = task_pid_nr(tsk);
23042306
if (uid_valid(tsk->loginuid))
23052307
audit_sig_uid = tsk->loginuid;
23062308
else
@@ -2314,7 +2316,7 @@ int __audit_signal_info(int sig, struct task_struct *t)
23142316
/* optimize the common case by putting first signal recipient directly
23152317
* in audit_context */
23162318
if (!ctx->target_pid) {
2317-
ctx->target_pid = t->tgid;
2319+
ctx->target_pid = task_tgid_nr(t);
23182320
ctx->target_auid = audit_get_loginuid(t);
23192321
ctx->target_uid = t_uid;
23202322
ctx->target_sessionid = audit_get_sessionid(t);
@@ -2335,7 +2337,7 @@ int __audit_signal_info(int sig, struct task_struct *t)
23352337
}
23362338
BUG_ON(axp->pid_count >= AUDIT_AUX_PIDS);
23372339

2338-
axp->target_pid[axp->pid_count] = t->tgid;
2340+
axp->target_pid[axp->pid_count] = task_tgid_nr(t);
23392341
axp->target_auid[axp->pid_count] = audit_get_loginuid(t);
23402342
axp->target_uid[axp->pid_count] = t_uid;
23412343
axp->target_sessionid[axp->pid_count] = audit_get_sessionid(t);
@@ -2435,7 +2437,7 @@ static void audit_log_task(struct audit_buffer *ab)
24352437
from_kgid(&init_user_ns, gid),
24362438
sessionid);
24372439
audit_log_task_context(ab);
2438-
audit_log_format(ab, " pid=%d comm=", current->pid);
2440+
audit_log_format(ab, " pid=%d comm=", task_pid_nr(current));
24392441
audit_log_untrustedstring(ab, current->comm);
24402442
if (mm) {
24412443
down_read(&mm->mmap_sem);

security/integrity/integrity_audit.c

+1-1
Original file line numberDiff line numberDiff line change
@@ -39,7 +39,7 @@ void integrity_audit_msg(int audit_msgno, struct inode *inode,
3939

4040
ab = audit_log_start(current->audit_context, GFP_KERNEL, audit_msgno);
4141
audit_log_format(ab, "pid=%d uid=%u auid=%u ses=%u",
42-
current->pid,
42+
task_pid_nr(current),
4343
from_kuid(&init_user_ns, current_cred()->uid),
4444
from_kuid(&init_user_ns, audit_get_loginuid(current)),
4545
audit_get_sessionid(current));

security/lsm_audit.c

+7-4
Original file line numberDiff line numberDiff line change
@@ -220,7 +220,7 @@ static void dump_common_audit_data(struct audit_buffer *ab,
220220
*/
221221
BUILD_BUG_ON(sizeof(a->u) > sizeof(void *)*2);
222222

223-
audit_log_format(ab, " pid=%d comm=", tsk->pid);
223+
audit_log_format(ab, " pid=%d comm=", task_pid_nr(tsk));
224224
audit_log_untrustedstring(ab, tsk->comm);
225225

226226
switch (a->type) {
@@ -278,9 +278,12 @@ static void dump_common_audit_data(struct audit_buffer *ab,
278278
}
279279
case LSM_AUDIT_DATA_TASK:
280280
tsk = a->u.tsk;
281-
if (tsk && tsk->pid) {
282-
audit_log_format(ab, " pid=%d comm=", tsk->pid);
283-
audit_log_untrustedstring(ab, tsk->comm);
281+
if (tsk) {
282+
pid_t pid = task_pid_nr(tsk);
283+
if (pid) {
284+
audit_log_format(ab, " pid=%d comm=", pid);
285+
audit_log_untrustedstring(ab, tsk->comm);
286+
}
284287
}
285288
break;
286289
case LSM_AUDIT_DATA_NET:

0 commit comments

Comments
 (0)