Hi Cristian, > -----Original Message----- > From: Dumitrescu, Cristian <cristian.dumitre...@intel.com> > Sent: Wednesday, August 2, 2023 7:57 PM > > > > > -----Original Message----- > > From: Ori Kam <or...@nvidia.com> > > Sent: Wednesday, August 2, 2023 4:47 PM > > To: Morten Brørup <m...@smartsharesystems.com>; Dumitrescu, Cristian > > <cristian.dumitre...@intel.com>; Jerin Jacob <jerinjac...@gmail.com> > > Cc: Zhang, Qi Z <qi.z.zh...@intel.com>; NBU-Contact-Thomas Monjalon > > (EXTERNAL) <tho...@monjalon.net>; david.march...@redhat.com; > > Richardson, Bruce <bruce.richard...@intel.com>; jer...@marvell.com; > > ferruh.yi...@amd.com; techbo...@dpdk.org; Mcnamara, John > > <john.mcnam...@intel.com>; Zhang, Helin <helin.zh...@intel.com>; > > dev@dpdk.org > > Subject: RE: [PATCH] ethdev: introduce generic flow item and action > > > > Hi Qi > > Hi Ori, > > Thanks for your input! > > > > > > -----Original Message----- > > > From: Morten Brørup <m...@smartsharesystems.com> > > > Sent: Wednesday, August 2, 2023 6:25 PM > > > > > > > From: Dumitrescu, Cristian [mailto:cristian.dumitre...@intel.com] > > > > Sent: Wednesday, 2 August 2023 16.06 > > > > > > > > > From: Jerin Jacob <jerinjac...@gmail.com> > > > > > Sent: Wednesday, August 2, 2023 12:22 PM > > > > > > > > > > On Wed, Aug 2, 2023 at 4:31 PM Morten Brørup > > > > > <m...@smartsharesystems.com> wrote: > > > > > > > > > > > > > From: Morten Brørup [mailto:m...@smartsharesystems.com] > > > > > > > Sent: Wednesday, 2 August 2023 12.25 > > > > > > > > > > > > > > > From: Qi Zhang [mailto:qi.z.zh...@intel.com] > > > > > > > > Sent: Wednesday, 2 August 2023 19.35 > > > > > > > > > > > > > > > > From: Cristian Dumitrescu <cristian.dumitre...@intel.com> > > > > > > > > > > > > > > > > For network devices that are programmable through languages > > such as > > > > > > > > the P4 language, there are no pre-defined flow items and > > > > > > > > actions. > > > > > > > > > > > > > > > > The format of the protocol header and metadata fields that are > > used to > > > > > > > > specify the flow items that make up the flow pattern, as well > > > > > > > > as the > > > > > > > > flow actions, are all defined by the program, with an infinity > > > > > > > > of > > > > > > > > possible combinations, as opposed to being selected from a > > > > > > > > finite > > > > > > > > pre-defined list. > > > > > > > > > > > > > > > > It is virtually impossible to pre-define all the flow items and > > > > > > > > the > > > > > > > > flow actions that programs might ever use, as these are only > > limited > > > > > > > > by the set of HW resources and the program developer's > > imagination. > > > > > > > > > > > > > > > > To support the programmable network devices, we are introducing: > > > > > > > > > > > > > > > > * A generic flow item: The flow item is expressed as an array of > > bytes > > > > > > > > of a given length, whose meaning is defined by the program > > > > > > > > loaded > > by > > > > > > > > the network device. > > > > > > > > > > > > > > The flow item is not "generic", it is "opaque": Only the > > > > > > > application > > > > knows > > > > > > > what this flow item does. > > > > > > > > > > > > > > I hate the concept for two reasons: > > > > > > > 1. The inability for applications to detect which flow items the > > > > underlying > > > > > > > hardware supports. > > > > > > > 2. The risk that vendors will use this instead of introducing new > > > > > > > flow > > > > item > > > > > > > types, available for anyone to implement. > > > > > > > > > > > > After further consideration, there might be a middle ground. > > > > > > > > > > > > Consider Vendor-Specific attributes for DHCP and RADIUS, or SNMP > > > MIBs... > > > > > > > > > > > > Any vendor is free to add his own, proprietary special-purpose > > attributes, > > > > > without going through the standardization process. (This is the key > > > > challenge > > > > > this patch seems to be aiming at.) > > > > > > > > > > > > The vendor might publish these attributes, and other vendors may > > > > > implement them too. > > > > > > > > > > > > And in order to prevent collisions, the Vendor-Specific attributes > > contain > > > > a > > > > > globally unique vendor ID, such as the Private Enterprise Number [1] > > > > > managed by IANA. > > > > > > > > > > > > If similar principles can be worked into the patch, I can support > > > > > > it. > > > > > > > > > > +1 > > > > > > > +1 I understand that this is supposed to be generic, but how can it? > > What exactly it not generic? > > > how do you know if PMD supports this? > > What is the current RTE_FLOW mechanism to find out whether a device/PMD > supports a certain flow? The only mechanism available is to try to create the > flow (rte_flow_create) or mimic the creation of the flow (rte_flow_validate) > and see if you get success or error, right? Same mechanism to be used here. > Of course, we would be happy to support the addition of a more complex > query mechanism in RTE_FLOW. >
My bad explanation, you are right the way to know if some PMD supports a feature is trial and error, what I ment is how PMD knows how to phrase the data, it should be in a known format. > > what if each PMD needs different configurations? > > Not sure what you're referring to exactly. The format of the flow items and > flow actions is defined by the P4 program; so all the HW devices that are > able to successfully load a given P4 program, potentially from different > vendors, will have the same understanding of each flow item and action. > So you don't suggest generic, you suggest p4_action/item which will get a blob based on standard. > > > > In addition how can you handle number of those action and items? > > For example if I have match on protocol X and Y and do actions Z and W > > each one of those can be generic item. > > if you have a way to define a standard why to read such actions then we have > > something to talk about. > > Yes, we do. The format of all flow items and flow actions available on the HW > device is fully defined by the P4 program, therefore all the HW devices, > potentially from different vendors, that are able to successfully load a > given P4 > program, will have the same understanding of them. > Again this was not clear from the RFC, see my above comment > > > > > > > > > > > > Morten, Jerin, > > > > > > > > I think there is a fundamental misunderstanding here: we are not trying > > > > to > > > > provide support for some non-standard vendor-specific features here. > > What > > > > we are trying to do is add generic multi-vendor support in RTE_FLOW for > > > > P4 programmable network devices, which requires supporting flow items > > > > and actions that are defined directly by the user through their P4 > > programs > > > > as opposed to being selected from a pre-defined list. > > > > > > > > There are an infinity of flow items and actions that the users can > > > > define > > > > through > > > > their P4 programs, and they cannot be supported with a finite list of > > > RTE_FLOW > > > > items and actions: > > > > > > > > 1/ Some flow items map directly to the IETF defined protocols, while > > > > some > > > > others do not, and only the user writing the program knows the exact > > answer; > > > > > > > > 2/ Some flow items are simply application-specific (not vendor specific) > > > > meta-data that (I hope we all accept) is outside of the standardization > > > > process. > > > > > > Such items can use a special "reserved" vendor-id. > > > > > > > Can you show me what items/actions are missing in rte_flow? > > The number of flow items (protocol headers, but also metadata) and flow > actions > that users can define in their P4 programs is infinite, so unfortunately Ori, > as > much > as I want to grant you this wish, I am not going to be able to 😊. Also, it is > important to note that the users write their P4 program (defining their data > path > pipeline) without any involvement from their device vendor, so the vendor is > simply > not aware of meaning of the user's flow items and actions either. > Maybe we should add an API to register actions/items, but at the end we don't want to write code Twice, meaning if action is already supported by the current API there is no reason to use different API. maybe we can add a small translation function the a PMD can convert actions and output the right rte_flow actions/items, and if it can't, it can create a user action > > > > > > > > > > 3/ Some flow actions map directly to the existing RTE_FLOW actions > > > (especially > > > > the more straightforward actions such as: packet drop, packet > > > > redirection > > to > > > > an > > > > output queue, some specific packet modifications, etc), while the vast > > > > majority > > > > of possible actions do not. > > > > > > > > Are you saying that the P4 programmable network devices should NOT be > > > > supported by DPDK and RTE_FLOW? > > > > > > No, I get the need for this. And I understand that since P4 is compiled to > > > hardware-specific binary blobs, there is a need to put such blobs into > > > DPDK > > as > > > flow items and actions, instead of the "uncompiled" P4 program. > > > > > > I am suggesting that instead of adding a completely opaque data type: > > > > > > Struct item { > > > Int len; // Length of value in bytes. > > > Char value[]; // Application specific meaning. > > > }; > > > > > > > But since you didn't define a known protocol for PMD to read the data how > > 2 pmds can use the same action? > > The format of all flow items and flow actions available on the HW device is > fully > defined by the P4 program, therefore all the HW devices, even if from > different > vendors, will have the same understanding of them. > Like I said above it is not generic it is p4 format. Best, Ori > > > > > ...add a semi-opaque data type: > > > > > > Struct tlv { > > > Int type; // Vendor specific type. > > > Int len; // Length of value in bytes. > > > Char value[]; // (Vendor, Type) specific meaning. > > > }; > > > > > > Struct item { > > > Int vendor; // Vendor ID. > > > Int len; // Length of values in bytes. > > > Struct tlv values[]; // Array of TLVs. > > > }; > > > > > > Like RADIUS Vendor-Specific attributes: > > > https://datatracker.ietf.org/doc/html/rfc2138#section-5.26 > > > > > > Then some (Vendor, Type) fields can be documented (and thus generally > > > understood by DPDK), and some undocumented. > > > > > > E.g. like Microsoft documented some of theirs in RFC 2548: > > > https://datatracker.ietf.org/doc/html/rfc2548 > > > > > > > > > Another benefit is that these new "VENDOR-SPECIFIC" flow types can be > > reused > > > for other purposes than compiled P4 programs. > > > > > > > > > > > > > > > > > > > > > > > > Preferably, there should also be a means for applications to query > > > > > > if > > > > specific > > > > > Vendor-Specific flow items and actions are supported or not. > > > > > > > > > > > > > > > > > > [1]: https://www.iana.org/assignments/enterprise-numbers/ > > > > > > > > > > > > > > Regards, > > > > Cristian > > Regards, > Cristian