提交 5dc84855 编写于 作者: D David Howells

afs: Only update d_fsdata if different in afs_d_revalidate()

In the in-kernel afs filesystem, d_fsdata is set with the data version of
the parent directory.  afs_d_revalidate() will update this to the current
directory version, but it shouldn't do this if it the value it read from
d_fsdata is the same as no lock is held and cmpxchg() is not used.

Fix the code to only change the value if it is different from the current
directory version.

Fixes: 260a9803 ("[AFS]: Add "directory write" support.")
Signed-off-by: NDavid Howells <dhowells@redhat.com>
上级 37c0bbb3
...@@ -1017,7 +1017,7 @@ static int afs_d_revalidate(struct dentry *dentry, unsigned int flags) ...@@ -1017,7 +1017,7 @@ static int afs_d_revalidate(struct dentry *dentry, unsigned int flags)
dir_version = (long)dir->status.data_version; dir_version = (long)dir->status.data_version;
de_version = (long)dentry->d_fsdata; de_version = (long)dentry->d_fsdata;
if (de_version == dir_version) if (de_version == dir_version)
goto out_valid; goto out_valid_noupdate;
dir_version = (long)dir->invalid_before; dir_version = (long)dir->invalid_before;
if (de_version - dir_version >= 0) if (de_version - dir_version >= 0)
...@@ -1081,6 +1081,7 @@ static int afs_d_revalidate(struct dentry *dentry, unsigned int flags) ...@@ -1081,6 +1081,7 @@ static int afs_d_revalidate(struct dentry *dentry, unsigned int flags)
out_valid: out_valid:
dentry->d_fsdata = (void *)dir_version; dentry->d_fsdata = (void *)dir_version;
out_valid_noupdate:
dput(parent); dput(parent);
key_put(key); key_put(key);
_leave(" = 1 [valid]"); _leave(" = 1 [valid]");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册