In async flow create API, there is only mask information when
creating flow table but flex item handle is required to parse
the HW sample information.

Pass the flex item handle instead of UINT64/32_MAX to mask.

Signed-off-by: Rongwei Liu <rongw...@nvidia.com>
---
 app/test-pmd/cmdline_flow.c | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/app/test-pmd/cmdline_flow.c b/app/test-pmd/cmdline_flow.c
index 7c12d63cbc..9037432cc8 100644
--- a/app/test-pmd/cmdline_flow.c
+++ b/app/test-pmd/cmdline_flow.c
@@ -10068,8 +10068,8 @@ parse_flex_handle(struct context *ctx, const struct 
token *token,
        }
        if (offset == offsetof(struct rte_flow_item_flex, handle)) {
                const struct flex_item *fp;
-               struct rte_flow_item_flex *item_flex = ctx->object;
-               handle = (uint16_t)(uintptr_t)item_flex->handle;
+               spec = ctx->object;
+               handle = (uint16_t)(uintptr_t)spec->handle;
                if (handle >= FLEX_MAX_PARSERS_NUM) {
                        printf("Bad flex item handle\n");
                        return -1;
@@ -10079,7 +10079,9 @@ parse_flex_handle(struct context *ctx, const struct 
token *token,
                        printf("Bad flex item handle\n");
                        return -1;
                }
-               item_flex->handle = fp->flex_handle;
+               spec->handle = fp->flex_handle;
+               mask = spec + 2; /* spec, last, mask */
+               mask->handle = fp->flex_handle;
        } else if (offset == offsetof(struct rte_flow_item_flex, pattern)) {
                handle = (uint16_t)(uintptr_t)
                        ((struct rte_flow_item_flex *)ctx->object)->pattern;
-- 
2.27.0

Reply via email to