]> git.baikalelectronics.ru Git - kernel.git/commit
ipv6: check return value of ipv6_skip_exthdr
authorJordy Zomer <jordy@pwning.systems>
Wed, 17 Nov 2021 19:06:48 +0000 (20:06 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 8 Dec 2021 08:04:40 +0000 (09:04 +0100)
commitabf187c5d51754aee932079091df36c749c42596
treead505918e30abe9a2bf86919d8bf0bf2c2675bf3
parent64e7e74d8fc7f67b3398ca874f61b2b6ae24deb5
ipv6: check return value of ipv6_skip_exthdr

[ Upstream commit c0a00ae184376ae0f9a032a90e638fe8e7f1489f ]

The offset value is used in pointer math on skb->data.
Since ipv6_skip_exthdr may return -1 the pointer to uh and th
may not point to the actual udp and tcp headers and potentially
overwrite other stuff. This is why I think this should be checked.

EDIT:  added {}'s, thanks Kees

Signed-off-by: Jordy Zomer <jordy@pwning.systems>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/ipv6/esp6.c