mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
rxrpc: Reduce the rxrpc_local::services list to a pointer
Reduce the rxrpc_local::services list to just a pointer as we don't permit multiple service endpoints to bind to a single transport endpoints (this is excluded by rxrpc_lookup_local()). The reason we don't allow this is that if you send a request to an AFS filesystem service, it will try to talk back to your cache manager on the port you sent from (this is how file change notifications are handled). To prevent someone from stealing your CM callbacks, we don't let AF_RXRPC sockets share a UDP socket if at least one of them has a service bound. Signed-off-by: David Howells <dhowells@redhat.com>
This commit is contained in:
parent
2629c7fa7c
commit
1e9e5c9521
5 changed files with 18 additions and 25 deletions
|
@ -86,7 +86,6 @@ static struct rxrpc_local *rxrpc_alloc_local(const struct sockaddr_rxrpc *srx)
|
|||
atomic_set(&local->usage, 1);
|
||||
INIT_LIST_HEAD(&local->link);
|
||||
INIT_WORK(&local->processor, rxrpc_local_processor);
|
||||
INIT_HLIST_HEAD(&local->services);
|
||||
init_rwsem(&local->defrag_sem);
|
||||
skb_queue_head_init(&local->reject_queue);
|
||||
skb_queue_head_init(&local->event_queue);
|
||||
|
@ -292,7 +291,7 @@ static void rxrpc_local_destroyer(struct rxrpc_local *local)
|
|||
mutex_unlock(&rxrpc_local_mutex);
|
||||
|
||||
ASSERT(RB_EMPTY_ROOT(&local->client_conns));
|
||||
ASSERT(hlist_empty(&local->services));
|
||||
ASSERT(!local->service);
|
||||
|
||||
if (socket) {
|
||||
local->socket = NULL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue