Hello, The patch was reviewed and approved by @Slava Ovsiienko
Regards, Gregory > -----Original Message----- > From: Andrew Rybchenko <andrew.rybche...@oktetlabs.ru> > Sent: Tuesday, July 13, 2021 11:08 > To: Ori Kam <or...@nvidia.com> > Cc: Slava Ovsiienko <viachesl...@nvidia.com>; Xiaoyun Li > <xiaoyun...@intel.com>; Gregory Etelson <getel...@nvidia.com>; > dev@dpdk.org > Subject: Re: [PATCH v2] app/testpmd: add flow item to match on IPv4 > version_ihl field > > External email: Use caution opening links or attachments > > > @Ori, could you review it, please. > > Thanks, > Andrew. > > On 7/13/21 10:29 AM, Gregory Etelson wrote: > > The new flow item allows PMD to offload IPv4 IHL field for matching, > > if hardware supports that operation. > > > > Signed-off-by: Gregory Etelson <getel...@nvidia.com> > > --- > > v2: replace UNSIGNED with COMMON_UNSIGNED following 21.08 API > change. > > --- > > app/test-pmd/cmdline_flow.c | 13 ++++++++++++- > > doc/guides/testpmd_app_ug/testpmd_funcs.rst | 1 + > > 2 files changed, 13 insertions(+), 1 deletion(-) > > > > diff --git a/app/test-pmd/cmdline_flow.c b/app/test-pmd/cmdline_flow.c > > index 8fc0e1469d..34e043621c 100644 > > --- a/app/test-pmd/cmdline_flow.c > > +++ b/app/test-pmd/cmdline_flow.c > > @@ -171,6 +171,7 @@ enum index { > > ITEM_VLAN_INNER_TYPE, > > ITEM_VLAN_HAS_MORE_VLAN, > > ITEM_IPV4, > > + ITEM_IPV4_VER_IHL, > > ITEM_IPV4_TOS, > > ITEM_IPV4_ID, > > ITEM_IPV4_FRAGMENT_OFFSET, > > @@ -1069,6 +1070,7 @@ static const enum index item_vlan[] = { }; > > > > static const enum index item_ipv4[] = { > > + ITEM_IPV4_VER_IHL, > > ITEM_IPV4_TOS, > > ITEM_IPV4_ID, > > ITEM_IPV4_FRAGMENT_OFFSET, > > @@ -2576,6 +2578,14 @@ static const struct token token_list[] = { > > .next = NEXT(item_ipv4), > > .call = parse_vc, > > }, > > + [ITEM_IPV4_VER_IHL] = { > > + .name = "version_ihl", > > + .help = "match header length", > > + .next = NEXT(item_ipv4, NEXT_ENTRY(COMMON_UNSIGNED), > > + item_param), > > + .args = ARGS(ARGS_ENTRY(struct rte_flow_item_ipv4, > > + hdr.version_ihl)), > > + }, > > [ITEM_IPV4_TOS] = { > > .name = "tos", > > .help = "type of service", @@ -8193,7 +8203,8 @@ > > update_fields(uint8_t *buf, struct rte_flow_item *item, uint16_t > next_proto) > > break; > > case RTE_FLOW_ITEM_TYPE_IPV4: > > ipv4 = (struct rte_ipv4_hdr *)buf; > > - ipv4->version_ihl = 0x45; > > + if (!ipv4->version_ihl) > > + ipv4->version_ihl = RTE_IPV4_VHL_DEF; > > if (next_proto && ipv4->next_proto_id == 0) > > ipv4->next_proto_id = (uint8_t)next_proto; > > break; > > diff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst > > b/doc/guides/testpmd_app_ug/testpmd_funcs.rst > > index 33857acf54..ab7e91ad6c 100644 > > --- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst > > +++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst > > @@ -3654,6 +3654,7 @@ This section lists supported pattern items and > their attributes, if any. > > > > - ``ipv4``: match IPv4 header. > > > > + - ``version_ihl {unsigned}``: IPv4 version and IP header length. > > - ``tos {unsigned}``: type of service. > > - ``ttl {unsigned}``: time to live. > > - ``proto {unsigned}``: next protocol ID. > >