sunrpc: fix peername failed on closed listener
authorXiaotian Feng <>
Thu, 31 Dec 2009 02:52:36 +0000 (10:52 +0800)
committerJ. Bruce Fields <>
Wed, 6 Jan 2010 22:38:04 +0000 (17:38 -0500)
There're some warnings of "nfsd: peername failed (err 107)!"
socket error -107 means Transport endpoint is not connected.
This warning message was outputed by svc_tcp_accept() [net/sunrpc/svcsock.c],
when kernel_getpeername returns -107. This means socket might be CLOSED.

And svc_tcp_accept was called by svc_recv() [net/sunrpc/svc_xprt.c]

        if (test_bit(XPT_LISTENER, &xprt->xpt_flags)) {
                newxpt = xprt->xpt_ops->xpo_accept(xprt);

So this might happen when xprt->xpt_flags has both XPT_LISTENER and XPT_CLOSE.

Let's take a look at commit b0401d72, this commit has moved the close
processing after do recvfrom method, but this commit also introduces this
warnings, if the xpt_flags has both XPT_LISTENER and XPT_CLOSED, we should
close it, not accpet then close.

Signed-off-by: Xiaotian Feng <>
Cc: J. Bruce Fields <>
Cc: Neil Brown <>
Cc: Trond Myklebust <>
Cc: David S. Miller <>
Signed-off-by: J. Bruce Fields <>

index 2c58b75a236f1db692ca8c368546381f1ea510ac..810ffe8a636b5f9197e6a9c21a59641f7151b0ac 100644 (file)
@@ -699,7 +699,8 @@ int svc_recv(struct svc_rqst *rqstp, long timeout)
        len = 0;
-       if (test_bit(XPT_LISTENER, &xprt->xpt_flags)) {
+       if (test_bit(XPT_LISTENER, &xprt->xpt_flags) &&
+           !test_bit(XPT_CLOSE, &xprt->xpt_flags)) {
                struct svc_xprt *newxpt;
                newxpt = xprt->xpt_ops->xpo_accept(xprt);
                if (newxpt) {