aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeff Layton <jlayton@redhat.com>2012-12-11 12:10:16 -0500
committerAl Viro <viro@zeniv.linux.org.uk>2012-12-20 18:50:10 -0500
commit10a90cf36efe0fca5c7719fd9b0299abd6be51aa (patch)
treed294e38f08018f63909faa02f56cedefd52f95a2
parent3a3e159dbfe405517584b09bbcefd72115d93342 (diff)
vfs: make listxattr retry once on ESTALE error
Signed-off-by: Jeff Layton <jlayton@redhat.com> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r--fs/xattr.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/fs/xattr.c b/fs/xattr.c
index c127d57bf655..1dc1eac17319 100644
--- a/fs/xattr.c
+++ b/fs/xattr.c
@@ -576,12 +576,17 @@ SYSCALL_DEFINE3(listxattr, const char __user *, pathname, char __user *, list,
576{ 576{
577 struct path path; 577 struct path path;
578 ssize_t error; 578 ssize_t error;
579 579 unsigned int lookup_flags = LOOKUP_FOLLOW;
580 error = user_path(pathname, &path); 580retry:
581 error = user_path_at(AT_FDCWD, pathname, lookup_flags, &path);
581 if (error) 582 if (error)
582 return error; 583 return error;
583 error = listxattr(path.dentry, list, size); 584 error = listxattr(path.dentry, list, size);
584 path_put(&path); 585 path_put(&path);
586 if (retry_estale(error, lookup_flags)) {
587 lookup_flags |= LOOKUP_REVAL;
588 goto retry;
589 }
585 return error; 590 return error;
586} 591}
587 592