Skip to content

Commit

Permalink
net: bridge: multicast: fix MRD advertisement router port marking race
Browse files Browse the repository at this point in the history
commit 000b728 upstream.

When an MRD advertisement is received on a bridge port with multicast
snooping enabled, we mark it as a router port automatically, that
includes adding that port to the router port list. The multicast lock
protects that list, but it is not acquired in the MRD advertisement case
leading to a race condition, we need to take it to fix the race.

Cc: stable@vger.kernel.org
Cc: linus.luessing@c0d3.blue
Fixes: 4b3087c ("bridge: Snoop Multicast Router Advertisements")
Signed-off-by: Nikolay Aleksandrov <nikolay@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
  • Loading branch information
Nikolay Aleksandrov authored and gregkh committed Jul 20, 2021
1 parent dc924e4 commit 28f0ada
Showing 1 changed file with 4 additions and 0 deletions.
4 changes: 4 additions & 0 deletions net/bridge/br_multicast.c
Expand Up @@ -3100,7 +3100,9 @@ static int br_ip4_multicast_mrd_rcv(struct net_bridge *br,
igmp_hdr(skb)->type != IGMP_MRDISC_ADV)
return -ENOMSG;

spin_lock(&br->multicast_lock);
br_multicast_mark_router(br, port);
spin_unlock(&br->multicast_lock);

return 0;
}
Expand Down Expand Up @@ -3168,7 +3170,9 @@ static void br_ip6_multicast_mrd_rcv(struct net_bridge *br,
if (icmp6_hdr(skb)->icmp6_type != ICMPV6_MRDISC_ADV)
return;

spin_lock(&br->multicast_lock);
br_multicast_mark_router(br, port);
spin_unlock(&br->multicast_lock);
}

static int br_multicast_ipv6_rcv(struct net_bridge *br,
Expand Down

0 comments on commit 28f0ada

Please sign in to comment.