]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
netfilter: ip6t_eui64: reject invalid MAC header for all packets
authorZhengchuan Liang <zcliangcn@gmail.com>
Sat, 4 Apr 2026 09:39:47 +0000 (17:39 +0800)
committerFlorian Westphal <fw@strlen.de>
Wed, 8 Apr 2026 11:33:56 +0000 (13:33 +0200)
commitfdce0b3590f724540795b874b4c8850c90e6b0a8
treeb398064319dc12aa0e74183344e8b6d7ce309af3
parentff64c5bfef12461df8450e0f50bb693b5269c720
netfilter: ip6t_eui64: reject invalid MAC header for all packets

`eui64_mt6()` derives a modified EUI-64 from the Ethernet source address
and compares it with the low 64 bits of the IPv6 source address.

The existing guard only rejects an invalid MAC header when
`par->fragoff != 0`. For packets with `par->fragoff == 0`, `eui64_mt6()`
can still reach `eth_hdr(skb)` even when the MAC header is not valid.

Fix this by removing the `par->fragoff != 0` condition so that packets
with an invalid MAC header are rejected before accessing `eth_hdr(skb)`.

Fixes: 1da177e4c3f41 ("Linux-2.6.12-rc2")
Reported-by: Yifan Wu <yifanwucs@gmail.com>
Reported-by: Juefei Pu <tomapufckgml@gmail.com>
Co-developed-by: Yuan Tan <yuantan098@gmail.com>
Signed-off-by: Yuan Tan <yuantan098@gmail.com>
Suggested-by: Xin Liu <bird@lzu.edu.cn>
Tested-by: Ren Wei <enjou1224z@gmail.com>
Signed-off-by: Zhengchuan Liang <zcliangcn@gmail.com>
Signed-off-by: Ren Wei <n05ec@lzu.edu.cn>
Signed-off-by: Florian Westphal <fw@strlen.de>
net/ipv6/netfilter/ip6t_eui64.c