On Tue, Dec 7, 2021 at 11:52 PM Dumitrescu, Cristian
<cristian.dumitre...@intel.com> wrote:
>
> HI Jerin,

Hi Chistian,


>
> Sorry for my delay. I am currently in vacation until the beginning on January 
> 2022, so my response is slower than usual.

I was too on vacation.

>
> Thanks for the explanation of the capabilities you are trying to enable in 
> the API. Based on this, I am reconsidering some of my previous input. Here 
> are my current thoughts:
>
> a) Each meter object can be configured with multiple methods to determine the 
> input color: IP DSCP and VLAN PCP are just two of them, others are possible 
> (as also listed by you). I think the problem we are trying to solve here is: 
> in case multiple such methods are enabled for a given meter object AND more 
> than one enabled method is applicable for a particular input packet at 
> run-time (e.g. the packet is an IP packet, but it also contains at least one 
> VLAN label, and both IP DSCP and the VLAN PCP methods are enabled for the 
> meter object), how do we decide which method is to be applied? So, IMO we 
> need to define a priority scheme that always picks a single method:
>
>         - a unique priority for each method;
>
>         - a default method to be used when none of the enabled methods is 
> applicable to the input packet.
>
> b) The default method must be usable even when the input packet type is 
> unknown to the HW (unsupported), e.g. we should still be able to decide the 
> input color of a packet that is not an IP packet, such as ARP, and it does 
> not contain any VLAN labels. For this, I suggest we add a field ins struct 
> rte_mtr_params called default_input_color of type enum rte_color:
>
>         struct rte_mtr_params {
>                 enum rte_color default_input_color; /* Input color to be set 
> for the input packet when none of the enabled input color methods is 
> applicable to the current input packet. Ignored when this method is set to 
> the color blind method. */
>         };
>
> c) In terms of methods and their priority, I propose to start with the 
> following options, each of which referring to a set of methods, with a clear 
> way to select a unique method. This is the minimal set needed to support the 
> HW capabilities that you mention, this set can be extended as needed in the 
> future:
>
>         enum rte_mtr_input_color_method {
>                 RTE_MTR_INPUT_COLOR_METHOD_COLOR_BLIND, /* The input color is 
> always green. The default_input_color is ignored for this method. */
>                 RTE_ MTR_INPUT_COLOR_METHOD_IP_DSCP, /* If the input packet 
> is IPv4 or IPv6, its input color is detected  by the DSCP field indexing into 
> the dscp_table. Otherwise, the default_input_color is applied. */
>                 RTE_ MTR_INPUT_COLOR_METHOD_OUTER_VLAN_PCP, /* If the input 
> packet has at least one VLAN label, its input color is detected by the 
> outermost VLAN PCP indexing into the vlan_table. Otherwise, the 
> default_input_color is applied. */
>                 RTE_ MTR_INPUT_COLOR_METHOD_OUTER_VLAN_PCP_IP_DSCP, /* If the 
> input packet has at least one VLAN label, its input color is detected by the 
> outermost VLAN PCP indexing into the vlan_table. Otherwise, if the packet is 
> IPv4 or IPv6, its input color is detected by the DSCP field indexing into the 
> dscp_table. Otherwise, the default_input_color is applied. */
>                 RTE_ MTR_INPUT_COLOR_METHOD_INNER_VLAN_PCP, /* If the input 
> packet has at least one VLAN label, its input color is detected by the 
> innermost VLAN PCP indexing into the vlan_table. Otherwise, the 
> default_input_color is applied. */
>                 RTE_ MTR_INPUT_COLOR_METHOD_INNER_VLAN_PCP_IP_DSCP, /* If the 
> input packet has at least one VLAN label, its input color is detected by the 
> innermost VLAN PCP indexing into the vlan_table. Otherwise, if the packet is 
> IPv4 or IPv6, its input color is detected by the DSCP field indexing into the 
> dscp_table. Otherwise, the default_input_color is applied. */
>         };
>
>         struct rte_mtr_params {
>                 enum rte_mtr_input_color_method input_color_method;
>         };
>
> d) The above point means that all the protocol dependent tables are 
> independent of each other, so they can all exist at the same time, so we 
> cannot put all of them into a union or a single unified input color 
> translation table. In case any of these tables is enabled/required by the 
> input color scheme, but it is set to NULL, it must automatically resolve to 
> an "all-green" table (as it is already the case for the existing dscp_table).
>
>         struct rte_mtr_params {
>                 enum rte_color *ip_dscp_table; /* Used when the IP DSCP input 
> color method is selected for the current input packet. If set to NULL, it 
> defaults to 64 elements of RTE_COLOR_GREEN. */
>                 enum rte_color *vlan_table; /* Used when the 
> outermost/innermost VLAN PCP input color method is selected for the current 
> input packet. If set to NULL, it defaults to all elements being 
> RTE_COLOR_GREEN. */
>         };
>
> So many details to address in order to avoid any loopholes in this API, but I 
> think this scheme is implementable and robust enough. What do you think?


Sounds good. I will next version based on your suggestion.




>
> > >
> > > >
> > > > 2. What if the defined input color methodology is not applicable to the
> > current input packet? For example, the user selects VLAN PCP, but some or
> > all of the input packets do not contain any VLAN labels?
> > >
> > > it picks the rte_mtr_params::fallback_input_color
> > >
>
> We likely need a more complex scheme, see above ;)
>
> > > >
> > > > 3. How do we manage the many packet fields that could be used as the
> > key for the input color: outer IP DSCP, inner IP DSCP, VLAN 1st label, VLAN
> > 2nd label, MPLS QoS, etc?
> > > > - Approach A: Use an enumeration, like you propose, and we can add
> > more in the future. Not ideal.
> > > > - Approach B: Point to a protocol-agnostic packet field by defining the
> > offset and mask of a 64-bit field. Advantage: we don't need to change the
> > API every time we add a new option.
> > >
> > > No strong opinion on doing Approach B. I think, it may be overkill for
> > > application and implementation to express. No strong opinion, If you
> > > have a strong opinion on that, I will change that to v1. Let me know.
> > >
>
> I would love to have a protocol agnostic scheme, but I am OK to start with a 
> simple scheme for now (if you can call the above scheme as being simple ;) 
> )and revisit later on if needed.
>
> > >
> > > >
> > > > 4. I suggest we use a unified input color table as opposed to one per
> > protocol, i.e. rename the struct rte_mtr_params::dscp_table to
> > color_in_table. The size of this table could be implicitly defined by the 
> > packet
> > field type (in case of enum) or the field mask (in case of protocol-agnostic
> > field offset and mask), as described above.
> > >
> > > Will do that. I thought not to do that just because, I don't want to
> > > remove the existing dscp_table symbol.
> > > Make sense to enable your suggestion.
> > >
> > > Let me know your views on Questions 1 and 3. I will send the next
> > > version based on that.
> > >
>
> Based on the above comments, I no longer thing a unified such table would 
> work.
>
> > >
> > >
> > > >
> > > > Regards,
> > > > Cristian
>
> Regards,
> Cristian

Reply via email to