Skip to content

Commit a9a315d

Browse files
spuiuksmfrench
authored andcommitted
cifs: Fix check for regular file in couldbe_mf_symlink()
MF Symlinks are regular files containing content in a specified format. The function couldbe_mf_symlink() checks the mode for a set S_IFREG bit as a test to confirm that it is a regular file. This bit is also set for other filetypes and simply checking for this bit being set may return false positives. We ensure that we are actually checking for a regular file by using the S_ISREG macro to test instead. Signed-off-by: Sachin Prabhu <sprabhu@redhat.com> Reviewed-by: Jeff Layton <jlayton@redhat.com> Reported-by: Neil Brown <neilb@suse.de> Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Steve French <smfrench@gmail.com>
1 parent 666753c commit a9a315d

File tree

1 file changed

+1
-1
lines changed

1 file changed

+1
-1
lines changed

fs/cifs/link.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -185,7 +185,7 @@ format_mf_symlink(u8 *buf, unsigned int buf_len, const char *link_str)
185185
bool
186186
couldbe_mf_symlink(const struct cifs_fattr *fattr)
187187
{
188-
if (!(fattr->cf_mode & S_IFREG))
188+
if (!S_ISREG(fattr->cf_mode))
189189
/* it's not a symlink */
190190
return false;
191191

0 commit comments

Comments
 (0)