l2tp: use add READ_ONCE() to fetch sk->sk_bound_dev_if
authorEric Dumazet <edumazet@google.com>
Fri, 13 May 2022 18:55:48 +0000 (11:55 -0700)
committerDavid S. Miller <davem@davemloft.net>
Mon, 16 May 2022 09:31:06 +0000 (10:31 +0100)
Use READ_ONCE() in paths not holding the socket lock.

Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/l2tp/l2tp_ip.c
net/l2tp/l2tp_ip6.c

index 6af09e1..4db5a55 100644 (file)
@@ -50,11 +50,13 @@ static struct sock *__l2tp_ip_bind_lookup(const struct net *net, __be32 laddr,
        sk_for_each_bound(sk, &l2tp_ip_bind_table) {
                const struct l2tp_ip_sock *l2tp = l2tp_ip_sk(sk);
                const struct inet_sock *inet = inet_sk(sk);
+               int bound_dev_if;
 
                if (!net_eq(sock_net(sk), net))
                        continue;
 
-               if (sk->sk_bound_dev_if && dif && sk->sk_bound_dev_if != dif)
+               bound_dev_if = READ_ONCE(sk->sk_bound_dev_if);
+               if (bound_dev_if && dif && bound_dev_if != dif)
                        continue;
 
                if (inet->inet_rcv_saddr && laddr &&
index 217c719..c6ff8bf 100644 (file)
@@ -62,11 +62,13 @@ static struct sock *__l2tp_ip6_bind_lookup(const struct net *net,
                const struct in6_addr *sk_laddr = inet6_rcv_saddr(sk);
                const struct in6_addr *sk_raddr = &sk->sk_v6_daddr;
                const struct l2tp_ip6_sock *l2tp = l2tp_ip6_sk(sk);
+               int bound_dev_if;
 
                if (!net_eq(sock_net(sk), net))
                        continue;
 
-               if (sk->sk_bound_dev_if && dif && sk->sk_bound_dev_if != dif)
+               bound_dev_if = READ_ONCE(sk->sk_bound_dev_if);
+               if (bound_dev_if && dif && bound_dev_if != dif)
                        continue;
 
                if (sk_laddr && !ipv6_addr_any(sk_laddr) &&
@@ -445,7 +447,7 @@ static int l2tp_ip6_getname(struct socket *sock, struct sockaddr *uaddr,
                lsa->l2tp_conn_id = lsk->conn_id;
        }
        if (ipv6_addr_type(&lsa->l2tp_addr) & IPV6_ADDR_LINKLOCAL)
-               lsa->l2tp_scope_id = sk->sk_bound_dev_if;
+               lsa->l2tp_scope_id = READ_ONCE(sk->sk_bound_dev_if);
        return sizeof(*lsa);
 }
 
@@ -560,7 +562,7 @@ static int l2tp_ip6_sendmsg(struct sock *sk, struct msghdr *msg, size_t len)
        }
 
        if (fl6.flowi6_oif == 0)
-               fl6.flowi6_oif = sk->sk_bound_dev_if;
+               fl6.flowi6_oif = READ_ONCE(sk->sk_bound_dev_if);
 
        if (msg->msg_controllen) {
                opt = &opt_space;