Allows application to specify match mode to be used.

Signed-off-by: Gerry Gribbon <ggrib...@nvidia.com>
Acked-by: Ori Kam <or...@nvidia.com>
---
 app/test-regex/main.c                    | 38 ++++++++++++++++++++++--
 doc/guides/tools/testregex.rst           |  3 ++
 drivers/regex/mlx5/mlx5_regex_fastpath.c |  8 +++--
 3 files changed, 44 insertions(+), 5 deletions(-)

diff --git a/app/test-regex/main.c b/app/test-regex/main.c
index 351c36a879..29e0bc391d 100644
--- a/app/test-regex/main.c
+++ b/app/test-regex/main.c
@@ -25,6 +25,7 @@
 #define MBUF_CACHE_SIZE 256
 #define MBUF_SIZE (1 << 8)
 #define START_BURST_SIZE 32u
+#define MAX_MATCH_MODE 2
 
 enum app_args {
        ARG_HELP,
@@ -36,6 +37,7 @@ enum app_args {
        ARG_NUM_OF_QPS,
        ARG_NUM_OF_LCORES,
        ARG_NUM_OF_MBUF_SEGS,
+       ARG_NUM_OF_MATCH_MODE,
 };
 
 struct job_ctx {
@@ -72,6 +74,7 @@ struct regex_conf {
        long data_len;
        long job_len;
        uint32_t nb_segs;
+       uint32_t match_mode;
 };
 
 static void
@@ -85,14 +88,17 @@ usage(const char *prog_name)
                " --nb_iter N: number of iteration to run\n"
                " --nb_qps N: number of queues to use\n"
                " --nb_lcores N: number of lcores to use\n"
-               " --nb_segs N: number of mbuf segments\n",
+               " --nb_segs N: number of mbuf segments\n"
+               " --match_mode N: match mode: 0 - None (default),"
+               " 1 - Highest Priority, 2 - Stop On Any\n",
                prog_name);
 }
 
 static void
 args_parse(int argc, char **argv, char *rules_file, char *data_file,
           uint32_t *nb_jobs, bool *perf_mode, uint32_t *nb_iterations,
-          uint32_t *nb_qps, uint32_t *nb_lcores, uint32_t *nb_segs)
+          uint32_t *nb_qps, uint32_t *nb_lcores, uint32_t *nb_segs,
+          uint32_t *match_mode)
 {
        char **argvopt;
        int opt;
@@ -116,6 +122,8 @@ args_parse(int argc, char **argv, char *rules_file, char 
*data_file,
                { "nb_lcores", 1, 0, ARG_NUM_OF_LCORES},
                /* Number of mbuf segments. */
                { "nb_segs", 1, 0, ARG_NUM_OF_MBUF_SEGS},
+               /* Match mode. */
+               { "match_mode", 1, 0, ARG_NUM_OF_MATCH_MODE},
                /* End of options */
                { 0, 0, 0, 0 }
        };
@@ -158,6 +166,12 @@ args_parse(int argc, char **argv, char *rules_file, char 
*data_file,
                case ARG_NUM_OF_MBUF_SEGS:
                        *nb_segs = atoi(optarg);
                        break;
+               case ARG_NUM_OF_MATCH_MODE:
+                       *match_mode = atoi(optarg);
+                       if (*match_mode > MAX_MATCH_MODE)
+                               rte_exit(EXIT_FAILURE,
+                                        "Invalid match mode value\n");
+                       break;
                case ARG_HELP:
                        usage(argv[0]);
                        break;
@@ -382,6 +396,7 @@ run_regex(void *args)
        char *data_buf = rgxc->data_buf;
        long data_len = rgxc->data_len;
        long job_len = rgxc->job_len;
+       uint32_t match_mode = rgxc->match_mode;
        long remainder;
        long act_job_len = 0;
        bool last_job = false;
@@ -506,6 +521,21 @@ run_regex(void *args)
                        jobs_ctx[i].mbuf = ops[i]->mbuf;
                        ops[i]->user_id = i;
                        ops[i]->group_id0 = 1;
+                       switch (match_mode) {
+                       case 0:
+                               /* Nothing to set in req_flags */
+                               break;
+                       case 1:
+                               ops[i]->req_flags |= 
RTE_REGEX_OPS_REQ_MATCH_HIGH_PRIORITY_F;
+                               break;
+                       case 2:
+                               ops[i]->req_flags |= 
RTE_REGEX_OPS_REQ_STOP_ON_MATCH_F;
+                               break;
+                       default:
+                               rte_exit(EXIT_FAILURE,
+                                        "Invalid match mode value\n");
+                               break;
+                       }
                        pos += act_job_len;
                        actual_jobs++;
                }
@@ -709,6 +739,7 @@ main(int argc, char **argv)
        long data_len;
        long job_len;
        uint32_t nb_lcores = 1, nb_segs = 1;
+       uint32_t match_mode = 0;
        struct regex_conf *rgxc;
        uint32_t i;
        struct qps_per_lcore *qps_per_lcore;
@@ -722,7 +753,7 @@ main(int argc, char **argv)
        if (argc > 1)
                args_parse(argc, argv, rules_file, data_file, &nb_jobs,
                                &perf_mode, &nb_iterations, &nb_qps,
-                               &nb_lcores, &nb_segs);
+                               &nb_lcores, &nb_segs, &match_mode);
 
        if (nb_qps == 0)
                rte_exit(EXIT_FAILURE, "Number of QPs must be greater than 
0\n");
@@ -763,6 +794,7 @@ main(int argc, char **argv)
                        .data_buf = data_buf,
                        .data_len = data_len,
                        .job_len = job_len,
+                       .match_mode = match_mode,
                };
                rte_eal_remote_launch(run_regex, &rgxc[i],
                                      qps_per_lcore[i].lcore_id);
