diff options
author | Stephen Hemminger <shemminger@osdl.org> | 2005-05-03 16:24:03 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2005-05-03 16:24:03 -0700 |
commit | 8cbe1d46d69f9e2c49f284fe0e9aee3387bd2c71 (patch) | |
tree | b9d25110d46551fa80a2c34e1b9147f855e43e41 | |
parent | bd96535b81ad09d7593cc75093534acb984d3dc9 (diff) | |
download | op-kernel-dev-8cbe1d46d69f9e2c49f284fe0e9aee3387bd2c71.zip op-kernel-dev-8cbe1d46d69f9e2c49f284fe0e9aee3387bd2c71.tar.gz |
[PKT_SCHED]: netetm: trap infinite loop hange on qlen underflow
Due to bugs in netem (fixed by later patches), it is possible to get qdisc
qlen to go negative. If this happens the CPU ends up spinning forever
in qdisc_run(). So add a BUG_ON() to trap it.
Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/sched/sch_generic.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c index 9a2f8e4..87e48a4 100644 --- a/net/sched/sch_generic.c +++ b/net/sched/sch_generic.c @@ -179,6 +179,7 @@ requeue: netif_schedule(dev); return 1; } + BUG_ON((int) q->q.qlen < 0); return q->q.qlen; } |