From: Chuck Lever Date: Thu, 17 Oct 2024 15:03:53 +0000 (-0400) Subject: NFSD: Prevent NULL dereference in nfsd4_process_cb_update() X-Git-Tag: v6.13-rc1~76^2~31 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1e02c641c3a43c88cecc08402000418e15578d38;p=thirdparty%2Flinux.git NFSD: Prevent NULL dereference in nfsd4_process_cb_update() @ses is initialized to NULL. If __nfsd4_find_backchannel() finds no available backchannel session, setup_callback_client() will try to dereference @ses and segfault. Fixes: dcbeaa68dbbd ("nfsd4: allow backchannel recovery") Reviewed-by: Jeff Layton Signed-off-by: Chuck Lever --- diff --git a/fs/nfsd/nfs4callback.c b/fs/nfsd/nfs4callback.c index f5ba9be917700..1ffac2b32d81a 100644 --- a/fs/nfsd/nfs4callback.c +++ b/fs/nfsd/nfs4callback.c @@ -1464,6 +1464,8 @@ static void nfsd4_process_cb_update(struct nfsd4_callback *cb) ses = c->cn_session; } spin_unlock(&clp->cl_lock); + if (!c) + return; err = setup_callback_client(clp, &conn, ses); if (err) {