Index: glibc-2.5-20061008T1257/sunrpc/svc_tcp.c =================================================================== --- glibc-2.5-20061008T1257.orig/sunrpc/svc_tcp.c +++ glibc-2.5-20061008T1257/sunrpc/svc_tcp.c @@ -50,6 +50,7 @@ static char sccsid[] = "@(#)svc_tcp.c 1. #include #include #include +#include #ifdef USE_IN_LIBIO # include @@ -249,6 +250,11 @@ again: { if (errno == EINTR) goto again; + if (errno == EMFILE) + { + struct timespec ts = { .tv_sec = 0, .tv_nsec = 50000000 }; + __nanosleep(&ts , NULL); + } return FALSE; } /* Index: glibc-2.5-20061008T1257/sunrpc/svc_udp.c =================================================================== --- glibc-2.5-20061008T1257.orig/sunrpc/svc_udp.c +++ glibc-2.5-20061008T1257/sunrpc/svc_udp.c @@ -46,6 +46,7 @@ static char sccsid[] = "@(#)svc_udp.c 1. #include #include #include +#include #ifdef IP_PKTINFO #include @@ -277,8 +278,16 @@ again: (int) su->su_iosz, 0, (struct sockaddr *) &(xprt->xp_raddr), &len); xprt->xp_addrlen = len; - if (rlen == -1 && errno == EINTR) - goto again; + if (rlen == -1) + { + if (errno == EINTR) + goto again; + if (errno == EMFILE) + { + struct timespec ts = { .tv_sec = 0, .tv_nsec = 50000000 }; + __nanosleep(&ts , NULL); + } + } if (rlen < 16) /* < 4 32-bit ints? */ return FALSE; xdrs->x_op = XDR_DECODE; Index: glibc-2.5-20061008T1257/sunrpc/svc_unix.c =================================================================== --- glibc-2.5-20061008T1257.orig/sunrpc/svc_unix.c +++ glibc-2.5-20061008T1257/sunrpc/svc_unix.c @@ -48,6 +48,7 @@ #include #include #include +#include #ifdef USE_IN_LIBIO # include @@ -247,6 +248,11 @@ again: { if (errno == EINTR) goto again; + if (errno == EMFILE) + { + struct timespec ts = { .tv_sec = 0, .tv_nsec = 50000000 }; + __nanosleep(&ts , NULL); + } return FALSE; } /*