diff options
author | Jarek Poplawski <jarkao2@gmail.com> | 2008-10-31 03:45:27 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-10-31 03:45:27 -0400 |
commit | 99c0db26797edb39cf83c8c5f8972067f5426b4e (patch) | |
tree | 918b933d2ac5f0579b24636274c4394c17011d0d /net/sched/sch_generic.c | |
parent | 48a8f519e0fe22a5c98523286b2a120841a11dd5 (diff) |
pkt_sched: sch_generic: Add generic qdisc->ops->peek() implementation.
With feedback from Patrick McHardy.
Signed-off-by: Jarek Poplawski <jarkao2@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched/sch_generic.c')
-rw-r--r-- | net/sched/sch_generic.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c index 93cd30ce6501..318c9f656e8e 100644 --- a/net/sched/sch_generic.c +++ b/net/sched/sch_generic.c | |||
@@ -320,6 +320,7 @@ struct Qdisc_ops noop_qdisc_ops __read_mostly = { | |||
320 | .priv_size = 0, | 320 | .priv_size = 0, |
321 | .enqueue = noop_enqueue, | 321 | .enqueue = noop_enqueue, |
322 | .dequeue = noop_dequeue, | 322 | .dequeue = noop_dequeue, |
323 | .peek = noop_dequeue, | ||
323 | .requeue = noop_requeue, | 324 | .requeue = noop_requeue, |
324 | .owner = THIS_MODULE, | 325 | .owner = THIS_MODULE, |
325 | }; | 326 | }; |
@@ -346,6 +347,7 @@ static struct Qdisc_ops noqueue_qdisc_ops __read_mostly = { | |||
346 | .priv_size = 0, | 347 | .priv_size = 0, |
347 | .enqueue = noop_enqueue, | 348 | .enqueue = noop_enqueue, |
348 | .dequeue = noop_dequeue, | 349 | .dequeue = noop_dequeue, |
350 | .peek = noop_dequeue, | ||
349 | .requeue = noop_requeue, | 351 | .requeue = noop_requeue, |
350 | .owner = THIS_MODULE, | 352 | .owner = THIS_MODULE, |
351 | }; | 353 | }; |
@@ -411,6 +413,19 @@ static struct sk_buff *pfifo_fast_dequeue(struct Qdisc* qdisc) | |||
411 | return NULL; | 413 | return NULL; |
412 | } | 414 | } |
413 | 415 | ||
416 | static struct sk_buff *pfifo_fast_peek(struct Qdisc* qdisc) | ||
417 | { | ||
418 | int prio; | ||
419 | struct sk_buff_head *list = qdisc_priv(qdisc); | ||
420 | |||
421 | for (prio = 0; prio < PFIFO_FAST_BANDS; prio++) { | ||
422 | if (!skb_queue_empty(list + prio)) | ||
423 | return skb_peek(list + prio); | ||
424 | } | ||
425 | |||
426 | return NULL; | ||
427 | } | ||
428 | |||
414 | static int pfifo_fast_requeue(struct sk_buff *skb, struct Qdisc* qdisc) | 429 | static int pfifo_fast_requeue(struct sk_buff *skb, struct Qdisc* qdisc) |
415 | { | 430 | { |
416 | qdisc->q.qlen++; | 431 | qdisc->q.qlen++; |
@@ -457,6 +472,7 @@ static struct Qdisc_ops pfifo_fast_ops __read_mostly = { | |||
457 | .priv_size = PFIFO_FAST_BANDS * sizeof(struct sk_buff_head), | 472 | .priv_size = PFIFO_FAST_BANDS * sizeof(struct sk_buff_head), |
458 | .enqueue = pfifo_fast_enqueue, | 473 | .enqueue = pfifo_fast_enqueue, |
459 | .dequeue = pfifo_fast_dequeue, | 474 | .dequeue = pfifo_fast_dequeue, |
475 | .peek = pfifo_fast_peek, | ||
460 | .requeue = pfifo_fast_requeue, | 476 | .requeue = pfifo_fast_requeue, |
461 | .init = pfifo_fast_init, | 477 | .init = pfifo_fast_init, |
462 | .reset = pfifo_fast_reset, | 478 | .reset = pfifo_fast_reset, |