Instead of using getopt_long return value, strcmp was used to
compare the input parameters with the struct option array. This
patch get rid of all those strcmp by directly binding each longopt
with an int enum.

Bugzilla ID: 238
Fixes: de3cfa2c98 ("sched: initial import")
Fixes: cb056611a8 ("eal: rename lcore master and slave")
Cc: step...@networkplumber.org

Reported-by: David Marchand <david.march...@redhat.com>
Signed-off-by: Ibtisam Tariq <ibtisam.ta...@emumba.com>
---
 examples/qos_sched/args.c | 161 +++++++++++++++++++++++---------------
 1 file changed, 99 insertions(+), 62 deletions(-)

diff --git a/examples/qos_sched/args.c b/examples/qos_sched/args.c
index c62719623..8411a87b5 100644
--- a/examples/qos_sched/args.c
+++ b/examples/qos_sched/args.c
@@ -297,6 +297,25 @@ app_parse_burst_conf(const char *conf_str)
        return 0;
 }
 
+enum {
+#define CMD_LINE_OPT_PFC "pfc"
+       CMD_LINE_OPT_PFC_NUM = 256,
+#define CMD_LINE_OPT_MNC "mnc"
+       CMD_LINE_OPT_MNC_NUM,
+#define CMD_LINE_OPT_RSZ "rsz"
+       CMD_LINE_OPT_RSZ_NUM,
+#define CMD_LINE_OPT_BSZ "bsz"
+       CMD_LINE_OPT_BSZ_NUM,
+#define CMD_LINE_OPT_MSZ "msz"
+       CMD_LINE_OPT_MSZ_NUM,
+#define CMD_LINE_OPT_RTH "rth"
+       CMD_LINE_OPT_RTH_NUM,
+#define CMD_LINE_OPT_TTH "tth"
+       CMD_LINE_OPT_TTH_NUM,
+#define CMD_LINE_OPT_CFG "cfg"
+       CMD_LINE_OPT_CFG_NUM,
+};
+
 /*
  * Parses the argument given in the command line of the application,
  * calculates mask for used cores and initializes EAL with calculated core mask
@@ -306,19 +325,26 @@ app_parse_args(int argc, char **argv)
 {
        int opt, ret;
        int option_index;
-       const char *optname;
        char *prgname = argv[0];
        uint32_t i, nb_lcores;
 
        static struct option lgopts[] = {
-               { "pfc", 1, 0, 0 },
-               { "mnc", 1, 0, 0 },
-               { "rsz", 1, 0, 0 },
-               { "bsz", 1, 0, 0 },
-               { "msz", 1, 0, 0 },
-               { "rth", 1, 0, 0 },
-               { "tth", 1, 0, 0 },
-               { "cfg", 1, 0, 0 },
+               { CMD_LINE_OPT_PFC, 1,
+                               NULL, CMD_LINE_OPT_PFC_NUM },
+               { CMD_LINE_OPT_MNC, 1,
+                               NULL, CMD_LINE_OPT_MNC_NUM},
+               { CMD_LINE_OPT_RSZ, 1,
+                               NULL, CMD_LINE_OPT_RSZ_NUM},
+               { CMD_LINE_OPT_BSZ, 1,
+                               NULL, CMD_LINE_OPT_BSZ_NUM},
+               { CMD_LINE_OPT_MSZ, 1,
+                               NULL, CMD_LINE_OPT_MSZ_NUM},
+               { CMD_LINE_OPT_RTH, 1,
+                               NULL, CMD_LINE_OPT_RTH_NUM},
+               { CMD_LINE_OPT_TTH, 1,
+                               NULL, CMD_LINE_OPT_TTH_NUM},
+               { CMD_LINE_OPT_CFG, 1,
+                               NULL, CMD_LINE_OPT_CFG_NUM},
                { NULL,  0, 0, 0 }
        };
 
@@ -342,66 +368,77 @@ app_parse_args(int argc, char **argv)
                                interactive = 1;
                                break;
                        /* long options */
