Commit e495149b authored by Al Viro's avatar Al Viro

[PATCH] drop gfp_mask in audit_log_exit()

now we can do that - all callers are process-synchronous and do not hold
any locks.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent fa84cb93
...@@ -506,7 +506,7 @@ static inline void audit_free_context(struct audit_context *context) ...@@ -506,7 +506,7 @@ static inline void audit_free_context(struct audit_context *context)
printk(KERN_ERR "audit: freed %d contexts\n", count); printk(KERN_ERR "audit: freed %d contexts\n", count);
} }
static void audit_log_task_context(struct audit_buffer *ab, gfp_t gfp_mask) static void audit_log_task_context(struct audit_buffer *ab)
{ {
char *ctx = NULL; char *ctx = NULL;
ssize_t len = 0; ssize_t len = 0;
...@@ -518,7 +518,7 @@ static void audit_log_task_context(struct audit_buffer *ab, gfp_t gfp_mask) ...@@ -518,7 +518,7 @@ static void audit_log_task_context(struct audit_buffer *ab, gfp_t gfp_mask)
return; return;
} }
ctx = kmalloc(len, gfp_mask); ctx = kmalloc(len, GFP_KERNEL);
if (!ctx) if (!ctx)
goto error_path; goto error_path;
...@@ -536,23 +536,19 @@ static void audit_log_task_context(struct audit_buffer *ab, gfp_t gfp_mask) ...@@ -536,23 +536,19 @@ static void audit_log_task_context(struct audit_buffer *ab, gfp_t gfp_mask)
return; return;
} }
static void audit_log_task_info(struct audit_buffer *ab, struct task_struct *tsk, gfp_t gfp_mask) static void audit_log_task_info(struct audit_buffer *ab, struct task_struct *tsk)
{ {
char name[sizeof(tsk->comm)]; char name[sizeof(tsk->comm)];
struct mm_struct *mm = tsk->mm; struct mm_struct *mm = tsk->mm;
struct vm_area_struct *vma; struct vm_area_struct *vma;
/* tsk == current */
get_task_comm(name, tsk); get_task_comm(name, tsk);
audit_log_format(ab, " comm="); audit_log_format(ab, " comm=");
audit_log_untrustedstring(ab, name); audit_log_untrustedstring(ab, name);
if (!mm) if (mm) {
return;
/*
* this is brittle; all callers that pass GFP_ATOMIC will have
* NULL tsk->mm and we won't get here.
*/
down_read(&mm->mmap_sem); down_read(&mm->mmap_sem);
vma = mm->mmap; vma = mm->mmap;
while (vma) { while (vma) {
...@@ -566,17 +562,20 @@ static void audit_log_task_info(struct audit_buffer *ab, struct task_struct *tsk ...@@ -566,17 +562,20 @@ static void audit_log_task_info(struct audit_buffer *ab, struct task_struct *tsk
vma = vma->vm_next; vma = vma->vm_next;
} }
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
audit_log_task_context(ab, gfp_mask); }
audit_log_task_context(ab);
} }
static void audit_log_exit(struct audit_context *context, struct task_struct *tsk, gfp_t gfp_mask) static void audit_log_exit(struct audit_context *context, struct task_struct *tsk)
{ {
int i; int i;
struct audit_buffer *ab; struct audit_buffer *ab;
struct audit_aux_data *aux; struct audit_aux_data *aux;
const char *tty; const char *tty;
ab = audit_log_start(context, gfp_mask, AUDIT_SYSCALL); /* tsk == current */
ab = audit_log_start(context, GFP_KERNEL, AUDIT_SYSCALL);
if (!ab) if (!ab)
return; /* audit_panic has been called */ return; /* audit_panic has been called */
audit_log_format(ab, "arch=%x syscall=%d", audit_log_format(ab, "arch=%x syscall=%d",
...@@ -607,12 +606,12 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts ...@@ -607,12 +606,12 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts
context->gid, context->gid,
context->euid, context->suid, context->fsuid, context->euid, context->suid, context->fsuid,
context->egid, context->sgid, context->fsgid, tty); context->egid, context->sgid, context->fsgid, tty);
audit_log_task_info(ab, gfp_mask); audit_log_task_info(ab, tsk);
audit_log_end(ab); audit_log_end(ab);
for (aux = context->aux; aux; aux = aux->next) { for (aux = context->aux; aux; aux = aux->next) {
ab = audit_log_start(context, gfp_mask, aux->type); ab = audit_log_start(context, GFP_KERNEL, aux->type);
if (!ab) if (!ab)
continue; /* audit_panic has been called */ continue; /* audit_panic has been called */
...@@ -649,7 +648,7 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts ...@@ -649,7 +648,7 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts
} }
if (context->pwd && context->pwdmnt) { if (context->pwd && context->pwdmnt) {
ab = audit_log_start(context, gfp_mask, AUDIT_CWD); ab = audit_log_start(context, GFP_KERNEL, AUDIT_CWD);
if (ab) { if (ab) {
audit_log_d_path(ab, "cwd=", context->pwd, context->pwdmnt); audit_log_d_path(ab, "cwd=", context->pwd, context->pwdmnt);
audit_log_end(ab); audit_log_end(ab);
...@@ -659,7 +658,7 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts ...@@ -659,7 +658,7 @@ static void audit_log_exit(struct audit_context *context, struct task_struct *ts
unsigned long ino = context->names[i].ino; unsigned long ino = context->names[i].ino;
unsigned long pino = context->names[i].pino; unsigned long pino = context->names[i].pino;
ab = audit_log_start(context, gfp_mask, AUDIT_PATH); ab = audit_log_start(context, GFP_KERNEL, AUDIT_PATH);
if (!ab) if (!ab)
continue; /* audit_panic has been called */ continue; /* audit_panic has been called */
...@@ -712,8 +711,9 @@ void audit_free(struct task_struct *tsk) ...@@ -712,8 +711,9 @@ void audit_free(struct task_struct *tsk)
* function (e.g., exit_group), then free context block. * function (e.g., exit_group), then free context block.
* We use GFP_ATOMIC here because we might be doing this * We use GFP_ATOMIC here because we might be doing this
* in the context of the idle thread */ * in the context of the idle thread */
/* that can happen only if we are called from do_exit() */
if (context->in_syscall && context->auditable) if (context->in_syscall && context->auditable)
audit_log_exit(context, tsk, GFP_ATOMIC); audit_log_exit(context, tsk);
audit_free_context(context); audit_free_context(context);
} }
...@@ -821,6 +821,8 @@ void audit_syscall_exit(struct task_struct *tsk, int valid, long return_code) ...@@ -821,6 +821,8 @@ void audit_syscall_exit(struct task_struct *tsk, int valid, long return_code)
{ {
struct audit_context *context; struct audit_context *context;
/* tsk == current */
get_task_struct(tsk); get_task_struct(tsk);
task_lock(tsk); task_lock(tsk);
context = audit_get_context(tsk, valid, return_code); context = audit_get_context(tsk, valid, return_code);
...@@ -832,7 +834,7 @@ void audit_syscall_exit(struct task_struct *tsk, int valid, long return_code) ...@@ -832,7 +834,7 @@ void audit_syscall_exit(struct task_struct *tsk, int valid, long return_code)
goto out; goto out;
if (context->in_syscall && context->auditable) if (context->in_syscall && context->auditable)
audit_log_exit(context, tsk, GFP_KERNEL); audit_log_exit(context, tsk);
context->in_syscall = 0; context->in_syscall = 0;
context->auditable = 0; context->auditable = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment