[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <52D28AD6.4080304@mojatatu.com>
Date: Sun, 12 Jan 2014 07:30:14 -0500
From: Jamal Hadi Salim <jhs@...atatu.com>
To: John Fastabend <john.r.fastabend@...el.com>,
Cong Wang <xiyou.wangcong@...il.com>
CC: Stephen Hemminger <stephen@...workplumber.org>,
Eric Dumazet <eric.dumazet@...il.com>,
Linux Kernel Network Developers <netdev@...r.kernel.org>,
John Fastabend <john.fastabend@...il.com>,
"David S. Miller" <davem@...emloft.net>
Subject: Re: [RFC Patch net-next 4/4] net_sched: make ingress qdisc lockless
On 01/09/14 20:06, John Fastabend wrote:
> Just to re-iterate you need to go through each and every qdisc,
> classifier, action and verify it is safe to run in parallel. Take
> a look at how the skb lists are managed in the qdiscs. If we want
> to do this we need to make these changes in some coherent way
> because it touches lots of pieces.
>
Indeed. Everything assumes the global qdisc lock is protecting them.
Actually actions are probably the best at the moment because
the lock is very fine grained to just the action instance
and it protects both control and data paths.
But filters have stuff littered everywhere. Egress qdiscs
as you mention have queues at multi levels etc.
> Also your stats are going to get hosed none of the bstats, qstats
> supports this.
Stats are probably the easiest to "fix".
Didnt Eric (or somebody else) fix netdev level stats to use seq counts?
Would that idea not be applicable here?
>I'll send out the classifier set later tonight
> if you want. I got stalled going through the actions.
>
The thing to note is:
actions can be shared across filters, netdevices and cpus.
By default they are not shared across filters and netdevices that is
a config option. You still have to worry about sharing across cpus
which will happen because a flow can be shared across cpus.
You could probably get rid of the lock if you can show
that you can make data and control path mutually exclusive
(rtnl will protect control path).
> Finally any global state in those qdiscs is going to drive performance
> down so many of them would likely need to be redesigned.
>
I feel like per-cpu qdiscs is the best surgery at the moment.
cheers,
jamal
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists