From: Ben Hutchings Date: Mon, 9 Jan 2012 22:06:46 +0000 (-0800) Subject: igmp: Avoid zero delay when receiving odd mixture of IGMP queries X-Git-Tag: firefly_0821_release~7541^2~1979 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=49ffa26eca87d3518ed88d3e6feebf1b80837a15;p=firefly-linux-kernel-4.4.55.git igmp: Avoid zero delay when receiving odd mixture of IGMP queries commit a8c1f65c79cbbb2f7da782d4c9d15639a9b94b27 upstream. Commit 5b7c84066733c5dfb0e4016d939757b38de189e4 ('ipv4: correct IGMP behavior on v3 query during v2-compatibility mode') added yet another case for query parsing, which can result in max_delay = 0. Substitute a value of 1, as in the usual v3 case. Reported-by: Simon McVittie References: http://bugs.debian.org/654876 Signed-off-by: Ben Hutchings Signed-off-by: David S. Miller --- diff --git a/net/ipv4/igmp.c b/net/ipv4/igmp.c index d577199eabd5..e0d42dbb33fe 100644 --- a/net/ipv4/igmp.c +++ b/net/ipv4/igmp.c @@ -875,6 +875,8 @@ static void igmp_heard_query(struct in_device *in_dev, struct sk_buff *skb, * to be intended in a v3 query. */ max_delay = IGMPV3_MRC(ih3->code)*(HZ/IGMP_TIMER_SCALE); + if (!max_delay) + max_delay = 1; /* can't mod w/ 0 */ } else { /* v3 */ if (!pskb_may_pull(skb, sizeof(struct igmpv3_query))) return;