[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20220630111327.3a951e3b@kernel.org>
Date: Thu, 30 Jun 2022 11:13:27 -0700
From: Jakub Kicinski <kuba@...nel.org>
To: Dima Chumak <dchumak@...dia.com>
Cc: Jiri Pirko <jiri@...dia.com>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Paolo Abeni <pabeni@...hat.com>, netdev@...r.kernel.org,
Simon Horman <horms@...ge.net.au>
Subject: Re: [PATCH net-next 0/5] devlink rate police limiter
On Thu, 30 Jun 2022 17:27:08 +0200 Dima Chumak wrote:
> I've re-read more carefully the cover letter of the original 'devlink:
> rate objects API' series by Dmytro Linkin, off of which I based my
> patches, though my understanding still might be incomplete/incorrect
> here.
>
> It seems that TC, being ingress only, doesn't cover the full spectrum of
> rate-limiting that's possible to achieve with devlink. TC works only
> with representors and doesn't allow to configure "the other side of the
> wire", where devlink port function seems to be a better match as it
> connects directly to a VF.
Right, but you are adding Rx and Tx now, IIUC, so you're venturing into
the same "side of the wire" where tc lives.
> Also, for the existing devlink-rate mechanism of VF grouping, it would be
> challenging to achieve similar functionality with TC flows, as groups don't
> have a net device instance where flows can be attached.
You can share actions in TC. The hierarchical aspects may be more
limited, not sure.
> I want to apologize in case my proposed changes have come across as
> being bluntly ignoring some of the pre-established agreements and
> understandings of TC / devlink responsibility separation, it wasn't
> intentional.
Apologies, TBH I thought you're the same person I was arguing with last
time.
My objective is to avoid having multiple user space interfaces which
drivers have to (a) support and (b) reconcile. We already have the VF
rate limits in ip link, and in TC (which I believe is used by OvS
offload).
I presume you have a mlx5 implementation ready, so how do you reconcile
those 3 APIs?
Powered by blists - more mailing lists