[IPV4]: Fix negative timer loop with lots of ipv4 peers.
authorDave Johnson <djohnson+linux-kernel@sw.starentnetworks.com>
Tue, 23 Aug 2005 17:10:15 +0000 (10:10 -0700)
committerDavid S. Miller <davem@davemloft.net>
Tue, 23 Aug 2005 17:10:15 +0000 (10:10 -0700)
commit1344a41637114485fac7afa1505bce2ff862807a
treecf8f84bee2b6e23a17e97beef53791a698256f77
parentc3a20692ca5c8eb8cf5d0f489d4fc839ce7593d1
[IPV4]: Fix negative timer loop with lots of ipv4 peers.

From: Dave Johnson <djohnson+linux-kernel@sw.starentnetworks.com>

Found this bug while doing some scaling testing that created 500K inet
peers.

peer_check_expire() in net/ipv4/inetpeer.c isn't using inet_peer_gc_mintime
correctly and will end up creating an expire timer with less than the
minimum duration, and even zero/negative if enough active peers are
present.

If >65K peers, the timer will be less than inet_peer_gc_mintime, and with
>70K peers, the timer duration will reach zero and go negative.

The timer handler will continue to schedule another zero/negative timer in
a loop until peers can be aged.  This can continue for at least a few
minutes or even longer if the peers remain active due to arriving packets
while the loop is occurring.

Bug is present in both 2.4 and 2.6.  Same patch will apply to both just
fine.

Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/inetpeer.c