]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
svcrdma: bound check rq_pages index in inline path
authorJoshua Rogers <linux@joshua.hu>
Wed, 31 Dec 2025 22:44:24 +0000 (17:44 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 19 Jan 2026 12:10:08 +0000 (13:10 +0100)
[ Upstream commit d1bea0ce35b6095544ee82bb54156fc62c067e58 ]

svc_rdma_copy_inline_range indexed rqstp->rq_pages[rc_curpage] without
verifying rc_curpage stays within the allocated page array. Add guards
before the first use and after advancing to a new page.

Fixes: d7cc73972661 ("svcrdma: support multiple Read chunks per RPC")
Cc: stable@vger.kernel.org
Signed-off-by: Joshua Rogers <linux@joshua.hu>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
[ adapted rc_curpage and rq_maxpages fields to ri_pageno and RPCSVC_MAXPAGES constant ]
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/sunrpc/xprtrdma/svc_rdma_rw.c

index 270f5c3b8d91f5654a86d6e4f17a54c8c21115bf..5791c26cd916baa370d9e083341f4050c959d6ee 100644 (file)
@@ -789,6 +789,9 @@ static int svc_rdma_copy_inline_range(struct svc_rdma_read_info *info,
        for (page_no = 0; page_no < numpages; page_no++) {
                unsigned int page_len;
 
+               if (info->ri_pageno >= RPCSVC_MAXPAGES)
+                       return -EINVAL;
+
                page_len = min_t(unsigned int, remaining,
                                 PAGE_SIZE - info->ri_pageoff);