02/02/2023 12:19, Rongwei Liu:
> In case flow rules match only one kind of traffic in a flow table,
> then optimization can be done via allocation of this table.
> Such optimization is possible only if the application gives a hint
> about its usage of the table during initial configuration.
> 
> The transfer domain rules may process traffic from wire or vport,
> which may correspond to two kinds of underlayer resources.
> That's why the first two hints introduced in this patch are about
> wire and vport traffic specialization.
> Wire means traffic arrives from the uplink port while vport means
> traffic initiated from VF/SF.
> 
> There are two possible approaches for providing the hints.
> Using IPv4 as an example:
> 1. Use pattern item in both flow template table and rules.
> 
>    template table 3 =
>      transfer pattern ANY_VPORT / eth / ipv4 src is 255.255.255.255 / end
>    flow rule =
>      template_table 3 pattern ANY_VPORT / eth / ipv4 src is 1.1.1.1 / end
> 
>    The pattern template 3 will be used only to match flows coming from
>    vports.
>    ANY_VPORT needs to be present in each flow rule.
>    ANY_VPORT matching is redundant with IP src 1.1.1.1 because
>    the user knows 1.1.1.1 is the IP of a vport.
> 
> 2. Add specialization flag into flow template table attribute:
> 
>    template table 3 =
>      transfer VPORT_ORIG pattern eth / ipv4 src is 255.255.255.255 / end
>    flow rule =
>      template_table 3 pattern eth / ipv4 src is 1.1.1.1 / end
> 
>    The pattern template 3 can be used only to match flows coming
>    from vports.
> 
> Approach 1 needs to specify the hint in each flow rule that wastes
> memory and is not user friendly.
> This patch takes the 2nd approach and introduces one new member
> "specialize" into rte_flow_table_attr to indicate possible flow table
> optimization.
> 
> By default, there is no hint, so nothing change.
> There is no guarantee that the hints will be effective in the driver.
> The application functionality must not rely on the hints.
> 
> Signed-off-by: Rongwei Liu <rongw...@nvidia.com>
> Acked-by: Ori Kam <or...@nvidia.com>

Andrew gave this recent comment on v7:
"
Anyway, hint itself is OK and makes sense. Hopefully
documentation highlights that pattern match is required.
If so,

Acked-by: Andrew Rybchenko <andrew.rybche...@oktetlabs.ru>
"

Given the lines below, I assume the documentation is OK.

> +This attribute is not mandatory for driver to implement.
> +If a hint is not supported, it will be silently ignored,
> +and no special optimization is done.
> +
> +If a table is specialized, the application should make sure the rules
> +comply with the table attribute.
> +The application functionality must not rely on the hints,
> +they are not replacing the matching criteria of flow rules.
[...]
> +/**@{@name Flags for template table attribute.
> + * Each bit is an optional hint for table specialization,
> + * offering a potential optimization at driver layer.
> + * The driver can ignore the hints silently.
> + * The hints do not replace any matching criteria.
> + */
> +/**
> + * Specialize table for transfer flows which come only from wire.
> + * It allows PMD not to allocate resources for non-wire originated traffic.
> + * This bit is not a matching criteria, just an optimization hint.
> + * Flow rules which match non-wire originated traffic will be missed
> + * if the hint is supported.
> + */
> +#define RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_WIRE_ORIG RTE_BIT32(0)
> +/**
> + * Specialize table for transfer flows which come only from vport (e.g. VF, 
> SF).
> + * It allows PMD not to allocate resources for non-vport originated traffic.
> + * This bit is not a matching criteria, just an optimization hint.
> + * Flow rules which match non-vport originated traffic will be missed
> + * if the hint is supported.
> + */
> +#define RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_VPORT_ORIG RTE_BIT32(1)
> +/**@}*/
[...]
> +     /**
> +      * Optional hint flags for driver optimization.
> +      * The effect may vary in the different drivers.
> +      * The functionality must not rely on the hints.
> +      * Value is composed with RTE_FLOW_TABLE_SPECIALIZE_* based on 
> application
> +      * design choices.
> +      * Misused hints may mislead the driver, it may result in an undefined 
> behavior.
> +      */
> +     uint32_t specialize;

Acked-by: Thomas Monjalon <tho...@monjalon.net>


Reply via email to