aboutsummaryrefslogtreecommitdiffstats
path: root/security/smack/smack_lsm.c
diff options
context:
space:
mode:
authorJosé Bollo <jose.bollo@open.eurogiciel.org>2014-01-08 09:53:05 -0500
committerCasey Schaufler <casey@schaufler-ca.com>2014-04-11 17:33:59 -0400
commit55dfc5da1a9b7e623b6f35620c74280555df0288 (patch)
tree684c885270fdf52de7639aba8ebcc4dd86836b96 /security/smack/smack_lsm.c
parentf64410ec665479d7b4b77b7519e814253ed0f686 (diff)
Minor improvement of 'smack_sb_kern_mount'
Fix a possible memory access fault when transmute is true and isp is NULL. Signed-off-by: José Bollo <jose.bollo@open.eurogiciel.org>
Diffstat (limited to 'security/smack/smack_lsm.c')
-rw-r--r--security/smack/smack_lsm.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c
index d814e35987be..efa42991235e 100644
--- a/security/smack/smack_lsm.c
+++ b/security/smack/smack_lsm.c
@@ -413,9 +413,11 @@ static int smack_sb_kern_mount(struct super_block *sb, int flags, void *data)
413 * Initialize the root inode. 413 * Initialize the root inode.
414 */ 414 */
415 isp = inode->i_security; 415 isp = inode->i_security;
416 if (inode->i_security == NULL) { 416 if (isp == NULL) {
417 inode->i_security = new_inode_smack(sp->smk_root); 417 isp = new_inode_smack(sp->smk_root);
418 isp = inode->i_security; 418 if (isp == NULL)
419 return -ENOMEM;
420 inode->i_security = isp;
419 } else 421 } else
420 isp->smk_inode = sp->smk_root; 422 isp->smk_inode = sp->smk_root;
421 423