diff options
author | NeilBrown <neil@brown.name> | 2025-03-28 03:05:59 +0300 |
---|---|---|
committer | Chuck Lever <chuck.lever@oracle.com> | 2025-05-12 02:48:25 +0300 |
commit | 1244f0b2c3cecd3f349a877006e67c9492b41807 (patch) | |
tree | ff4c0eba905176e0ec9da92e5b51abcf9ed0559d | |
parent | 0813c5f01249dbc32ccbc68d27a24fde5bf2901c (diff) | |
download | linux-1244f0b2c3cecd3f349a877006e67c9492b41807.tar.xz |
nfsd: nfsd4_spo_must_allow() must check this is a v4 compound request
If the request being processed is not a v4 compound request, then
examining the cstate can have undefined results.
This patch adds a check that the rpc procedure being executed
(rq_procinfo) is the NFSPROC4_COMPOUND procedure.
Reported-by: Olga Kornievskaia <okorniev@redhat.com>
Cc: stable@vger.kernel.org
Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: NeilBrown <neil@brown.name>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
-rw-r--r-- | fs/nfsd/nfs4proc.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c index f5a06912ff8c..77895e099673 100644 --- a/fs/nfsd/nfs4proc.c +++ b/fs/nfsd/nfs4proc.c @@ -3777,7 +3777,8 @@ bool nfsd4_spo_must_allow(struct svc_rqst *rqstp) struct nfs4_op_map *allow = &cstate->clp->cl_spo_must_allow; u32 opiter; - if (!cstate->minorversion) + if (rqstp->rq_procinfo != &nfsd_version4.vs_proc[NFSPROC4_COMPOUND] || + cstate->minorversion == 0) return false; if (cstate->spo_must_allowed) |