The shared indirect action can be shared between ports,
action should be created on single port and the handle
can be used in the templates and flows on multiple ports,
example:

  flow configure 0 queues_number 1 queues_size 64 counters_number 64
  flow configure 1 queues_number 1 queues_size 64 counters_number 0 host_port 0 
flags 1

  flow indirect_action 0 create ingress action_id 0 action count / end

  flow actions_template 0 create ingress actions_template_id 8
       template indirect 0 / queue index 0 / end
       mask count / queue index 0 / end

  flow actions_template 1 create ingress actions_template_id 18
       template shared_indirect 0 0 / queue index 0 / end
       mask count / queue index 0 / end

Signed-off-by: Viacheslav Ovsiienko <viachesl...@nvidia.com>
---
 app/test-pmd/cmdline_flow.c | 53 ++++++++++++++++++++++++++++++++++++-
 1 file changed, 52 insertions(+), 1 deletion(-)

diff --git a/app/test-pmd/cmdline_flow.c b/app/test-pmd/cmdline_flow.c
index b88756903b..734959ba9b 100644
--- a/app/test-pmd/cmdline_flow.c
+++ b/app/test-pmd/cmdline_flow.c
@@ -595,6 +595,8 @@ enum index {
        ACTION_SAMPLE_INDEX,
        ACTION_SAMPLE_INDEX_VALUE,
        ACTION_INDIRECT,
+       ACTION_SHARED_INDIRECT,
+       INDIRECT_ACTION_PORT,
        INDIRECT_ACTION_ID2PTR,
        ACTION_MODIFY_FIELD,
        ACTION_MODIFY_FIELD_OP,
@@ -1882,6 +1884,7 @@ static const enum index next_action[] = {
        ACTION_AGE_UPDATE,
        ACTION_SAMPLE,
        ACTION_INDIRECT,
+       ACTION_SHARED_INDIRECT,
        ACTION_MODIFY_FIELD,
        ACTION_CONNTRACK,
        ACTION_CONNTRACK_UPDATE,
@@ -2387,6 +2390,9 @@ static int parse_ia_destroy(struct context *ctx, const 
struct token *token,
 static int parse_ia_id2ptr(struct context *ctx, const struct token *token,
                           const char *str, unsigned int len, void *buf,
                           unsigned int size);
+static int parse_ia_port(struct context *ctx, const struct token *token,
+                        const char *str, unsigned int len, void *buf,
+                        unsigned int size);
 static int parse_mp(struct context *, const struct token *,
                    const char *, unsigned int,
                    void *, unsigned int);
@@ -6374,6 +6380,23 @@ static const struct token token_list[] = {
                .args = ARGS(ARGS_ENTRY_ARB(0, sizeof(uint32_t))),
                .call = parse_vc,
        },
+       [ACTION_SHARED_INDIRECT] = {
+               .name = "shared_indirect",
+               .help = "apply indirect action by id and port",
+               .priv = PRIV_ACTION(INDIRECT, 0),
+               .next = NEXT(NEXT_ENTRY(INDIRECT_ACTION_PORT)),
+               .args = ARGS(ARGS_ENTRY_ARB(0, sizeof(uint32_t)),
+                            ARGS_ENTRY_ARB(0, sizeof(uint32_t))),
+               .call = parse_vc,
+       },
+       [INDIRECT_ACTION_PORT] = {
+               .name = "{indirect_action_port}",
+               .type = "INDIRECT_ACTION_PORT",
+               .help = "indirect action port",
+               .next = NEXT(NEXT_ENTRY(INDIRECT_ACTION_ID2PTR)),
+               .call = parse_ia_port,
+               .comp = comp_none,
+       },
        [INDIRECT_ACTION_ID2PTR] = {
                .name = "{action_id}",
                .type = "INDIRECT_ACTION_ID",
@@ -9788,6 +9811,31 @@ parse_port(struct context *ctx, const struct token 
*token,
        return ret;
 }
 
+/** Parse tokens for shared indirect actions. */
+static int
+parse_ia_port(struct context *ctx, const struct token *token,
+             const char *str, unsigned int len,
+             void *buf, unsigned int size)
+{
+       struct rte_flow_action *action = ctx->object;
+       uint32_t id;
+       int ret;
+
+       (void)buf;
+       (void)size;
+       ctx->objdata = 0;
+       ctx->object = &id;
+       ctx->objmask = NULL;
+       ret = parse_int(ctx, token, str, len, ctx->object, sizeof(id));
+       ctx->object = action;
+       if (ret != (int)len)
+               return ret;
+       /* set indirect action */
+       if (action)
+               action->conf = (void *)(uintptr_t)id;
+       return ret;
+}
+
 static int
 parse_ia_id2ptr(struct context *ctx, const struct token *token,
                const char *str, unsigned int len,
@@ -9808,7 +9856,10 @@ parse_ia_id2ptr(struct context *ctx, const struct token 
*token,
                return ret;
        /* set indirect action */
        if (action) {
-               action->conf = port_action_handle_get_by_id(ctx->port, id);
+               portid_t port_id = ctx->port;
+               if (ctx->prev == INDIRECT_ACTION_PORT)
+                       port_id = (portid_t)(uintptr_t)action->conf;
+               action->conf = port_action_handle_get_by_id(port_id, id);
                ret = (action->conf) ? ret : -1;
        }
        return ret;
-- 
2.18.1

Reply via email to