• C
    NFSD: Fix possible sleep during nfsd4_release_lockowner() · ce3c4ad7
    Chuck Lever 提交于
    nfsd4_release_lockowner() holds clp->cl_lock when it calls
    check_for_locks(). However, check_for_locks() calls nfsd_file_get()
    / nfsd_file_put() to access the backing inode's flc_posix list, and
    nfsd_file_put() can sleep if the inode was recently removed.
    
    Let's instead rely on the stateowner's reference count to gate
    whether the release is permitted. This should be a reliable
    indication of locks-in-use since file lock operations and
    ->lm_get_owner take appropriate references, which are released
    appropriately when file locks are removed.
    Reported-by: NDai Ngo <dai.ngo@oracle.com>
    Signed-off-by: NChuck Lever <chuck.lever@oracle.com>
    Cc: stable@vger.kernel.org
    ce3c4ad7
nfs4state.c 204.6 KB