]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ipv4: use check_net()
authorChristian Brauner <brauner@kernel.org>
Thu, 18 Sep 2025 10:11:55 +0000 (12:11 +0200)
committerChristian Brauner <brauner@kernel.org>
Fri, 19 Sep 2025 14:22:37 +0000 (16:22 +0200)
Don't directly acess the namespace count. There's even a dedicated
helper for this.

Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Christian Brauner <brauner@kernel.org>
net/ipv4/inet_timewait_sock.c
net/ipv4/tcp_metrics.c

index 875ff923a8ed05411628f55f788f33cbe3dee5b3..56a117560c0cbb8ab30cac81889249f7b7cae1d4 100644 (file)
@@ -329,13 +329,13 @@ restart:
                                             TCPF_NEW_SYN_RECV))
                                continue;
 
-                       if (refcount_read(&sock_net(sk)->ns.count))
+                       if (check_net(sock_net(sk)))
                                continue;
 
                        if (unlikely(!refcount_inc_not_zero(&sk->sk_refcnt)))
                                continue;
 
-                       if (refcount_read(&sock_net(sk)->ns.count)) {
+                       if (check_net(sock_net(sk))) {
                                sock_gen_put(sk);
                                goto restart;
                        }
index 03c068ea27b6ad3283b8365f31706c11ecdd07f2..b67f94c60f9ffcfff7c94b101f18248e5e6ad673 100644 (file)
@@ -912,7 +912,7 @@ static void tcp_metrics_flush_all(struct net *net)
                spin_lock_bh(&tcp_metrics_lock);
                for (tm = deref_locked(*pp); tm; tm = deref_locked(*pp)) {
                        match = net ? net_eq(tm_net(tm), net) :
-                               !refcount_read(&tm_net(tm)->ns.count);
+                               !check_net(tm_net(tm));
                        if (match) {
                                rcu_assign_pointer(*pp, tm->tcpm_next);
                                kfree_rcu(tm, rcu_head);