-                       case 0:
-                               optname = lgopts[option_index].name;
-                               if (str_is(optname, "pfc")) {
-                                       ret = app_parse_flow_conf(optarg);
-                                       if (ret) {
-                                               RTE_LOG(ERR, APP, "Invalid pipe 
configuration %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
-                               }
-                               if (str_is(optname, "mnc")) {
-                                       app_main_core = (uint32_t)atoi(optarg);
-                                       break;
-                               }
-                               if (str_is(optname, "rsz")) {
-                                       ret = app_parse_ring_conf(optarg);
-                                       if (ret) {
-                                               RTE_LOG(ERR, APP, "Invalid ring 
configuration %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
+
+                       case CMD_LINE_OPT_PFC_NUM:
+                       {
+                               ret = app_parse_flow_conf(optarg);
+                               if (ret) {
+                                       RTE_LOG(ERR, APP, "Invalid pipe 
configuration %s\n",
+                                                       optarg);
+                                       return -1;
                                }
-                               if (str_is(optname, "bsz")) {
-                                       ret = app_parse_burst_conf(optarg);
-                                       if (ret) {
-                                               RTE_LOG(ERR, APP, "Invalid 
burst configuration %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
+                               break;
+                       }
+                       case CMD_LINE_OPT_MNC_NUM:
+                       {
+                               app_main_core = (uint32_t)atoi(optarg);
+                               break;
+                       }
+                       case CMD_LINE_OPT_RSZ_NUM:
+                       {
+                               ret = app_parse_ring_conf(optarg);
+                               if (ret) {
+                                       RTE_LOG(ERR, APP, "Invalid ring 
configuration %s\n",
+                                                       optarg);
+                                       return -1;
                                }
-                               if (str_is(optname, "msz")) {
-                                       mp_size = atoi(optarg);
-                                       if (mp_size <= 0) {
-                                               RTE_LOG(ERR, APP, "Invalid 
mempool size %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
+                               break;
+                       }
+                       case CMD_LINE_OPT_BSZ_NUM:
+                       {
+                               ret = app_parse_burst_conf(optarg);
+                               if (ret) {
+                                       RTE_LOG(ERR, APP, "Invalid burst 
configuration %s\n",
+                                                       optarg);
+                                       return -1;
                                }
-                               if (str_is(optname, "rth")) {
-                                       ret = app_parse_rth_conf(optarg);
-                                       if (ret) {
-                                               RTE_LOG(ERR, APP, "Invalid RX 
threshold configuration %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
+                               break;
+                       }
+                       case CMD_LINE_OPT_MSZ_NUM:
+                       {
+                               mp_size = atoi(optarg);
+                               if (mp_size <= 0) {
+                                       RTE_LOG(ERR, APP, "Invalid mempool size 
%s\n",
+                                                       optarg);
+                                       return -1;
                                }
-                               if (str_is(optname, "tth")) {
-                                       ret = app_parse_tth_conf(optarg);
-                                       if (ret) {
-                                               RTE_LOG(ERR, APP, "Invalid TX 
threshold configuration %s\n", optarg);
-                                               return -1;
-                                       }
-                                       break;
+                               break;
+                       }
+                       case CMD_LINE_OPT_RTH_NUM:
+                       {
+                               ret = app_parse_rth_conf(optarg);
+                               if (ret) {
+                                       RTE_LOG(ERR, APP, "Invalid RX threshold 
configuration %s\n",
+                                                       optarg);
+                                       return -1;
                                }
-                               if (str_is(optname, "cfg")) {
-                                       cfg_profile = optarg;
-                                       break;
+                               break;
+                       }
+                       case CMD_LINE_OPT_TTH_NUM:
+                       {
+                               ret = app_parse_tth_conf(optarg);
+                               if (ret) {
+                                       RTE_LOG(ERR, APP, "Invalid TX threshold 
configuration %s\n",
+                                                       optarg);
+                                       return -1;
                                }
                                break;
-
+                       }
+                       case CMD_LINE_OPT_CFG_NUM:
+                       {
+                               cfg_profile = optarg;
+                               break;
+                       }
                        default:
                                app_usage(prgname);
                                return -1;
-- 
2.17.1

Reply via email to