diff options
author | Benjamin Coddington <bcodding@redhat.com> | 2019-05-09 13:25:21 +0200 |
---|---|---|
committer | Anna Schumaker <Anna.Schumaker@Netapp.com> | 2019-05-09 22:26:57 +0200 |
commit | c260121a97a3e4df6536edbc2f26e166eff370ce (patch) | |
tree | a57d62086cbea2fcf95ee2e10a80349b23ef993b /fs/nfs | |
parent | nfs: pass the correct prototype to read_cache_page (diff) | |
download | linux-c260121a97a3e4df6536edbc2f26e166eff370ce.tar.xz linux-c260121a97a3e4df6536edbc2f26e166eff370ce.zip |
NFS: Fix a double unlock from nfs_match,get_client
Now that nfs_match_client drops the nfs_client_lock, we should be
careful
to always return it in the same condition: locked.
Fixes: 950a578c6128 ("NFS: make nfs_match_client killable")
Reported-by: syzbot+228a82b263b5da91883d@syzkaller.appspotmail.com
Signed-off-by: Benjamin Coddington <bcodding@redhat.com>
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
Diffstat (limited to '')
-rw-r--r-- | fs/nfs/client.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/nfs/client.c b/fs/nfs/client.c index 06e8719655f0..da74c4c4a244 100644 --- a/fs/nfs/client.c +++ b/fs/nfs/client.c @@ -299,9 +299,9 @@ again: spin_unlock(&nn->nfs_client_lock); error = nfs_wait_client_init_complete(clp); nfs_put_client(clp); + spin_lock(&nn->nfs_client_lock); if (error < 0) return ERR_PTR(error); - spin_lock(&nn->nfs_client_lock); goto again; } |