Commit 4ffa79bd authored by Eric Dumazet's avatar Eric Dumazet Committed by Greg Kroah-Hartman

l2tp: fix a race in l2tp_ip_sendmsg()

[ Upstream commit 4399a4df ]

Commit 081b1b1b (l2tp: fix l2tp_ip_sendmsg() route handling) added
a race, in case IP route cache is disabled.

In this case, we should not do the dst_release(&rt->dst), since it'll
free the dst immediately, instead of waiting a RCU grace period.
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Cc: James Chapman <jchapman@katalix.com>
Cc: Denys Fedoryshchenko <denys@visp.net.lb>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b133be60
...@@ -516,10 +516,12 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m ...@@ -516,10 +516,12 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m
sk->sk_bound_dev_if); sk->sk_bound_dev_if);
if (IS_ERR(rt)) if (IS_ERR(rt))
goto no_route; goto no_route;
if (connected) if (connected) {
sk_setup_caps(sk, &rt->dst); sk_setup_caps(sk, &rt->dst);
else } else {
dst_release(&rt->dst); /* safe since we hold rcu_read_lock */ skb_dst_set(skb, &rt->dst);
goto xmit;
}
} }
/* We dont need to clone dst here, it is guaranteed to not disappear. /* We dont need to clone dst here, it is guaranteed to not disappear.
...@@ -527,6 +529,7 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m ...@@ -527,6 +529,7 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m
*/ */
skb_dst_set_noref(skb, &rt->dst); skb_dst_set_noref(skb, &rt->dst);
xmit:
/* Queue the packet to IP for output */ /* Queue the packet to IP for output */
rc = ip_queue_xmit(skb, &inet->cork.fl); rc = ip_queue_xmit(skb, &inet->cork.fl);
rcu_read_unlock(); rcu_read_unlock();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment