]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ipv6: move tcp_ipv6_hash_secret and udp_ipv6_hash_secret to net_hotdata
authorEric Dumazet <edumazet@google.com>
Wed, 6 Mar 2024 16:00:29 +0000 (16:00 +0000)
committerJakub Kicinski <kuba@kernel.org>
Fri, 8 Mar 2024 05:12:43 +0000 (21:12 -0800)
Use a 32bit hole in "struct net_offload" to store
the remaining 32bit secrets used by TCPv6 and UDPv6.

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-17-edumazet@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/net/hotdata.h
include/net/protocol.h
net/ipv6/inet6_hashtables.c
net/ipv6/udp.c

index 6d5cd967183a59271da1a27edfee1bc6bf155c1b..b0b847585f7e62245cee81a56b5a252051e07834 100644 (file)
@@ -39,7 +39,9 @@ struct net_hotdata {
 #define inet_ehash_secret      net_hotdata.tcp_protocol.secret
 #define udp_ehash_secret       net_hotdata.udp_protocol.secret
 #define inet6_ehash_secret     net_hotdata.tcpv6_protocol.secret
+#define tcp_ipv6_hash_secret   net_hotdata.tcpv6_offload.secret
 #define udp6_ehash_secret      net_hotdata.udpv6_protocol.secret
+#define udp_ipv6_hash_secret   net_hotdata.udpv6_offload.secret
 
 extern struct net_hotdata net_hotdata;
 
index 213649d2ab098edc4eb9f44a5403540887c2b8ef..b2499f88f8f8199de28555d0cbd6b4523325205b 100644 (file)
@@ -70,6 +70,7 @@ struct inet6_protocol {
 struct net_offload {
        struct offload_callbacks callbacks;
        unsigned int             flags; /* Flags used by IPv6 for now */
+       u32                      secret;
 };
 /* This should be set for any extension header which is compatible with GSO. */
 #define INET6_PROTO_GSO_EXTHDR 0x1
index 0fee97f3166cf8326b3b714ac6bde48ca5188cec..2e81383b663b71b95719a295fd9629f1193e4225 100644 (file)
@@ -26,15 +26,13 @@ u32 inet6_ehashfn(const struct net *net,
                  const struct in6_addr *laddr, const u16 lport,
                  const struct in6_addr *faddr, const __be16 fport)
 {
-       static u32 ipv6_hash_secret __read_mostly;
-
        u32 lhash, fhash;
 
        net_get_random_once(&inet6_ehash_secret, sizeof(inet6_ehash_secret));
-       net_get_random_once(&ipv6_hash_secret, sizeof(ipv6_hash_secret));
+       net_get_random_once(&tcp_ipv6_hash_secret, sizeof(tcp_ipv6_hash_secret));
 
        lhash = (__force u32)laddr->s6_addr32[3];
-       fhash = __ipv6_addr_jhash(faddr, ipv6_hash_secret);
+       fhash = __ipv6_addr_jhash(faddr, tcp_ipv6_hash_secret);
 
        return __inet6_ehashfn(lhash, lport, fhash, fport,
                               inet6_ehash_secret + net_hash_mix(net));
index 1e1c67a51675e8534a953a6d4d63211388d95ca9..80ad8f436b179d7279cbbd5108c3494a9773c0d8 100644 (file)
@@ -79,8 +79,6 @@ u32 udp6_ehashfn(const struct net *net,
                 const struct in6_addr *faddr,
                 const __be16 fport)
 {
-       static u32 udp_ipv6_hash_secret __read_mostly;
-
        u32 lhash, fhash;
 
        net_get_random_once(&udp6_ehash_secret,