From: John Fastabend <john.fastabend@gmail.com>
To: Jesper Dangaard Brouer <brouer@redhat.com>
Cc: fw@strlen.de, jhs@mojatatu.com, alexei.starovoitov@gmail.com,
eric.dumazet@gmail.com, netdev@vger.kernel.org
Subject: Re: [RFC PATCH v2 08/10] net: sched: pfifo_fast use alf_queue
Date: Thu, 14 Jul 2016 17:09:43 -0700 [thread overview]
Message-ID: <578829C7.8060604@gmail.com> (raw)
In-Reply-To: <20160714171148.3bb7b47b@redhat.com>
On 16-07-14 08:11 AM, Jesper Dangaard Brouer wrote:
> On Wed, 13 Jul 2016 23:23:12 -0700
> John Fastabend <john.fastabend@gmail.com> wrote:
>
>> This converts the pfifo_fast qdisc to use the alf_queue enqueue and
>> dequeue routines then sets the NOLOCK bit.
>
> Should have said skb_array, not alf_queue ;-)
I think I'll get numbers for the alf_queue to so we can compare them
as well. On the todo list for tomorrow.
>
> > This also removes the logic used to pick the next band to dequeue from
>> and instead just checks each alf_queue for packets from top priority
>> to lowest. This might need to be a bit more clever but seems to work
>> for now.
>>
>> Signed-off-by: John Fastabend <john.r.fastabend@intel.com>
>> ---
>> net/sched/sch_generic.c | 131 +++++++++++++++++++++++++++--------------------
>> 1 file changed, 75 insertions(+), 56 deletions(-)
>>
>> diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c
>> index 7dcd066..2ac3eb9 100644
>> --- a/net/sched/sch_generic.c
>> +++ b/net/sched/sch_generic.c
>> @@ -26,6 +26,7 @@
>> #include <linux/list.h>
>> #include <linux/slab.h>
>> #include <linux/if_vlan.h>
>> +#include <linux/skb_array.h>
>> #include <net/sch_generic.h>
>> #include <net/pkt_sched.h>
>> #include <net/dst.h>
>> @@ -555,88 +556,79 @@ static const u8 prio2band[TC_PRIO_MAX + 1] = {
>>
>> /*
>> * Private data for a pfifo_fast scheduler containing:
>> - * - queues for the three band
>> - * - bitmap indicating which of the bands contain skbs
>> + * - rings for priority bands
>> */
>> struct pfifo_fast_priv {
>> - u32 bitmap;
>> - struct sk_buff_head q[PFIFO_FAST_BANDS];
>> + struct skb_array q[PFIFO_FAST_BANDS];
>> };
>>
>> -/*
>> - * Convert a bitmap to the first band number where an skb is queued, where:
>> - * bitmap=0 means there are no skbs on any band.
>> - * bitmap=1 means there is an skb on band 0.
>> - * bitmap=7 means there are skbs on all 3 bands, etc.
>> - */
>> -static const int bitmap2band[] = {-1, 0, 1, 0, 2, 0, 1, 0};
>> -
>> -static inline struct sk_buff_head *band2list(struct pfifo_fast_priv *priv,
>> - int band)
>> +static inline struct skb_array *band2list(struct pfifo_fast_priv *priv,
>> + int band)
>> {
>> - return priv->q + band;
>> + return &priv->q[band];
>> }
>>
>> static int pfifo_fast_enqueue(struct sk_buff *skb, struct Qdisc *qdisc,
>> struct sk_buff **to_free)
>> {
>> - if (skb_queue_len(&qdisc->q) < qdisc_dev(qdisc)->tx_queue_len) {
>> - int band = prio2band[skb->priority & TC_PRIO_MAX];
>> - struct pfifo_fast_priv *priv = qdisc_priv(qdisc);
>> - struct sk_buff_head *list = band2list(priv, band);
>> -
>> - priv->bitmap |= (1 << band);
>> - qdisc->q.qlen++;
>> - return __qdisc_enqueue_tail(skb, qdisc, list);
>> - }
>> + int band = prio2band[skb->priority & TC_PRIO_MAX];
>> + struct pfifo_fast_priv *priv = qdisc_priv(qdisc);
>> + struct skb_array *q = band2list(priv, band);
>> + int err;
>>
>> - return qdisc_drop(skb, qdisc, to_free);
>> + err = skb_array_produce_bh(q, skb);
>
> Do you need the _bh variant here? (Doesn't the qdisc run with BH disabled?)
>
>
Yep its inside rcu_read_lock_bh().
next prev parent reply other threads:[~2016-07-15 0:09 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-07-14 6:19 [RFC PATCH v2 00/10] running qdiscs without qdisc_lock John Fastabend
2016-07-14 6:19 ` [RFC PATCH v2 01/10] net: sched: allow qdiscs to handle locking John Fastabend
2016-07-14 6:44 ` John Fastabend
2016-07-14 6:20 ` [RFC PATCH v2 02/10] net: sched: qdisc_qlen for per cpu logic John Fastabend
2016-07-14 6:20 ` [RFC PATCH v2 03/10] net: sched: provide per cpu qstat helpers John Fastabend
2016-07-14 6:21 ` [RFC PATCH v2 04/10] net: sched: a dflt qdisc may be used with per cpu stats John Fastabend
2016-07-14 6:21 ` [RFC PATCH v2 05/10] net: sched: per cpu gso handlers John Fastabend
2016-07-14 6:22 ` [RFC PATCH v2 06/10] net: sched: support qdisc_reset on NOLOCK qdisc John Fastabend
2016-07-14 6:22 ` [RFC PATCH v2 07/10] net: sched: support skb_bad_tx with lockless qdisc John Fastabend
2016-07-14 6:23 ` [RFC PATCH v2 08/10] net: sched: pfifo_fast use alf_queue John Fastabend
2016-07-14 15:11 ` Jesper Dangaard Brouer
2016-07-15 0:09 ` John Fastabend [this message]
2016-07-15 10:09 ` Jesper Dangaard Brouer
2016-07-15 17:29 ` John Fastabend
2016-07-14 23:42 ` Alexei Starovoitov
2016-07-15 0:07 ` John Fastabend
2016-07-15 11:23 ` Jesper Dangaard Brouer
2016-07-15 22:18 ` John Fastabend
2016-07-15 22:48 ` Alexei Starovoitov
2016-07-14 6:23 ` [RFC PATCH v2 09/10] net: sched: helper to sum qlen John Fastabend
2016-07-14 6:24 ` [RFC PATCH v2 10/10] net: sched: add support for TCQ_F_NOLOCK subqueues to sch_mq John Fastabend
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=578829C7.8060604@gmail.com \
--to=john.fastabend@gmail.com \
--cc=alexei.starovoitov@gmail.com \
--cc=brouer@redhat.com \
--cc=eric.dumazet@gmail.com \
--cc=fw@strlen.de \
--cc=jhs@mojatatu.com \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.