mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
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: Hannes Frederic Sowa <hannes@stressinduktion.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
53481da372
commit
65cd8033ff
4 changed files with 42 additions and 23 deletions
|
@ -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 @@
|
||||||
#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,
|
||||||
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 @@ begin:
|
||||||
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 @@ begin:
|
||||||
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;
|
||||||
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];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue