mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-15 13:15:57 +00:00
net: flow_dissector: fail on evil iph->ihl
We don't validate iph->ihl which may lead a dead loop if we meet a IPIP skb whose iph->ihl is zero. Fix this by failing immediately when iph->ihl is evil (less than 5). This issue were introduced by commit ec5efe7946280d1e84603389a1030ccec0a767ae (rps: support IPIP encapsulation). Cc: Eric Dumazet <edumazet@google.com> Cc: Petr Matousek <pmatouse@redhat.com> Cc: Michael S. Tsirkin <mst@redhat.com> Cc: Daniel Borkmann <dborkman@redhat.com> Signed-off-by: Jason Wang <jasowang@redhat.com> Acked-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2e19ef0251
commit
6f09234385
@ -40,7 +40,7 @@ again:
|
|||||||
struct iphdr _iph;
|
struct iphdr _iph;
|
||||||
ip:
|
ip:
|
||||||
iph = skb_header_pointer(skb, nhoff, sizeof(_iph), &_iph);
|
iph = skb_header_pointer(skb, nhoff, sizeof(_iph), &_iph);
|
||||||
if (!iph)
|
if (!iph || iph->ihl < 5)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (ip_is_fragment(iph))
|
if (ip_is_fragment(iph))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user