Commit 7ac7551d authored by Al Viro's avatar Al Viro Committed by Greg Kroah-Hartman

fix deadlock in audit_log_task_context()

GFP_KERNEL allocations in non-blocking context; fixed by killing
an idiotic use of security_getprocattr().
Acked-by: default avatarStephen Smalley <sds@tycho.nsa.gov>
Acked-by: default avatarJames Morris <jmorris@namei.org>
Cc: Chuck Ebbert <cebbert@redhat.com>
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 6f09b7b3
...@@ -734,28 +734,26 @@ static inline void audit_free_context(struct audit_context *context) ...@@ -734,28 +734,26 @@ static inline void audit_free_context(struct audit_context *context)
void audit_log_task_context(struct audit_buffer *ab) void audit_log_task_context(struct audit_buffer *ab)
{ {
char *ctx = NULL; char *ctx = NULL;
ssize_t len = 0; unsigned len;
int error;
u32 sid;
len = security_getprocattr(current, "current", NULL, 0); selinux_get_task_sid(current, &sid);
if (len < 0) { if (!sid)
if (len != -EINVAL)
goto error_path;
return; return;
}
ctx = kmalloc(len, GFP_KERNEL);
if (!ctx)
goto error_path;
len = security_getprocattr(current, "current", ctx, len); error = selinux_sid_to_string(sid, &ctx, &len);
if (len < 0 ) if (error) {
if (error != -EINVAL)
goto error_path; goto error_path;
return;
}
audit_log_format(ab, " subj=%s", ctx); audit_log_format(ab, " subj=%s", ctx);
kfree(ctx);
return; return;
error_path: error_path:
kfree(ctx);
audit_panic("error in audit_log_task_context"); audit_panic("error in audit_log_task_context");
return; return;
} }
......
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