summaryrefslogtreecommitdiffstats
path: root/net/rxrpc/local_event.c
diff options
context:
space:
mode:
authorDavid Howells <dhowells@redhat.com>2017-08-29 10:18:37 +0100
committerDavid Howells <dhowells@redhat.com>2017-08-29 10:55:20 +0100
commit7b674e390e513ea443c5a0f27ec95e93fb8a94fa (patch)
tree21ed0fb6ec3d190608bf72cbf9e3776d7e296fbe /net/rxrpc/local_event.c
parent0a3785855edcdb326ebf052c4f92ebc2710614c6 (diff)
downloadlinux-stable-7b674e390e513ea443c5a0f27ec95e93fb8a94fa.tar.gz
linux-stable-7b674e390e513ea443c5a0f27ec95e93fb8a94fa.tar.bz2
linux-stable-7b674e390e513ea443c5a0f27ec95e93fb8a94fa.zip
rxrpc: Fix IPv6 support
Fix IPv6 support in AF_RXRPC in the following ways: (1) When extracting the address from a received IPv4 packet, if the local transport socket is open for IPv6 then fill out the sockaddr_rxrpc struct for an IPv4-mapped-to-IPv6 AF_INET6 transport address instead of an AF_INET one. (2) When sending CHALLENGE or RESPONSE packets, the transport length needs to be set from the sockaddr_rxrpc::transport_len field rather than sizeof() on the IPv4 transport address. (3) When processing an IPv4 ICMP packet received by an IPv6 socket, set up the address correctly before searching for the affected peer. Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'net/rxrpc/local_event.c')
-rw-r--r--net/rxrpc/local_event.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/net/rxrpc/local_event.c b/net/rxrpc/local_event.c
index 540d3955c1bc..93b5d910b4a1 100644
--- a/net/rxrpc/local_event.c
+++ b/net/rxrpc/local_event.c
@@ -39,7 +39,7 @@ static void rxrpc_send_version_request(struct rxrpc_local *local,
_enter("");
- if (rxrpc_extract_addr_from_skb(&srx, skb) < 0)
+ if (rxrpc_extract_addr_from_skb(local, &srx, skb) < 0)
return;
msg.msg_name = &srx.transport;