On Thu, Mar 01, 2018 at 05:13:39PM +1100, Daniel Axtens wrote: > Replace skb_gso_network_seglen() with > skb_gso_validate_network_len(), as it considers the GSO_BY_FRAGS > case. > > Signed-off-by: Daniel Axtens <d...@axtens.net>
Reviewed-by: Marcelo Ricardo Leitner <marcelo.leit...@gmail.com> > --- > net/ipv4/xfrm4_output.c | 3 ++- > net/ipv6/xfrm6_output.c | 2 +- > 2 files changed, 3 insertions(+), 2 deletions(-) > > diff --git a/net/ipv4/xfrm4_output.c b/net/ipv4/xfrm4_output.c > index 94b8702603bc..be980c195fc5 100644 > --- a/net/ipv4/xfrm4_output.c > +++ b/net/ipv4/xfrm4_output.c > @@ -30,7 +30,8 @@ static int xfrm4_tunnel_check_size(struct sk_buff *skb) > > mtu = dst_mtu(skb_dst(skb)); > if ((!skb_is_gso(skb) && skb->len > mtu) || > - (skb_is_gso(skb) && skb_gso_network_seglen(skb) > > ip_skb_dst_mtu(skb->sk, skb))) { > + (skb_is_gso(skb) && > + !skb_gso_validate_network_len(skb, ip_skb_dst_mtu(skb->sk, skb)))) > { > skb->protocol = htons(ETH_P_IP); > > if (skb->sk) > diff --git a/net/ipv6/xfrm6_output.c b/net/ipv6/xfrm6_output.c > index 8ae87d4ec5ff..5959ce9620eb 100644 > --- a/net/ipv6/xfrm6_output.c > +++ b/net/ipv6/xfrm6_output.c > @@ -82,7 +82,7 @@ static int xfrm6_tunnel_check_size(struct sk_buff *skb) > > if ((!skb_is_gso(skb) && skb->len > mtu) || > (skb_is_gso(skb) && > - skb_gso_network_seglen(skb) > ip6_skb_dst_mtu(skb))) { > + !skb_gso_validate_network_len(skb, ip6_skb_dst_mtu(skb)))) { > skb->dev = dst->dev; > skb->protocol = htons(ETH_P_IPV6); > > -- > 2.14.1 >