Commit 61c0f234 authored by Jeff Layton's avatar Jeff Layton Committed by Ben Hutchings

cifs: always update the inode cache with the results from a FIND_*

commit cd60042c upstream.

When we get back a FIND_FIRST/NEXT result, we have some info about the
dentry that we use to instantiate a new inode. We were ignoring and
discarding that info when we had an existing dentry in the cache.

Fix this by updating the inode in place when we find an existing dentry
and the uniqueid is the same.
Reported-and-Tested-by: default avatarAndrew Bartlett <abartlet@samba.org>
Reported-by: default avatarBill Robertson <bill_robertson@debortoli.com.au>
Reported-by: default avatarDion Edwards <dion_edwards@debortoli.com.au>
Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
Signed-off-by: default avatarSteve French <smfrench@gmail.com>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 8e1e19fe
...@@ -86,9 +86,12 @@ cifs_readdir_lookup(struct dentry *parent, struct qstr *name, ...@@ -86,9 +86,12 @@ cifs_readdir_lookup(struct dentry *parent, struct qstr *name,
dentry = d_lookup(parent, name); dentry = d_lookup(parent, name);
if (dentry) { if (dentry) {
/* FIXME: check for inode number changes? */ inode = dentry->d_inode;
if (dentry->d_inode != NULL) /* update inode in place if i_ino didn't change */
if (inode && CIFS_I(inode)->uniqueid == fattr->cf_uniqueid) {
cifs_fattr_to_inode(inode, fattr);
return dentry; return dentry;
}
d_drop(dentry); d_drop(dentry);
dput(dentry); dput(dentry);
} }
......
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