Add ip_vs_conn_hashkey_v6() and call it instead of ip_vs_conn_hashkey()
when hashing IPv6 connection entries.
Signed-off-by: Julius R. Volz <juliusv@xxxxxxxxxx>
1 files changed, 22 insertions(+), 2 deletions(-)
diff --git a/net/netfilter/ipvs/ip_vs_conn.c b/net/netfilter/ipvs/ip_vs_conn.c
index 1a4040d..4ee5dac 100644
--- a/net/netfilter/ipvs/ip_vs_conn.c
+++ b/net/netfilter/ipvs/ip_vs_conn.c
@@ -37,6 +37,9 @@
#include <net/net_namespace.h>
#include <net/ip_vs.h>
+#ifdef CONFIG_IP_VS_IPV6
+#include <net/ipv6.h>
+#endif
/*
@@ -122,6 +125,13 @@ static unsigned int ip_vs_conn_hashkey(unsigned proto,
__be32 addr, __be16 port)
& IP_VS_CONN_TAB_MASK;
}
+#ifdef CONFIG_IP_VS_IPV6
+static unsigned int ip_vs_conn_hashkey_v6(unsigned proto, const struct
in6_addr *addr, __be16 port)
+{
+ return jhash_3words(jhash(addr, 16, ip_vs_conn_rnd), (__force u32)port,
proto, ip_vs_conn_rnd)
+ & IP_VS_CONN_TAB_MASK;
+}
+#endif
/*
* Hashes ip_vs_conn in ip_vs_conn_tab by proto,addr,port.
@@ -133,7 +143,12 @@ static inline int ip_vs_conn_hash(struct ip_vs_conn *cp)
int ret;
/* Hash by protocol, client address and port */
- hash = ip_vs_conn_hashkey(cp->protocol, cp->caddr, cp->cport);
+#ifdef CONFIG_IP_VS_IPV6
+ if (cp->af == AF_INET6)
+ hash = ip_vs_conn_hashkey_v6(cp->protocol, &cp->caddr.v6,
cp->cport);
+ else
+#endif
+ hash = ip_vs_conn_hashkey(cp->protocol, cp->caddr.v4,
cp->cport);
ct_write_lock(hash);
@@ -164,7 +179,12 @@ static inline int ip_vs_conn_unhash(struct ip_vs_conn *cp)
int ret;
/* unhash it and decrease its reference counter */
- hash = ip_vs_conn_hashkey(cp->protocol, cp->caddr, cp->cport);
+#ifdef CONFIG_IP_VS_IPV6
+ if (cp->af == AF_INET6)
+ hash = ip_vs_conn_hashkey_v6(cp->protocol, &cp->caddr.v6,
cp->cport);
+ else
+#endif
+ hash = ip_vs_conn_hashkey(cp->protocol, cp->caddr.v4,
cp->cport);
ct_write_lock(hash);
--
1.5.3.6
--
To unsubscribe from this list: send the line "unsubscribe lvs-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
|