netfilter: ip6_tables: zero-initialize fragment offset
authorJeremy Sowden <jeremy@azazel.net>
Sun, 12 Sep 2021 21:24:33 +0000 (22:24 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 17 Oct 2021 08:43:32 +0000 (10:43 +0200)
commitddc4ba737bcb31c227192af4e194ec0f01516700
tree4ef362b65e5cb0feec435ea73fc0edfb0ff7f2fe
parentddf026d6ae9aa6ba188800c9e3f2e79ec1597a67
netfilter: ip6_tables: zero-initialize fragment offset

[ Upstream commit 310e2d43c3ad429c1fba4b175806cf1f55ed73a6 ]

ip6tables only sets the `IP6T_F_PROTO` flag on a rule if a protocol is
specified (`-p tcp`, for example).  However, if the flag is not set,
`ip6_packet_match` doesn't call `ipv6_find_hdr` for the skb, in which
case the fragment offset is left uninitialized and a garbage value is
passed to each matcher.

Signed-off-by: Jeremy Sowden <jeremy@azazel.net>
Reviewed-by: Florian Westphal <fw@strlen.de>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/ipv6/netfilter/ip6_tables.c