Skip to content

Commit

Permalink
Revert "bridge: do not add port to router list when receives query wi…
Browse files Browse the repository at this point in the history
…th source 0.0.0.0"

This reverts commit 5a2de63 ("bridge: do not add port to router list
when receives query with source 0.0.0.0") and commit 0fe5119 ("net:
bridge: remove ipv6 zero address check in mcast queries")

The reason is RFC 4541 is not a standard but suggestive. Currently we
will elect 0.0.0.0 as Querier if there is no ip address configured on
bridge. If we do not add the port which recives query with source
0.0.0.0 to router list, the IGMP reports will not be about to forward
to Querier, IGMP data will also not be able to forward to dest.

As Nikolay suggested, revert this change first and add a boolopt api
to disable none-zero election in future if needed.

Reported-by: Linus Lüssing <[email protected]>
Reported-by: Sebastian Gottschall <[email protected]>
Fixes: 5a2de63 ("bridge: do not add port to router list when receives query with source 0.0.0.0")
Fixes: 0fe5119 ("net: bridge: remove ipv6 zero address check in mcast queries")
Signed-off-by: Hangbin Liu <[email protected]>
Acked-by: Nikolay Aleksandrov <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
  • Loading branch information
liuhangbin authored and davem330 committed Feb 24, 2019
1 parent af548a2 commit 278e214
Showing 1 changed file with 1 addition and 8 deletions.
9 changes: 1 addition & 8 deletions net/bridge/br_multicast.c
Original file line number Diff line number Diff line change
Expand Up @@ -1204,14 +1204,7 @@ static void br_multicast_query_received(struct net_bridge *br,
return;

br_multicast_update_query_timer(br, query, max_delay);

/* Based on RFC4541, section 2.1.1 IGMP Forwarding Rules,
* the arrival port for IGMP Queries where the source address
* is 0.0.0.0 should not be added to router port list.
*/
if ((saddr->proto == htons(ETH_P_IP) && saddr->u.ip4) ||
saddr->proto == htons(ETH_P_IPV6))
br_multicast_mark_router(br, port);
br_multicast_mark_router(br, port);
}

static void br_ip4_multicast_query(struct net_bridge *br,
Expand Down

0 comments on commit 278e214

Please sign in to comment.