net_sched: prio: use qdisc_dequeue_peeked
authorFlorian Westphal <fw@strlen.de>
Tue, 9 Aug 2011 02:04:43 +0000 (02:04 +0000)
committerDavid S. Miller <davem@davemloft.net>
Wed, 10 Aug 2011 04:52:11 +0000 (21:52 -0700)
commit3557619f0f6f7496ed453d4825e24958ab1884e0
treefe66b34573509d0f4880d4f03ae5cde26ff69cb3
parent9be6dd6510fde5cfa2ab73f238754d38ee6797bc
net_sched: prio: use qdisc_dequeue_peeked

commit 07bd8df5df4369487812bf85a237322ff3569b77
(sch_sfq: fix peek() implementation) changed sfq to use generic
peek helper.

This makes HFSC complain about a non-work-conserving child qdisc, if
prio with sfq child is used within hfsc:

hfsc peeks into prio qdisc, which will then peek into sfq.
returned skb is stashed in sch->gso_skb.

Next, hfsc tries to dequeue from prio, but prio will call sfq dequeue
directly, which may return NULL instead of previously peeked-at skb.

Have prio call qdisc_dequeue_peeked, so sfq->dequeue() is
not called in this case.

Cc: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: Florian Westphal <fw@strlen.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sched/sch_prio.c