net: diag: make udp_diag_destroy work for mapped addresses.
authorLorenzo Colitti <lorenzo@google.com>
Wed, 7 Sep 2016 04:38:35 +0000 (13:38 +0900)
committerLorenzo Colitti <lorenzo@google.com>
Sun, 18 Sep 2016 17:26:27 +0000 (02:26 +0900)
udp_diag_destroy does look up the IPv4 UDP hashtable for mapped
addresses, but it gets the IPv4 address to look up from the
beginning of the IPv6 address instead of the end.

[cherry-pick of net-next f95bf346226b9b79352e05508beececc807cc37a]

Change-Id: Ia369482c4645bcade320b2c33a763f1ce4378ff1
Tested: https://android-review.googlesource.com/269874
Fixes: 5d77dca82839 ("net: diag: support SOCK_DESTROY for UDP sockets")
Signed-off-by: Lorenzo Colitti <lorenzo@google.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Acked-by: David Ahern <dsa@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/udp_diag.c

index 8b9570c84fd52a15c563506c82aa9d615b1b81c6..39e0b8347bd21aafdbe6922603a44c9d7d87c342 100644 (file)
@@ -186,8 +186,8 @@ static int __udp_diag_destroy(struct sk_buff *in_skb,
                if (ipv6_addr_v4mapped((struct in6_addr *)req->id.idiag_dst) &&
                    ipv6_addr_v4mapped((struct in6_addr *)req->id.idiag_src))
                        sk = __udp4_lib_lookup(net,
-                                       req->id.idiag_dst[0], req->id.idiag_dport,
-                                       req->id.idiag_src[0], req->id.idiag_sport,
+                                       req->id.idiag_dst[3], req->id.idiag_dport,
+                                       req->id.idiag_src[3], req->id.idiag_sport,
                                        req->id.idiag_if, tbl);
 
                else