Commit 53f3517a authored by Christian Göttsche's avatar Christian Göttsche Committed by Paul Moore

selinux: do not leave dangling pointer behind

In case mls_context_cpy() fails due to OOM set the free'd pointer in
context_cpy() to NULL to avoid it potentially being dereferenced or
free'd again in future.  Freeing a NULL pointer is well-defined and a
hard NULL dereference crash is at least not exploitable and should give
a workable stack trace.

Fixes: 12b29f34 ("selinux: support deferred mapping of contexts")
Signed-off-by: default avatarChristian Göttsche <cgzones@googlemail.com>
Signed-off-by: default avatarPaul Moore <paul@paul-moore.com>
parent 6f933aa7
...@@ -167,6 +167,7 @@ static inline int context_cpy(struct context *dst, const struct context *src) ...@@ -167,6 +167,7 @@ static inline int context_cpy(struct context *dst, const struct context *src)
rc = mls_context_cpy(dst, src); rc = mls_context_cpy(dst, src);
if (rc) { if (rc) {
kfree(dst->str); kfree(dst->str);
dst->str = NULL;
return rc; return rc;
} }
return 0; return 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