From: Marcin Niesluchowski Date: Tue, 19 Aug 2014 12:26:32 +0000 (+0200) Subject: Smack: Fix setting label on successful file open X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=2948accb198e6b7263a8d1dab9458ee152e15c81;p=platform%2Fkernel%2Flinux-stable.git Smack: Fix setting label on successful file open While opening with CAP_MAC_OVERRIDE file label is not set. Other calls may access it after CAP_MAC_OVERRIDE is dropped from process. Change-Id: I937d070e1c0cb251f4a0dd3291efbc94be3ca548 Signed-off-by: Marcin Niesluchowski Signed-off-by: Rafal Krypa Origin: git://git.gitorious.org/smack-next/kernel.git# smack-for-3.18 --- diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c index d347b7911a83..47ed6a484901 100644 --- a/security/smack/smack_lsm.c +++ b/security/smack/smack_lsm.c @@ -1477,8 +1477,10 @@ static int smack_file_open(struct file *file, const struct cred *cred) struct smk_audit_info ad; int rc; - if (smack_privileged(CAP_MAC_OVERRIDE)) + if (smack_privileged(CAP_MAC_OVERRIDE)) { + file->f_security = isp->smk_inode; return 0; + } smk_ad_init(&ad, __func__, LSM_AUDIT_DATA_PATH); smk_ad_setfield_u_fs_path(&ad, file->f_path);