Skip to content
Snippets Groups Projects
Commit edd37290 authored by Eric Dumazet's avatar Eric Dumazet Committed by Andrew Chant
Browse files

ipv4: keep skb->dst around in presence of IP options


Andrey Konovalov got crashes in __ip_options_echo() when a NULL skb->dst
is accessed.

ipv4_pktinfo_prepare() should not drop the dst if (evil) IP options
are present.

We could refine the test to the presence of ts_needtime or srr,
but IP options are not often used, so let's be conservative.

Thanks to syzkaller team for finding this bug.

Upstream commit: 34b2cef20f19c87999fff3da4071e66937db9644
Fixes: d826eb14 ("ipv4: PKTINFO doesnt need dst reference")
Bug: 35805460
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Reported-by: default avatarAndrey Konovalov <andreyknvl@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Change-Id: I4428212665ba44b6f4a3d5999bcd8409a79bea04
parent f37e859a
No related branches found
No related tags found
No related merge requests found
......@@ -1046,6 +1046,13 @@ void ipv4_pktinfo_prepare(struct sk_buff *skb)
pktinfo->ipi_ifindex = 0;
pktinfo->ipi_spec_dst.s_addr = 0;
}
/* We need to keep the dst for __ip_options_echo()
* We could restrict the test to opt.ts_needtime || opt.srr,
* but the following is good enough as IP options are not often used.
*/
if (unlikely(IPCB(skb)->opt.optlen))
skb_dst_force(skb);
else
skb_dst_drop(skb);
}
......
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please to comment