]> git.hungrycats.org Git - linux/commitdiff
Revert "NFSv4: Remove incorrect check in can_open_delegated()"
authorTrond Myklebust <trond.myklebust@primarydata.com>
Wed, 19 Aug 2015 05:14:20 +0000 (00:14 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 29 Sep 2015 17:26:10 +0000 (19:26 +0200)
commit 36319608e28701c07cad80ae3be8b0fdfb1ab40f upstream.

This reverts commit 4e379d36c050b0117b5d10048be63a44f5036115.

This commit opens up a race between the recovery code and the open code.

Reported-by: Olga Kornievskaia <aglo@umich.edu>
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/nfs/nfs4proc.c

index d69bd6ae0ff017208d525fb0324b3173ad39e04c..c245874d7e9d0d6e82f25fdf2c7251e6ffda6163 100644 (file)
@@ -1152,6 +1152,8 @@ static int can_open_delegated(struct nfs_delegation *delegation, fmode_t fmode)
                return 0;
        if ((delegation->type & fmode) != fmode)
                return 0;
+       if (test_bit(NFS_DELEGATION_NEED_RECLAIM, &delegation->flags))
+               return 0;
        if (test_bit(NFS_DELEGATION_RETURNING, &delegation->flags))
                return 0;
        nfs_mark_delegation_referenced(delegation);