Commit 66c9314b authored by Paulo Alcantara's avatar Paulo Alcantara Committed by Steve French

smb: client: don't clobber ->i_rdev from cached reparse points

Don't clobber ->i_rdev from valid reparse inodes over readdir(2) as it
can't be provided by query dir responses.
Signed-off-by: default avatarPaulo Alcantara <pc@manguebit.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent f83709b9
...@@ -133,14 +133,14 @@ cifs_prime_dcache(struct dentry *parent, struct qstr *name, ...@@ -133,14 +133,14 @@ cifs_prime_dcache(struct dentry *parent, struct qstr *name,
* Query dir responses don't provide enough * Query dir responses don't provide enough
* information about reparse points other than * information about reparse points other than
* their reparse tags. Save an invalidation by * their reparse tags. Save an invalidation by
* not clobbering the existing mode, size and * not clobbering some existing attributes when
* symlink target (if any) when reparse tag and * reparse tag and ctime haven't changed.
* ctime haven't changed.
*/ */
rc = 0; rc = 0;
if (fattr->cf_cifsattrs & ATTR_REPARSE) { if (fattr->cf_cifsattrs & ATTR_REPARSE) {
if (likely(reparse_inode_match(inode, fattr))) { if (likely(reparse_inode_match(inode, fattr))) {
fattr->cf_mode = inode->i_mode; fattr->cf_mode = inode->i_mode;
fattr->cf_rdev = inode->i_rdev;
fattr->cf_eof = CIFS_I(inode)->server_eof; fattr->cf_eof = CIFS_I(inode)->server_eof;
fattr->cf_symlink_target = NULL; fattr->cf_symlink_target = NULL;
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment