From 92c2d312aa0de09b9ccbf0f8c4e6675961e539f5 Mon Sep 17 00:00:00 2001 From: Jeff Layton Date: Thu, 20 Dec 2012 16:28:33 -0500 Subject: [PATCH] --- yaml --- r: 347848 b: refs/heads/master c: c6ee920698301febdf10df0b57039173a1edbd43 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/fs/namei.c | 9 +++++++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index 19b09bb61308..754afe784b45 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 9e790bd65ce4cbfdff305a57b67b1a2cbe5d4335 +refs/heads/master: c6ee920698301febdf10df0b57039173a1edbd43 diff --git a/trunk/fs/namei.c b/trunk/fs/namei.c index 19190618695f..fe06a2fd1925 100644 --- a/trunk/fs/namei.c +++ b/trunk/fs/namei.c @@ -3339,8 +3339,9 @@ static long do_rmdir(int dfd, const char __user *pathname) struct filename *name; struct dentry *dentry; struct nameidata nd; - - name = user_path_parent(dfd, pathname, &nd, 0); + unsigned int lookup_flags = 0; +retry: + name = user_path_parent(dfd, pathname, &nd, lookup_flags); if (IS_ERR(name)) return PTR_ERR(name); @@ -3382,6 +3383,10 @@ static long do_rmdir(int dfd, const char __user *pathname) exit1: path_put(&nd.path); putname(name); + if (retry_estale(error, lookup_flags)) { + lookup_flags |= LOOKUP_REVAL; + goto retry; + } return error; }