summaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorLinus Lüssing <linus.luessing@web.de>2013-06-16 23:20:34 +0200
committerDavid S. Miller <davem@davemloft.net>2013-06-17 17:11:22 -0700
commit32de868cbc6bee010d2cee95b5071b25ecbec8c3 (patch)
tree4732265c9470bf469793c090eaa844f972a3bceb /net
parent788dfcacacfbdd51f9c92065bd8e136686f07a29 (diff)
downloadlinux-stable-32de868cbc6bee010d2cee95b5071b25ecbec8c3.tar.gz
linux-stable-32de868cbc6bee010d2cee95b5071b25ecbec8c3.tar.bz2
linux-stable-32de868cbc6bee010d2cee95b5071b25ecbec8c3.zip
bridge: fix switched interval for MLD Query types
General Queries (the one with the Multicast Address field set to zero / '::') are supposed to have a Maximum Response Delay of [Query Response Interval], while for Multicast-Address-Specific Queries it is [Last Listener Query Interval] - not the other way round. (see RFC2710, section 7.3+7.8) Signed-off-by: Linus Lüssing <linus.luessing@web.de> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/bridge/br_multicast.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/net/bridge/br_multicast.c b/net/bridge/br_multicast.c
index 81f2389f78eb..d6448e35e027 100644
--- a/net/bridge/br_multicast.c
+++ b/net/bridge/br_multicast.c
@@ -465,8 +465,9 @@ static struct sk_buff *br_ip6_multicast_alloc_query(struct net_bridge *br,
skb_set_transport_header(skb, skb->len);
mldq = (struct mld_msg *) icmp6_hdr(skb);
- interval = ipv6_addr_any(group) ? br->multicast_last_member_interval :
- br->multicast_query_response_interval;
+ interval = ipv6_addr_any(group) ?
+ br->multicast_query_response_interval :
+ br->multicast_last_member_interval;
mldq->mld_type = ICMPV6_MGM_QUERY;
mldq->mld_code = 0;