[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20180801094651.7136-1-yuehaibing@huawei.com>
Date: Wed, 1 Aug 2018 17:46:51 +0800
From: YueHaibing <yuehaibing@...wei.com>
To: <davem@...emloft.net>, <dhowells@...hat.com>
CC: <linux-kernel@...r.kernel.org>, <netdev@...r.kernel.org>,
<linux-afs@...ts.infradead.org>, YueHaibing <yuehaibing@...wei.com>
Subject: [PATCH] rxrpc: Fix user ID check in rxrpc_service_prealloc_one
There just check the user ID isn't already in use, hence should
compare user_call_ID with xcall->user_call_ID, which is current
node's user_call_ID.
Fixes: 540b1c48c37a ("rxrpc: Fix deadlock between call creation and sendmsg/recvmsg")
Suggested-by: David Howells <dhowells@...hat.com>
Signed-off-by: YueHaibing <yuehaibing@...wei.com>
---
net/rxrpc/call_accept.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/net/rxrpc/call_accept.c b/net/rxrpc/call_accept.c
index a9a9be5..9d1e298 100644
--- a/net/rxrpc/call_accept.c
+++ b/net/rxrpc/call_accept.c
@@ -116,9 +116,9 @@ static int rxrpc_service_prealloc_one(struct rxrpc_sock *rx,
while (*pp) {
parent = *pp;
xcall = rb_entry(parent, struct rxrpc_call, sock_node);
- if (user_call_ID < call->user_call_ID)
+ if (user_call_ID < xcall->user_call_ID)
pp = &(*pp)->rb_left;
- else if (user_call_ID > call->user_call_ID)
+ else if (user_call_ID > xcall->user_call_ID)
pp = &(*pp)->rb_right;
else
goto id_in_use;
--
2.7.0
Powered by blists - more mailing lists