]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
inet: move inet_ehash_secret and udp_ehash_secret into net_hotdata
authorEric Dumazet <edumazet@google.com>
Wed, 6 Mar 2024 16:00:27 +0000 (16:00 +0000)
committerJakub Kicinski <kuba@kernel.org>
Fri, 8 Mar 2024 05:12:43 +0000 (21:12 -0800)
"struct net_protocol" has a 32bit hole in 32bit arches.

Use it to store the 32bit secret used by UDP and TCP,
to increase cache locality in rx path.

Signed-off-by: Eric Dumazet <edumazet@google.com>
Acked-by: Soheil Hassas Yeganeh <soheil@google.com>
Reviewed-by: David Ahern <dsahern@kernel.org>
Link: https://lore.kernel.org/r/20240306160031.874438-15-edumazet@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/net/hotdata.h
include/net/protocol.h
net/ipv4/inet_hashtables.c
net/ipv4/udp.c

index 87215f7ac200f2ba34de9b52841bc0c9e4849857..7a210ea6899c6af4e0424201cd265755ef460078 100644 (file)
@@ -36,6 +36,9 @@ struct net_hotdata {
        int                     dev_rx_weight;
 };
 
+#define inet_ehash_secret      net_hotdata.tcp_protocol.secret
+#define udp_ehash_secret       net_hotdata.udp_protocol.secret
+
 extern struct net_hotdata net_hotdata;
 
 #endif /* _NET_HOTDATA_H */
index 6aef8cb11cc8c409e5f7a2519f5e747be584c8d5..3ff26e66735cec98b08eadb1c3f129e011923cb0 100644 (file)
@@ -46,6 +46,7 @@ struct net_protocol {
                                 * socket lookup?
                                 */
                                icmp_strict_tag_validation:1;
+       u32                     secret;
 };
 
 #if IS_ENABLED(CONFIG_IPV6)
index 308ff34002ea6b5e0620004f65ffd833087afbc1..7498af3201647fd937bf8177f04c200bea178a79 100644 (file)
@@ -24,6 +24,7 @@
 #include <net/inet6_hashtables.h>
 #endif
 #include <net/secure_seq.h>
+#include <net/hotdata.h>
 #include <net/ip.h>
 #include <net/tcp.h>
 #include <net/sock_reuseport.h>
@@ -32,8 +33,6 @@ u32 inet_ehashfn(const struct net *net, const __be32 laddr,
                 const __u16 lport, const __be32 faddr,
                 const __be16 fport)
 {
-       static u32 inet_ehash_secret __read_mostly;
-
        net_get_random_once(&inet_ehash_secret, sizeof(inet_ehash_secret));
 
        return __inet_ehashfn(laddr, lport, faddr, fport,
index a8acea17b4e5344d022ae8f8eb674d1a36f8035a..2beabf5b2d8628f1fed69a0212c57bd3cd638483 100644 (file)
@@ -411,8 +411,6 @@ INDIRECT_CALLABLE_SCOPE
 u32 udp_ehashfn(const struct net *net, const __be32 laddr, const __u16 lport,
                const __be32 faddr, const __be16 fport)
 {
-       static u32 udp_ehash_secret __read_mostly;
-
        net_get_random_once(&udp_ehash_secret, sizeof(udp_ehash_secret));
 
        return __inet_ehashfn(laddr, lport, faddr, fport,