Message ID | 1395843863-12038-1-git-send-email-jlayton@redhat.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Fixed minor typo in comments and merged into cifs-2.6.git On Wed, Mar 26, 2014 at 9:24 AM, Jeff Layton <jlayton@redhat.com> wrote: > actimeo=0 is supposed to be a special case that ensures that inode > attributes are always refetched from the server instead of trusting the > cache. The cifs code however uses time_in_range() to determine whether > the attributes have timed out. In the case where cifs_i->time equals > jiffies, this leads to the cifs code not refetching the inode attributes > when it should. > > Fix this by explicitly testing for actimeo=0, and handling it as a > special case. > > Reported-and-Tested-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> > Signed-off-by: Jeff Layton <jlayton@redhat.com> > --- > fs/cifs/inode.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c > index aadc2b68678b..a22d667f1069 100644 > --- a/fs/cifs/inode.c > +++ b/fs/cifs/inode.c > @@ -1737,6 +1737,9 @@ cifs_inode_needs_reval(struct inode *inode) > if (cifs_i->time == 0) > return true; > > + if (!cifs_sb->actimeo) > + return true; > + > if (!time_in_range(jiffies, cifs_i->time, > cifs_i->time + cifs_sb->actimeo)) > return true; > -- > 1.8.5.3 >
diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c index aadc2b68678b..a22d667f1069 100644 --- a/fs/cifs/inode.c +++ b/fs/cifs/inode.c @@ -1737,6 +1737,9 @@ cifs_inode_needs_reval(struct inode *inode) if (cifs_i->time == 0) return true; + if (!cifs_sb->actimeo) + return true; + if (!time_in_range(jiffies, cifs_i->time, cifs_i->time + cifs_sb->actimeo)) return true;
actimeo=0 is supposed to be a special case that ensures that inode attributes are always refetched from the server instead of trusting the cache. The cifs code however uses time_in_range() to determine whether the attributes have timed out. In the case where cifs_i->time equals jiffies, this leads to the cifs code not refetching the inode attributes when it should. Fix this by explicitly testing for actimeo=0, and handling it as a special case. Reported-and-Tested-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> Signed-off-by: Jeff Layton <jlayton@redhat.com> --- fs/cifs/inode.c | 3 +++ 1 file changed, 3 insertions(+)