Handle out-of-memory case in svc_tcp.c/svc_unix.c:rendezvous_request.
commit4b2e40a9259fab08161e1c607b06a41e15d543dc
authorStefan Liebler <stli@linux.ibm.com>
Fri, 4 Dec 2020 16:00:27 +0000 (4 17:00 +0100)
committerStefan Liebler <stli@linux.ibm.com>
Thu, 10 Dec 2020 10:11:20 +0000 (10 11:11 +0100)
treed9b01ed2133968f280d1a0d950fd7bd232ddd87a
parent0d4ed9d40efa84e8dc88e64cf337c8e95af7b045
Handle out-of-memory case in svc_tcp.c/svc_unix.c:rendezvous_request.

If glibc is build with -O3 on at least 390 (-m31) or x86 (-m32),
gcc 11 dumps this warning:
svc_tcp.c: In function 'rendezvous_request':
svc_tcp.c:274:3: error: 'memcpy' offset [0, 15] is out of the bounds [0, 0] [-Werror=array-bounds]
  274 |   memcpy (&xprt->xp_raddr, &addr, sizeof (addr));
      |   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cc1: all warnings being treated as errors

In out-of-memory case, if one of the mallocs in makefd_xprt function
returns NULL, a message is dumped, makefd_xprt returns NULL
and the subsequent memcpy would copy to NULL.

Instead of a segfaulting, we delay a bit (see also __svc_accept_failed
and Bug 14889 (CVE-2011-4609) - svc_run() produces high cpu usage when
accept() fails with EMFILE (CVE-2011-4609).

The same applies to svc_unix.c.
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
include/rpc/svc.h
sunrpc/svc.c
sunrpc/svc_tcp.c
sunrpc/svc_unix.c