diff options
| author | Ignacy Gawędzki <[email protected]> | 2021-12-10 16:31:27 +0100 | 
|---|---|---|
| committer | Pablo Neira Ayuso <[email protected]> | 2021-12-16 00:06:24 +0100 | 
| commit | ebb966d3bdfed581ecccbb4a7432341baf7619b4 (patch) | |
| tree | 769b61302917f9342b3379a2376be2ebc93792e9 /scripts/gcc-plugins/gcc-generate-gimple-pass.h | |
| parent | 0f7d9b31ce7abdbb29bf018131ac920c9f698518 (diff) | |
netfilter: fix regression in looped (broad|multi)cast's MAC handling
In commit 5648b5e1169f ("netfilter: nfnetlink_queue: fix OOB when mac
header was cleared"), the test for non-empty MAC header introduced in
commit 2c38de4c1f8da7 ("netfilter: fix looped (broad|multi)cast's MAC
handling") has been replaced with a test for a set MAC header.
This breaks the case when the MAC header has been reset (using
skb_reset_mac_header), as is the case with looped-back multicast
packets.  As a result, the packets ending up in NFQUEUE get a bogus
hwaddr interpreted from the first bytes of the IP header.
This patch adds a test for a non-empty MAC header in addition to the
test for a set MAC header.  The same two tests are also implemented in
nfnetlink_log.c, where the initial code of commit 2c38de4c1f8da7
("netfilter: fix looped (broad|multi)cast's MAC handling") has not been
touched, but where supposedly the same situation may happen.
Fixes: 5648b5e1169f ("netfilter: nfnetlink_queue: fix OOB when mac header was cleared")
Signed-off-by: Ignacy Gawędzki <[email protected]>
Reviewed-by: Florian Westphal <[email protected]>
Signed-off-by: Pablo Neira Ayuso <[email protected]>
Diffstat (limited to 'scripts/gcc-plugins/gcc-generate-gimple-pass.h')
0 files changed, 0 insertions, 0 deletions