From: Eric Paris Date: Wed, 4 Apr 2012 17:46:36 +0000 (-0400) Subject: SELinux: possible NULL deref in context_struct_to_string X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=bb7081ab93582fd2557160549854200a5fc7b42a;p=GitHub%2Fmt8127%2Fandroid_kernel_alcatel_ttab.git SELinux: possible NULL deref in context_struct_to_string It's possible that the caller passed a NULL for scontext. However if this is a defered mapping we might still attempt to call *scontext=kstrdup(). This is bad. Instead just return the len. Signed-off-by: Eric Paris --- diff --git a/security/selinux/ss/services.c b/security/selinux/ss/services.c index 1ded0ec7e8c2..9b7e7ed54e7e 100644 --- a/security/selinux/ss/services.c +++ b/security/selinux/ss/services.c @@ -1018,9 +1018,11 @@ static int context_struct_to_string(struct context *context, char **scontext, u3 if (context->len) { *scontext_len = context->len; - *scontext = kstrdup(context->str, GFP_ATOMIC); - if (!(*scontext)) - return -ENOMEM; + if (scontext) { + *scontext = kstrdup(context->str, GFP_ATOMIC); + if (!(*scontext)) + return -ENOMEM; + } return 0; }