Signed-off-by: Jeff Layton <jlay...@primarydata.com>
---
 fs/nfsd/nfs4state.c | 18 +++++++++++-------
 1 file changed, 11 insertions(+), 7 deletions(-)

diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
index c4c8d0621dde..4fc1a2f98d1e 100644
--- a/fs/nfsd/nfs4state.c
+++ b/fs/nfsd/nfs4state.c
@@ -5490,10 +5490,11 @@ out_nfserr:
 static bool
 check_for_locks(struct nfs4_file *fp, struct nfs4_lockowner *lowner)
 {
-       struct file_lock **flpp;
+       struct file_lock *fl;
        int status = false;
        struct file *filp = find_any_file(fp);
        struct inode *inode;
+       struct file_lock_context *flctx;
 
        if (!filp) {
                /* Any valid lock stateid should have some sort of access */
@@ -5502,15 +5503,18 @@ check_for_locks(struct nfs4_file *fp, struct 
nfs4_lockowner *lowner)
        }
 
        inode = file_inode(filp);
+       flctx = inode->i_flctx;
 
-       spin_lock(&inode->i_lock);
-       for (flpp = &inode->i_flock; *flpp != NULL; flpp = &(*flpp)->fl_next) {
-               if ((*flpp)->fl_owner == (fl_owner_t)lowner) {
-                       status = true;
-                       break;
+       if (flctx) {
+               spin_lock(&flctx->flc_lock);
+               list_for_each_entry(fl, &flctx->flc_posix, fl_list) {
+                       if (fl->fl_owner == (fl_owner_t)lowner) {
+                               status = true;
+                               break;
+                       }
                }
+               spin_unlock(&flctx->flc_lock);
        }
-       spin_unlock(&inode->i_lock);
        fput(filp);
        return status;
 }
-- 
1.9.3

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to