netfilter: br_netfilter: fix recent physdev match breakage
authorFlorian Westphal <fw@strlen.de>
Mon, 3 Apr 2023 11:54:37 +0000 (13:54 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Thu, 6 Apr 2023 09:33:52 +0000 (11:33 +0200)
commit94623f579ce338b5fa61b5acaa5beb8aa657fb9e
tree7a202bd2d9dc867abd22f449cdc8a928aa8e6949
parent24e3fce00c0b557491ff596c0682a29dee6fe848
netfilter: br_netfilter: fix recent physdev match breakage

Recent attempt to ensure PREROUTING hook is executed again when a
decrypted ipsec packet received on a bridge passes through the network
stack a second time broke the physdev match in INPUT hook.

We can't discard the nf_bridge info strct from sabotage_in hook, as
this is needed by the physdev match.

Keep the struct around and handle this with another conditional instead.

Fixes: 2b272bb558f1 ("netfilter: br_netfilter: disable sabotage_in hook after first suppression")
Reported-and-tested-by: Farid BENAMROUCHE <fariouche@yahoo.fr>
Signed-off-by: Florian Westphal <fw@strlen.de>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
include/linux/skbuff.h
net/bridge/br_netfilter_hooks.c