From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ivan Khoronzhuk Subject: Re: [PATCH 0/4] RFC CPSW switchdev mode Date: Wed, 6 Jun 2018 11:23:05 +0300 Message-ID: <20180606082304.GA5346@khorivan> References: <1527144984-31236-1-git-send-email-ilias.apalodimas@linaro.org> <20180524080528.GD2295@nanopsycho> <20180524084831.GA2759@apalos> <20180524125431.GB24557@lunn.ch> <7437d485-1eac-9619-3827-5af9b32b939e@redhat.com> <20180524140831.GA16793@apalos> <2b3cabca-4710-0a71-69c7-cc433e2b3062@ti.com> <20180603002618.GB14515@lunn.ch> <4908e5f8-7533-6fa5-866f-1fb32fd13857@ti.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed Cc: Andrew Lunn , Ilias Apalodimas , Ivan Vecera , Jiri Pirko , netdev@vger.kernel.org, nsekhar@ti.com, francois.ozog@linaro.org, yogeshs@ti.com, spatton@ti.com To: Grygorii Strashko Return-path: Received: from mail-lf0-f66.google.com ([209.85.215.66]:45091 "EHLO mail-lf0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932249AbeFFIXK (ORCPT ); Wed, 6 Jun 2018 04:23:10 -0400 Received: by mail-lf0-f66.google.com with SMTP id n3-v6so7718182lfe.12 for ; Wed, 06 Jun 2018 01:23:09 -0700 (PDT) Content-Disposition: inline In-Reply-To: <4908e5f8-7533-6fa5-866f-1fb32fd13857@ti.com> Sender: netdev-owner@vger.kernel.org List-ID: On Tue, Jun 05, 2018 at 06:23:45PM -0500, Grygorii Strashko wrote: > > >On 06/02/2018 07:26 PM, Andrew Lunn wrote: >>> *After this patch set*: goal keep things working the same as max as >>> possible and get rid of TI custom tool. >> >> We are happy to keep things the same, if they fit with the switchdev >> model. Anything in your customer TI tool/model which does not fit the >> switchdev model you won't be able to keep, except if we agree to >> extend the model. > >Right. That's the main goal of RFC to identify those gaps. > >> >> I can say now, sw0p0 is going to cause problems. I really do suggest >> you drop it for the moment in order to get a minimal driver >> accepted. sw0p0 does not fit the switchdev model. > >Honestly, this is not the first patchset and we started without sw0p0, >but then.... (with current LKML) >- default vlan offloading breaks traffic reception to P0 > (Ilias saying it's fixed in next - good) >- adding vlan to P1/P2 works, but not for P0 (again as per Ilias -fixed) >- mcast - no way to manually add static record and include or exclude P0. > > >:( above are basic functionality required. > >> >>> Below I've described some tested use cases (not include full static configuration), >>> but regarding sw0p0 - there is work done by Ivan Khoronzhuk [1] which enables >>> adds MQPRIO and CBS Qdisc and targets AVB network features. It required to >>> offload MQPRIO and CBS parameters on all ports including P0. In case of P0, >>> CPDMA TX channels shapers need to be configured, and in case >>> of sw0p1/sw0p2 internal FIFOS. >>> sw0p0 also expected to be used to configure CPDMA interface in general - >>> number of tx/rx channels, rates, ring sizes. >> >> Can this be derives from the configuration on sw0p1 and sw0p2? >> sw0p1 has 1 tx channel, sw0p2 has 2 tx channels, so give p0 3 tx >> channels? > >This not exactly what is required, sry I probably will need just repeat what Ivan >described in https://lkml.org/lkml/2018/5/18/1135. I'd try to provide this info tomorrow. > >Unfortunately, I'm not sure if all this reworking and switchdev conversation would make sense >if we will not be able to fit Ivan's work in new CPSW driver model ;..( >and do AVB bridge. Not sure I tracked everything, but current link example only for dual-emac mode, where i guess no switchdev and thus we have only 2 ports having phys and no need in some common configuration. Only common resources tx queues that are easily shared between two ports. In case of switchdev the same, no need in port 0, at least for cpsw implementation (not sure about others), tx queues cpdma shapers are configured separately and can be done with any netdev presenting ports, thus p0 can be avoided in this case also. For instance, I've created short description, based on current switchdev RFC, showing simple configuration commands for shapers configuration from host side and CBS for every port, w/o p0 usage: https://git.linaro.org/people/ivan.khoronzhuk/tsn_conf.git/tree/README_switchdev Will add it once switchdev decision is stabilized and applied. Basically nothing changed with dual-emac configuration except different rates set for cpdma shapers from host side. Probably, p0 is needed for other configurations, or for compatibility reasons with old versions, but definitely should be created list of all cases, and on my opinion, any common resource for both ports can be configured with any netdev presenting ports if it doesn't conflict with ports configuration itself. > >> >>> In addition there is set of global CPSW parameters (not related to P1/P2, like >>> MAC Authorization Mode, OUI Deny Mode, crc ) which I've >>> thought can be added to sw0p0 (using ethtool -priv-flags). >> >> You should describe these features, and then we can figure out how >> best to model them. devlink might be an option if they are switch >> global. > >Ok. that can be postponed. > >-- >regards, >-grygorii -- Regards, Ivan Khoronzhuk