Commit 176306f59ac7a35369cbba87aff13e14c5916074

Authored by Neil Brown
Committed by Al Viro
1 parent 1eb2cbb6d5

VFS: fix recent breakage of FS_REVAL_DOT

Commit 1f36f774b22a0ceb7dd33eca626746c81a97b6a5 broke FS_REVAL_DOT semantics.

In particular, before this patch, the command
   ls -l
in an NFS mounted directory would always check if the directory on the server
had changed and if so would flush and refill the pagecache for the dir.
After this patch, the same "ls -l" will repeatedly return stale date until
the cached attributes for the directory time out.

The following patch fixes this by ensuring the d_revalidate is called by
do_last when "." is being looked-up.
link_path_walk has already called d_revalidate, but in that case LOOKUP_OPEN
is not set so nfs_lookup_verify_inode chooses not to do any validation.

The following patch restores the original behaviour.

Cc: stable@kernel.org
Signed-off-by: NeilBrown <neilb@suse.de>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>

Showing 1 changed file with 1 additions and 1 deletions Side-by-side Diff

... ... @@ -1621,6 +1621,7 @@
1621 1621 case LAST_DOTDOT:
1622 1622 follow_dotdot(nd);
1623 1623 dir = nd->path.dentry;
  1624 + case LAST_DOT:
1624 1625 if (nd->path.mnt->mnt_sb->s_type->fs_flags & FS_REVAL_DOT) {
1625 1626 if (!dir->d_op->d_revalidate(dir, nd)) {
1626 1627 error = -ESTALE;
... ... @@ -1628,7 +1629,6 @@
1628 1629 }
1629 1630 }
1630 1631 /* fallthrough */
1631   - case LAST_DOT:
1632 1632 case LAST_ROOT:
1633 1633 if (open_flag & O_CREAT)
1634 1634 goto exit;