diff --git a/doc/guides/tools/testregex.rst b/doc/guides/tools/testregex.rst
index cdb1ffd6ee..17175854e6 100644
--- a/doc/guides/tools/testregex.rst
+++ b/doc/guides/tools/testregex.rst
@@ -71,6 +71,9 @@ Application Options
 ``--nb_segs N``
   number of mbuf segment
 
+``--match_mode N``
+  match mode: 0 - None (default), 1 - Highest Priority, 2 - Stop on Any
+
 ``--help``
   print application options
 
diff --git a/drivers/regex/mlx5/mlx5_regex_fastpath.c 
b/drivers/regex/mlx5/mlx5_regex_fastpath.c
index 9a2db7e43f..86edfacee3 100644
--- a/drivers/regex/mlx5/mlx5_regex_fastpath.c
+++ b/drivers/regex/mlx5/mlx5_regex_fastpath.c
@@ -125,8 +125,12 @@ __prep_one(struct mlx5_regex_priv *priv, struct 
mlx5_regex_hw_qp *qp_obj,
                                op->group_id2 : 0;
        uint16_t group3 = op->req_flags & RTE_REGEX_OPS_REQ_GROUP_ID3_VALID_F ?
                                op->group_id3 : 0;
-       uint8_t control = op->req_flags &
-                               RTE_REGEX_OPS_REQ_MATCH_HIGH_PRIORITY_F ? 1 : 0;
+       uint8_t control = 0x0;
+
+       if (op->req_flags & RTE_REGEX_OPS_REQ_MATCH_HIGH_PRIORITY_F)
+               control = 0x1;
+       else if (op->req_flags & RTE_REGEX_OPS_REQ_STOP_ON_MATCH_F)
+               control = 0x2;
 
        /* For backward compatibility. */
        if (!(op->req_flags & (RTE_REGEX_OPS_REQ_GROUP_ID0_VALID_F |
-- 
2.25.1

Reply via email to