Commit 65cd8033 authored by Hannes Frederic Sowa's avatar Hannes Frederic Sowa Committed by David S. Miller

ipv4: split inet_ehashfn to hash functions per compilation unit

This duplicates a bit of code but let's us easily introduce
separate secret keys later. The separate compilation units are
ipv4/inet_hashtabbles.o, ipv4/udp.o and rds/connection.o.

Cc: Eric Dumazet <edumazet@google.com>
Cc: "David S. Miller" <davem@davemloft.net>
Signed-off-by: default avatarHannes Frederic Sowa <hannes@stressinduktion.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 53481da3
...@@ -208,26 +208,16 @@ extern u32 inet_ehash_secret; ...@@ -208,26 +208,16 @@ extern u32 inet_ehash_secret;
extern u32 ipv6_hash_secret; extern u32 ipv6_hash_secret;
void build_ehash_secret(void); void build_ehash_secret(void);
static inline unsigned int inet_ehashfn(struct net *net, static inline unsigned int __inet_ehashfn(const __be32 laddr,
const __be32 laddr, const __u16 lport, const __u16 lport,
const __be32 faddr, const __be16 fport) const __be32 faddr,
const __be16 fport,
u32 initval)
{ {
return jhash_3words((__force __u32) laddr, return jhash_3words((__force __u32) laddr,
(__force __u32) faddr, (__force __u32) faddr,
((__u32) lport) << 16 | (__force __u32)fport, ((__u32) lport) << 16 | (__force __u32)fport,
inet_ehash_secret + net_hash_mix(net)); initval);
}
static inline int inet_sk_ehashfn(const struct sock *sk)
{
const struct inet_sock *inet = inet_sk(sk);
const __be32 laddr = inet->inet_rcv_saddr;
const __u16 lport = inet->inet_num;
const __be32 faddr = inet->inet_daddr;
const __be16 fport = inet->inet_dport;
struct net *net = sock_net(sk);
return inet_ehashfn(net, laddr, lport, faddr, fport);
} }
static inline struct request_sock *inet_reqsk_alloc(struct request_sock_ops *ops) static inline struct request_sock *inet_reqsk_alloc(struct request_sock_ops *ops)
......
...@@ -24,6 +24,27 @@ ...@@ -24,6 +24,27 @@
#include <net/secure_seq.h> #include <net/secure_seq.h>
#include <net/ip.h> #include <net/ip.h>
static unsigned int inet_ehashfn(struct net *net, const __be32 laddr,
const __u16 lport, const __be32 faddr,
const __be16 fport)
{
return __inet_ehashfn(laddr, lport, faddr, fport,
inet_ehash_secret + net_hash_mix(net));
}
static unsigned int inet_sk_ehashfn(const struct sock *sk)
{
const struct inet_sock *inet = inet_sk(sk);
const __be32 laddr = inet->inet_rcv_saddr;
const __u16 lport = inet->inet_num;
const __be32 faddr = inet->inet_daddr;
const __be16 fport = inet->inet_dport;
struct net *net = sock_net(sk);
return inet_ehashfn(net, laddr, lport, faddr, fport);
}
/* /*
* Allocate and initialize a new local port bind bucket. * Allocate and initialize a new local port bind bucket.
* The bindhash mutex for snum's hash chain must be held here. * The bindhash mutex for snum's hash chain must be held here.
......
...@@ -407,6 +407,14 @@ static inline int compute_score2(struct sock *sk, struct net *net, ...@@ -407,6 +407,14 @@ static inline int compute_score2(struct sock *sk, struct net *net,
return score; return score;
} }
static unsigned int udp_ehashfn(struct net *net, const __be32 laddr,
const __u16 lport, const __be32 faddr,
const __be16 fport)
{
return __inet_ehashfn(laddr, lport, faddr, fport,
inet_ehash_secret + net_hash_mix(net));
}
/* called with read_rcu_lock() */ /* called with read_rcu_lock() */
static struct sock *udp4_lib_lookup2(struct net *net, static struct sock *udp4_lib_lookup2(struct net *net,
...@@ -430,8 +438,8 @@ static struct sock *udp4_lib_lookup2(struct net *net, ...@@ -430,8 +438,8 @@ static struct sock *udp4_lib_lookup2(struct net *net,
badness = score; badness = score;
reuseport = sk->sk_reuseport; reuseport = sk->sk_reuseport;
if (reuseport) { if (reuseport) {
hash = inet_ehashfn(net, daddr, hnum, hash = udp_ehashfn(net, daddr, hnum,
saddr, sport); saddr, sport);
matches = 1; matches = 1;
} }
} else if (score == badness && reuseport) { } else if (score == badness && reuseport) {
...@@ -511,8 +519,8 @@ struct sock *__udp4_lib_lookup(struct net *net, __be32 saddr, ...@@ -511,8 +519,8 @@ struct sock *__udp4_lib_lookup(struct net *net, __be32 saddr,
badness = score; badness = score;
reuseport = sk->sk_reuseport; reuseport = sk->sk_reuseport;
if (reuseport) { if (reuseport) {
hash = inet_ehashfn(net, daddr, hnum, hash = udp_ehashfn(net, daddr, hnum,
saddr, sport); saddr, sport);
matches = 1; matches = 1;
} }
} else if (score == badness && reuseport) { } else if (score == badness && reuseport) {
......
...@@ -52,9 +52,9 @@ static struct kmem_cache *rds_conn_slab; ...@@ -52,9 +52,9 @@ static struct kmem_cache *rds_conn_slab;
static struct hlist_head *rds_conn_bucket(__be32 laddr, __be32 faddr) static struct hlist_head *rds_conn_bucket(__be32 laddr, __be32 faddr)
{ {
/* Pass NULL, don't need struct net for hash */ /* Pass NULL, don't need struct net for hash */
unsigned long hash = inet_ehashfn(NULL, unsigned long hash = __inet_ehashfn(be32_to_cpu(laddr), 0,
be32_to_cpu(laddr), 0, be32_to_cpu(faddr), 0,
be32_to_cpu(faddr), 0); inet_ehash_secret);
return &rds_conn_hash[hash & RDS_CONNECTION_HASH_MASK]; return &rds_conn_hash[hash & RDS_CONNECTION_HASH_MASK];
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment