Return-Path: Received: from mx1.redhat.com ([209.132.183.28]:41462 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932946AbbLGQ0P (ORCPT ); Mon, 7 Dec 2015 11:26:15 -0500 From: Benjamin Coddington To: "J. Bruce Fields" , Jeff Layton , Trond Myklebust , Anna Schumaker , hch@infradead.org Cc: linux-nfs@vger.kernel.org Subject: [PATCH v2 00/10] locking fixups for NFS Date: Mon, 7 Dec 2015 11:25:59 -0500 Message-Id: Sender: linux-nfs-owner@vger.kernel.org List-ID: This set addresses a few NFS related locking issues as well as a couple minor cleanups. It does a bit of plumbing to make sure we can complete unlocks after close when the fl_file may be unavailable, and it attempts to always release locks even when a wait for oustanding IO is interrupted before sending an unlock. This can orphan a lock on a server, which might mean a delay for matching lock NFS4, or require a server restart to clean up that lock for NFS3. Changes for v2: - the change to move do_vfs_lock() to a shared inline has been removed - added patch to set FL_CLOSE for flock unlock on close (08/10) - instead of keeping a copied list of deferred file_locks to unlock, just send an unlock for the entire file if FL_CLOSE is set. Benjamin Coddington (10): NFS4: remove a redundant lock range check NFS: Move the flock open mode check into nfs_flock() NFS: Pass nfs_open_context instead of file to the lock procs NFSv4: Pass nfs_open_context instead of nfs4_state to nfs4_proc_unlck() lockd: Plumb nfs_open_context into nlm client unlock lockd: Send the inode to nlmclnt_setlockargs() lockd: do_vfs_lock() only needs the inode locks: Set FL_CLOSE when removing flock locks on close() NFS: Deferred unlocks - always unlock on FL_CLOSE NFS: cleanup do_vfs_lock() fs/lockd/clntproc.c | 41 +++++++++++++++++---------------- fs/locks.c | 2 +- fs/nfs/file.c | 53 ++++++++++++++++++++++++++++++++++---------- fs/nfs/inode.c | 22 ++++++++++++++++++ fs/nfs/nfs3proc.c | 6 +--- fs/nfs/nfs4proc.c | 45 ++++++++++-------------------------- fs/nfs/pagelist.c | 8 +++++- fs/nfs/proc.c | 6 +--- include/linux/lockd/bind.h | 3 +- include/linux/nfs_fs.h | 3 ++ include/linux/nfs_xdr.h | 2 +- 11 files changed, 114 insertions(+), 77 deletions(-)