SMACK: Fix the memory leak in smack_cred_prepare() hook
authorHimanshu Shukla <himanshu.sh@samsung.com>
Thu, 10 Nov 2016 10:47:02 +0000 (16:17 +0530)
committerCasey Schaufler <casey@schaufler-ca.com>
Thu, 10 Nov 2016 19:22:06 +0000 (11:22 -0800)
commitb437aba85b5c4689543409d8407c016749231aae
tree9f03c18907323f8703571b2e87dc31cd83907152
parent7128ea159d60a91b3f0a7d10a1ea7d62b53cda93
SMACK: Fix the memory leak in smack_cred_prepare() hook

Memory leak in smack_cred_prepare()function.
smack_cred_prepare() hook returns error if there is error in allocating
memory in smk_copy_rules() or smk_copy_relabel() function.
If smack_cred_prepare() function returns error then the calling
function should call smack_cred_free() function for cleanup.
In smack_cred_free() function first credential is  extracted and
then all rules are deleted. In smack_cred_prepare() function security
field is assigned in the end when all function return success. But this
function may return before and memory will not be freed.

Signed-off-by: Himanshu Shukla <himanshu.sh@samsung.com>
Acked-by: Casey Schaufler <casey@schaufler-ca.com>
security/smack/smack_lsm.c