From: Xiu Jianfeng Date: Mon, 13 Jun 2022 13:59:53 +0000 (+0800) Subject: selinux: fix memleak in security_read_state_kernel() X-Git-Tag: v6.0-rc1~172^2~2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=73de1befcc53a7c68b0c5e76b9b5ac41c517760f;p=thirdparty%2Fkernel%2Flinux.git selinux: fix memleak in security_read_state_kernel() In this function, it directly returns the result of __security_read_policy without freeing the allocated memory in *data, cause memory leak issue, so free the memory if __security_read_policy failed. Signed-off-by: Xiu Jianfeng [PM: subject line tweak] Signed-off-by: Paul Moore --- diff --git a/security/selinux/ss/services.c b/security/selinux/ss/services.c index 69b2734311a69..fe5fcf571c564 100644 --- a/security/selinux/ss/services.c +++ b/security/selinux/ss/services.c @@ -4048,6 +4048,7 @@ int security_read_policy(struct selinux_state *state, int security_read_state_kernel(struct selinux_state *state, void **data, size_t *len) { + int err; struct selinux_policy *policy; policy = rcu_dereference_protected( @@ -4060,5 +4061,11 @@ int security_read_state_kernel(struct selinux_state *state, if (!*data) return -ENOMEM; - return __security_read_policy(policy, *data, len); + err = __security_read_policy(policy, *data, len); + if (err) { + vfree(*data); + *data = NULL; + *len = 0; + } + return err; }