summaryrefslogtreecommitdiffstats
path: root/net/rxrpc/call_accept.c
diff options
context:
space:
mode:
authorDavid Howells <dhowells@redhat.com>2016-09-17 11:49:11 +0200
committerDavid Howells <dhowells@redhat.com>2016-09-17 11:51:54 +0200
commite6f3afb3fc058e17b407b6f7cac08058b19e641c (patch)
tree07216f88a9bbc47c758d23e37a25e753b316b25b /net/rxrpc/call_accept.c
parentrxrpc: Fix handling of the last packet in rxrpc_recvmsg_data() (diff)
downloadlinux-e6f3afb3fc058e17b407b6f7cac08058b19e641c.tar.xz
linux-e6f3afb3fc058e17b407b6f7cac08058b19e641c.zip
rxrpc: Record calls that need to be accepted
Record calls that need to be accepted using sk_acceptq_added() otherwise the backlog counter goes negative because sk_acceptq_removed() is called. This causes the preallocator to malfunction. Calls that are preaccepted by AFS within the kernel aren't affected by this. Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'net/rxrpc/call_accept.c')
-rw-r--r--net/rxrpc/call_accept.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/net/rxrpc/call_accept.c b/net/rxrpc/call_accept.c
index 26c293ef98eb..323b8da50163 100644
--- a/net/rxrpc/call_accept.c
+++ b/net/rxrpc/call_accept.c
@@ -369,6 +369,8 @@ found_service:
if (rx->notify_new_call)
rx->notify_new_call(&rx->sk, call, call->user_call_ID);
+ else
+ sk_acceptq_added(&rx->sk);
spin_lock(&conn->state_lock);
switch (conn->state) {