From: Trond Myklebust Date: Thu, 7 Apr 2022 18:10:23 +0000 (-0400) Subject: SUNRPC: svc_tcp_sendmsg() should handle errors from xdr_alloc_bvec() X-Git-Tag: v6.1-rc5~1593^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b056fa070814897be32d83b079dbc311375588e7;p=platform%2Fkernel%2Flinux-starfive.git SUNRPC: svc_tcp_sendmsg() should handle errors from xdr_alloc_bvec() The allocation is done with GFP_KERNEL, but it could still fail in a low memory situation. Fixes: 4a85a6a3320b ("SUNRPC: Handle TCP socket sends with kernel_sendpage() again") Signed-off-by: Trond Myklebust --- diff --git a/net/sunrpc/svcsock.c b/net/sunrpc/svcsock.c index 478f857..6ea3d87 100644 --- a/net/sunrpc/svcsock.c +++ b/net/sunrpc/svcsock.c @@ -1096,7 +1096,9 @@ static int svc_tcp_sendmsg(struct socket *sock, struct xdr_buf *xdr, int ret; *sentp = 0; - xdr_alloc_bvec(xdr, GFP_KERNEL); + ret = xdr_alloc_bvec(xdr, GFP_KERNEL); + if (ret < 0) + return ret; ret = kernel_sendmsg(sock, &msg, &rm, 1, rm.iov_len); if (ret < 0)