diff options
author | Nicolas Dichtel | 2018-01-25 19:03:03 +0100 |
---|---|---|
committer | David S. Miller | 2018-01-25 22:27:34 +0100 |
commit | f15ca723c1ebe6c1a06bc95fda6b62cd87b44559 (patch) | |
tree | d81f5825fe96dbfc589b19561961814fed78b4fc /net/ipv6/sit.c | |
parent | net: tcp: close sock if net namespace is exiting (diff) | |
download | kernel-qcow2-linux-f15ca723c1ebe6c1a06bc95fda6b62cd87b44559.tar.gz kernel-qcow2-linux-f15ca723c1ebe6c1a06bc95fda6b62cd87b44559.tar.xz kernel-qcow2-linux-f15ca723c1ebe6c1a06bc95fda6b62cd87b44559.zip |
net: don't call update_pmtu unconditionally
Some dst_ops (e.g. md_dst_ops)) doesn't set this handler. It may result to:
"BUG: unable to handle kernel NULL pointer dereference at (null)"
Let's add a helper to check if update_pmtu is available before calling it.
Fixes: 52a589d51f10 ("geneve: update skb dst pmtu on tx path")
Fixes: a93bf0ff4490 ("vxlan: update skb dst pmtu on tx path")
CC: Roman Kapl <code@rkapl.cz>
CC: Xin Long <lucien.xin@gmail.com>
Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/sit.c')
-rw-r--r-- | net/ipv6/sit.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/ipv6/sit.c b/net/ipv6/sit.c index d7dc23c1b2ca..3873d3877135 100644 --- a/net/ipv6/sit.c +++ b/net/ipv6/sit.c @@ -934,8 +934,8 @@ static netdev_tx_t ipip6_tunnel_xmit(struct sk_buff *skb, df = 0; } - if (tunnel->parms.iph.daddr && skb_dst(skb)) - skb_dst(skb)->ops->update_pmtu(skb_dst(skb), NULL, skb, mtu); + if (tunnel->parms.iph.daddr) + skb_dst_update_pmtu(skb, mtu); if (skb->len > mtu && !skb_is_gso(skb)) { icmpv6_send(skb, ICMPV6_PKT_TOOBIG, 0, mtu); |