diff options
-rw-r--r-- | net/ipv6/mcast.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c index e5de48551864..3a2849f660ca 100644 --- a/net/ipv6/mcast.c +++ b/net/ipv6/mcast.c | |||
@@ -661,6 +661,10 @@ static void igmp6_group_added(struct ifmcaddr6 *mc) | |||
661 | struct net_device *dev = mc->idev->dev; | 661 | struct net_device *dev = mc->idev->dev; |
662 | char buf[MAX_ADDR_LEN]; | 662 | char buf[MAX_ADDR_LEN]; |
663 | 663 | ||
664 | if (IPV6_ADDR_MC_SCOPE(&mc->mca_addr) < | ||
665 | IPV6_ADDR_SCOPE_LINKLOCAL) | ||
666 | return; | ||
667 | |||
664 | spin_lock_bh(&mc->mca_lock); | 668 | spin_lock_bh(&mc->mca_lock); |
665 | if (!(mc->mca_flags&MAF_LOADED)) { | 669 | if (!(mc->mca_flags&MAF_LOADED)) { |
666 | mc->mca_flags |= MAF_LOADED; | 670 | mc->mca_flags |= MAF_LOADED; |
@@ -687,6 +691,10 @@ static void igmp6_group_dropped(struct ifmcaddr6 *mc) | |||
687 | struct net_device *dev = mc->idev->dev; | 691 | struct net_device *dev = mc->idev->dev; |
688 | char buf[MAX_ADDR_LEN]; | 692 | char buf[MAX_ADDR_LEN]; |
689 | 693 | ||
694 | if (IPV6_ADDR_MC_SCOPE(&mc->mca_addr) < | ||
695 | IPV6_ADDR_SCOPE_LINKLOCAL) | ||
696 | return; | ||
697 | |||
690 | spin_lock_bh(&mc->mca_lock); | 698 | spin_lock_bh(&mc->mca_lock); |
691 | if (mc->mca_flags&MAF_LOADED) { | 699 | if (mc->mca_flags&MAF_LOADED) { |
692 | mc->mca_flags &= ~MAF_LOADED; | 700 | mc->mca_flags &= ~MAF_LOADED; |