From 315facfce6dc13d6ec1993db1e16532cadcfcaaa Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Mon, 17 Feb 2025 12:29:27 +0100 Subject: [PATCH] kernel: receive all bridged multicast packets if IFF_ALLMULTI is set Fixes issues with odhcpd, especially in relay mode Signed-off-by: Felix Fietkau (cherry picked from commit 38c21271d2b5749f135d662c2b28ef2bbdf607b8) --- ...ly-receive-all-multicast-packets-if-.patch | 24 +++++++++++++++++++ ...d-knob-for-filtering-rx-tx-BPDU-pack.patch | 2 +- 2 files changed, 25 insertions(+), 1 deletion(-) create mode 100644 target/linux/generic/pending-6.6/642-net-bridge-locally-receive-all-multicast-packets-if-.patch diff --git a/target/linux/generic/pending-6.6/642-net-bridge-locally-receive-all-multicast-packets-if-.patch b/target/linux/generic/pending-6.6/642-net-bridge-locally-receive-all-multicast-packets-if-.patch new file mode 100644 index 0000000000..98edb315b1 --- /dev/null +++ b/target/linux/generic/pending-6.6/642-net-bridge-locally-receive-all-multicast-packets-if-.patch @@ -0,0 +1,24 @@ +From: Felix Fietkau +Date: Mon, 17 Feb 2025 12:21:08 +0100 +Subject: [PATCH] net: bridge: locally receive all multicast packets if + IFF_ALLMULTI is set + +If multicast snooping is enabled, multicast packets may not always end up on +the local bridge interface, if the host is not a member of the multicast +group. Similar to how IFF_PROMISC allows all packets to be received locally, +let IFF_ALLMULTI allow all multicast packets to be received. + +Signed-off-by: Felix Fietkau +--- + +--- a/net/bridge/br_input.c ++++ b/net/bridge/br_input.c +@@ -152,6 +152,8 @@ int br_handle_frame_finish(struct net *n + pkt_type = BR_PKT_MULTICAST; + if (br_multicast_rcv(&brmctx, &pmctx, vlan, skb, vid)) + goto drop; ++ if (br->dev->flags & IFF_ALLMULTI) ++ local_rcv = true; + } + } + diff --git a/target/linux/generic/pending-6.6/710-bridge-add-knob-for-filtering-rx-tx-BPDU-pack.patch b/target/linux/generic/pending-6.6/710-bridge-add-knob-for-filtering-rx-tx-BPDU-pack.patch index 96e1a19db4..31e29c447e 100644 --- a/target/linux/generic/pending-6.6/710-bridge-add-knob-for-filtering-rx-tx-BPDU-pack.patch +++ b/target/linux/generic/pending-6.6/710-bridge-add-knob-for-filtering-rx-tx-BPDU-pack.patch @@ -45,7 +45,7 @@ Signed-off-by: Felix Fietkau if (!(p->flags & BR_BCAST_FLOOD) && skb->dev != br->dev) --- a/net/bridge/br_input.c +++ b/net/bridge/br_input.c -@@ -367,6 +367,8 @@ static rx_handler_result_t br_handle_fra +@@ -369,6 +369,8 @@ static rx_handler_result_t br_handle_fra fwd_mask |= p->group_fwd_mask; switch (dest[5]) { case 0x00: /* Bridge Group Address */ -- 2.30.2