]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
smack: Handle SMACK64TRANSMUTE in smack_inode_setsecurity()
authorRoberto Sassu <roberto.sassu@huawei.com>
Thu, 16 Nov 2023 09:01:22 +0000 (10:01 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 13 Apr 2024 10:58:00 +0000 (12:58 +0200)
[ Upstream commit ac02f007d64eb2769d0bde742aac4d7a5fc6e8a5 ]

If the SMACK64TRANSMUTE xattr is provided, and the inode is a directory,
update the in-memory inode flags by setting SMK_INODE_TRANSMUTE.

Cc: stable@vger.kernel.org
Fixes: 5c6d1125f8db ("Smack: Transmute labels on specified directories") # v2.6.38.x
Signed-off-by: Roberto Sassu <roberto.sassu@huawei.com>
Signed-off-by: Casey Schaufler <casey@schaufler-ca.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
security/smack/smack_lsm.c

index 0be25e05c1a03dc786d540fb440d16d9e2e4122f..750f6007bbbb0b436e774a0d383ebf77a252e98d 100644 (file)
@@ -2722,6 +2722,15 @@ static int smack_inode_setsecurity(struct inode *inode, const char *name,
        if (value == NULL || size > SMK_LONGLABEL || size == 0)
                return -EINVAL;
 
+       if (strcmp(name, XATTR_SMACK_TRANSMUTE) == 0) {
+               if (!S_ISDIR(inode->i_mode) || size != TRANS_TRUE_SIZE ||
+                   strncmp(value, TRANS_TRUE, TRANS_TRUE_SIZE) != 0)
+                       return -EINVAL;
+
+               nsp->smk_flags |= SMK_INODE_TRANSMUTE;
+               return 0;
+       }
+
        skp = smk_import_entry(value, size);
        if (IS_ERR(skp))
                return PTR_ERR(skp);