tcp: add ipv6_addr_v4mapped_loopback() helper
tcp_twsk_unique() has a hard coded assumption about ipv4 loopback being 127/8 Lets instead use the standard ipv4_is_loopback() method, in a new ipv6_addr_v4mapped_loopback() helper. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
5be5515a8e
commit
be2644aac3
|
@ -696,6 +696,11 @@ static inline bool ipv6_addr_v4mapped(const struct in6_addr *a)
|
||||||
cpu_to_be32(0x0000ffff))) == 0UL;
|
cpu_to_be32(0x0000ffff))) == 0UL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline bool ipv6_addr_v4mapped_loopback(const struct in6_addr *a)
|
||||||
|
{
|
||||||
|
return ipv6_addr_v4mapped(a) && ipv4_is_loopback(a->s6_addr32[3]);
|
||||||
|
}
|
||||||
|
|
||||||
static inline u32 ipv6_portaddr_hash(const struct net *net,
|
static inline u32 ipv6_portaddr_hash(const struct net *net,
|
||||||
const struct in6_addr *addr6,
|
const struct in6_addr *addr6,
|
||||||
unsigned int port)
|
unsigned int port)
|
||||||
|
|
|
@ -121,11 +121,9 @@ int tcp_twsk_unique(struct sock *sk, struct sock *sktw, void *twp)
|
||||||
#if IS_ENABLED(CONFIG_IPV6)
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
if (tw->tw_family == AF_INET6) {
|
if (tw->tw_family == AF_INET6) {
|
||||||
if (ipv6_addr_loopback(&tw->tw_v6_daddr) ||
|
if (ipv6_addr_loopback(&tw->tw_v6_daddr) ||
|
||||||
(ipv6_addr_v4mapped(&tw->tw_v6_daddr) &&
|
ipv6_addr_v4mapped_loopback(&tw->tw_v6_daddr) ||
|
||||||
(tw->tw_v6_daddr.s6_addr[12] == 127)) ||
|
|
||||||
ipv6_addr_loopback(&tw->tw_v6_rcv_saddr) ||
|
ipv6_addr_loopback(&tw->tw_v6_rcv_saddr) ||
|
||||||
(ipv6_addr_v4mapped(&tw->tw_v6_rcv_saddr) &&
|
ipv6_addr_v4mapped_loopback(&tw->tw_v6_rcv_saddr))
|
||||||
(tw->tw_v6_rcv_saddr.s6_addr[12] == 127)))
|
|
||||||
loopback = true;
|
loopback = true;
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue