From: Trond Myklebust Date: Tue, 2 Aug 2022 19:48:50 +0000 (-0400) Subject: NFSv4/pnfs: Fix a use-after-free bug in open X-Git-Tag: v6.0-rc1~38^2~4 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2135e5d56278ffdb1c2e6d325dc6b87f669b9dac;p=thirdparty%2Fkernel%2Flinux.git NFSv4/pnfs: Fix a use-after-free bug in open If someone cancels the open RPC call, then we must not try to free either the open slot or the layoutget operation arguments, since they are likely still in use by the hung RPC call. Fixes: 6949493884fe ("NFSv4: Don't hold the layoutget locks across multiple RPC calls") Signed-off-by: Trond Myklebust --- diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 2d7c14ade1932..3ed14a2a84a44 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -3096,12 +3096,13 @@ static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, } out: - if (opendata->lgp) { - nfs4_lgopen_release(opendata->lgp); - opendata->lgp = NULL; - } - if (!opendata->cancelled) + if (!opendata->cancelled) { + if (opendata->lgp) { + nfs4_lgopen_release(opendata->lgp); + opendata->lgp = NULL; + } nfs4_sequence_free_slot(&opendata->o_res.seq_res); + } return ret; }