test/crypto-perf: extend asymmetric crypto throughput test
[dpdk.git] / app / test-eventdev / evt_options.c
index 47e37bc..d3c704d 100644 (file)
@@ -7,6 +7,7 @@
 #include <inttypes.h>
 #include <getopt.h>
 
+#include <rte_string_fns.h>
 #include <rte_common.h>
 #include <rte_eventdev.h>
 #include <rte_lcore.h>
@@ -25,6 +26,7 @@ evt_options_default(struct evt_options *opt)
        opt->nb_flows = 1024;
        opt->socket_id = SOCKET_ID_ANY;
        opt->pool_sz = 16 * 1024;
+       opt->prod_enq_burst_sz = 1;
        opt->wkr_deq_dep = 16;
        opt->nb_pkts = (1ULL << 26); /* do ~64M packets */
        opt->nb_timers = 1E8;
@@ -33,6 +35,9 @@ evt_options_default(struct evt_options *opt)
        opt->max_tmo_nsec = 1E5;  /* 100000ns ~100us */
        opt->expiry_nsec = 1E4;   /* 10000ns ~10us */
        opt->prod_type = EVT_PROD_TYPE_SYNT;
+       opt->eth_queues = 1;
+       opt->vector_size = 64;
+       opt->vector_tmo_nsec = 100E3;
 }
 
 typedef int (*option_parser_t)(struct evt_options *opt,
@@ -84,6 +89,16 @@ evt_parse_queue_priority(struct evt_options *opt, const char *arg __rte_unused)
        return 0;
 }
 
+static int
+evt_parse_deq_tmo_nsec(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint32(&(opt->deq_tmo_nsec), arg);
+
+       return ret;
+}
+
 static int
 evt_parse_eth_prod_type(struct evt_options *opt, const char *arg __rte_unused)
 {
@@ -98,10 +113,39 @@ evt_parse_timer_prod_type(struct evt_options *opt, const char *arg __rte_unused)
        return 0;
 }
 
+static int
+evt_parse_timer_prod_type_burst(struct evt_options *opt,
+               const char *arg __rte_unused)
+{
+       opt->prod_type = EVT_PROD_TYPE_EVENT_TIMER_ADPTR;
+       opt->timdev_use_burst = 1;
+       return 0;
+}
+
+static int
+evt_parse_crypto_prod_type(struct evt_options *opt,
+                          const char *arg __rte_unused)
+{
+       opt->prod_type = EVT_PROD_TYPE_EVENT_CRYPTO_ADPTR;
+       return 0;
+}
+
+static int
+evt_parse_crypto_adptr_mode(struct evt_options *opt, const char *arg)
+{
+       uint8_t mode;
+       int ret;
+
+       ret = parser_read_uint8(&mode, arg);
+       opt->crypto_adptr_mode = mode ? RTE_EVENT_CRYPTO_ADAPTER_OP_FORWARD :
+                                       RTE_EVENT_CRYPTO_ADAPTER_OP_NEW;
+       return ret;
+}
+
 static int
 evt_parse_test_name(struct evt_options *opt, const char *arg)
 {
-       snprintf(opt->test_name, EVT_TEST_NAME_MAX_LEN, "%s", arg);
+       strlcpy(opt->test_name, arg, EVT_TEST_NAME_MAX_LEN);
        return 0;
 }
 
@@ -131,6 +175,60 @@ evt_parse_nb_pkts(struct evt_options *opt, const char *arg)
        return ret;
 }
 
+static int
+evt_parse_nb_timers(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint64(&(opt->nb_timers), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_timer_tick_nsec(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint64(&(opt->timer_tick_nsec), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_max_tmo_nsec(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint64(&(opt->max_tmo_nsec), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_expiry_nsec(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint64(&(opt->expiry_nsec), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_nb_timer_adptrs(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint8(&(opt->nb_timer_adptrs), arg);
+       if (opt->nb_timer_adptrs <= 0) {
+               evt_err("Number of timer adapters cannot be <= 0");
+               return -EINVAL;
+       }
+
+       return ret;
+}
+
 static int
 evt_parse_pool_sz(struct evt_options *opt, const char *arg)
 {
@@ -144,7 +242,7 @@ evt_parse_plcores(struct evt_options *opt, const char *corelist)
 {
        int ret;
 
-       ret = parse_lcores_list(opt->plcores, corelist);
+       ret = parse_lcores_list(opt->plcores, RTE_MAX_LCORE, corelist);
        if (ret == -E2BIG)
                evt_err("duplicate lcores in plcores");
 
@@ -156,13 +254,87 @@ evt_parse_work_lcores(struct evt_options *opt, const char *corelist)
 {
        int ret;
 
-       ret = parse_lcores_list(opt->wlcores, corelist);
+       ret = parse_lcores_list(opt->wlcores, RTE_MAX_LCORE, corelist);
        if (ret == -E2BIG)
                evt_err("duplicate lcores in wlcores");
 
        return ret;
 }
 
+static int
+evt_parse_mbuf_sz(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint16(&(opt->mbuf_sz), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_max_pkt_sz(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint32(&(opt->max_pkt_sz), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_ena_vector(struct evt_options *opt, const char *arg __rte_unused)
+{
+       opt->ena_vector = 1;
+       return 0;
+}
+
+static int
+evt_parse_vector_size(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint16(&(opt->vector_size), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_vector_tmo_ns(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint64(&(opt->vector_tmo_nsec), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_eth_queues(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint16(&(opt->eth_queues), arg);
+
+       return ret;
+}
+
+static int
+evt_parse_per_port_pool(struct evt_options *opt, const char *arg __rte_unused)
+{
+       opt->per_port_pool = 1;
+       return 0;
+}
+
+static int
+evt_parse_prod_enq_burst_sz(struct evt_options *opt, const char *arg)
+{
+       int ret;
+
+       ret = parser_read_uint32(&(opt->prod_enq_burst_sz), arg);
+
+       return ret;
+}
+
 static void
 usage(char *program)
 {
@@ -181,10 +353,29 @@ usage(char *program)
                "\t--worker_deq_depth : dequeue depth of the worker\n"
                "\t--fwd_latency      : perform fwd_latency measurement\n"
                "\t--queue_priority   : enable queue priority\n"
+               "\t--deq_tmo_nsec     : global dequeue timeout\n"
                "\t--prod_type_ethdev : use ethernet device as producer.\n"
+               "\t--prod_type_cryptodev : use crypto device as producer.\n"
                "\t--prod_type_timerdev : use event timer device as producer.\n"
-               "\t                     expity_nsec would be the timeout\n"
+               "\t                     expiry_nsec would be the timeout\n"
                "\t                     in ns.\n"
+               "\t--prod_type_timerdev_burst : use timer device as producer\n"
+               "\t                             burst mode.\n"
+               "\t--nb_timers        : number of timers to arm.\n"
+               "\t--nb_timer_adptrs  : number of timer adapters to use.\n"
+               "\t--timer_tick_nsec  : timer tick interval in ns.\n"
+               "\t--max_tmo_nsec     : max timeout interval in ns.\n"
+               "\t--expiry_nsec      : event timer expiry ns.\n"
+               "\t--crypto_adptr_mode : 0 for OP_NEW mode (default) and\n"
+               "\t                      1 for OP_FORWARD mode.\n"
+               "\t--mbuf_sz          : packet mbuf size.\n"
+               "\t--max_pkt_sz       : max packet size.\n"
+               "\t--prod_enq_burst_sz : producer enqueue burst size.\n"
+               "\t--nb_eth_queues    : number of ethernet Rx queues.\n"
+               "\t--enable_vector    : enable event vectorization.\n"
+               "\t--vector_size      : Max vector size.\n"
+               "\t--vector_tmo_ns    : Max vector timeout in nanoseconds\n"
+               "\t--per_port_pool    : Configure unique pool per ethdev port\n"
                );
        printf("available tests:\n");
        evt_test_dump_names();
@@ -245,8 +436,25 @@ static struct option lgopts[] = {
        { EVT_SCHED_TYPE_LIST,     1, 0, 0 },
        { EVT_FWD_LATENCY,         0, 0, 0 },
        { EVT_QUEUE_PRIORITY,      0, 0, 0 },
+       { EVT_DEQ_TMO_NSEC,        1, 0, 0 },
        { EVT_PROD_ETHDEV,         0, 0, 0 },
+       { EVT_PROD_CRYPTODEV,      0, 0, 0 },
        { EVT_PROD_TIMERDEV,       0, 0, 0 },
+       { EVT_PROD_TIMERDEV_BURST, 0, 0, 0 },
+       { EVT_CRYPTO_ADPTR_MODE,   1, 0, 0 },
+       { EVT_NB_TIMERS,           1, 0, 0 },
+       { EVT_NB_TIMER_ADPTRS,     1, 0, 0 },
+       { EVT_TIMER_TICK_NSEC,     1, 0, 0 },
+       { EVT_MAX_TMO_NSEC,        1, 0, 0 },
+       { EVT_EXPIRY_NSEC,         1, 0, 0 },
+       { EVT_MBUF_SZ,             1, 0, 0 },
+       { EVT_MAX_PKT_SZ,          1, 0, 0 },
+       { EVT_PROD_ENQ_BURST_SZ,   1, 0, 0 },
+       { EVT_NB_ETH_QUEUES,       1, 0, 0 },
+       { EVT_ENA_VECTOR,          0, 0, 0 },
+       { EVT_VECTOR_SZ,           1, 0, 0 },
+       { EVT_VECTOR_TMO,          1, 0, 0 },
+       { EVT_PER_PORT_POOL,       0, 0, 0 },
        { EVT_HELP,                0, 0, 0 },
        { NULL,                    0, 0, 0 }
 };
@@ -270,8 +478,25 @@ evt_opts_parse_long(int opt_idx, struct evt_options *opt)
                { EVT_SCHED_TYPE_LIST, evt_parse_sched_type_list},
                { EVT_FWD_LATENCY, evt_parse_fwd_latency},
                { EVT_QUEUE_PRIORITY, evt_parse_queue_priority},
+               { EVT_DEQ_TMO_NSEC, evt_parse_deq_tmo_nsec},
                { EVT_PROD_ETHDEV, evt_parse_eth_prod_type},
+               { EVT_PROD_CRYPTODEV, evt_parse_crypto_prod_type},
                { EVT_PROD_TIMERDEV, evt_parse_timer_prod_type},
+               { EVT_PROD_TIMERDEV_BURST, evt_parse_timer_prod_type_burst},
+               { EVT_CRYPTO_ADPTR_MODE, evt_parse_crypto_adptr_mode},
+               { EVT_NB_TIMERS, evt_parse_nb_timers},
+               { EVT_NB_TIMER_ADPTRS, evt_parse_nb_timer_adptrs},
+               { EVT_TIMER_TICK_NSEC, evt_parse_timer_tick_nsec},
+               { EVT_MAX_TMO_NSEC, evt_parse_max_tmo_nsec},
+               { EVT_EXPIRY_NSEC, evt_parse_expiry_nsec},
+               { EVT_MBUF_SZ, evt_parse_mbuf_sz},
+               { EVT_MAX_PKT_SZ, evt_parse_max_pkt_sz},
+               { EVT_PROD_ENQ_BURST_SZ, evt_parse_prod_enq_burst_sz},
+               { EVT_NB_ETH_QUEUES, evt_parse_eth_queues},
+               { EVT_ENA_VECTOR, evt_parse_ena_vector},
+               { EVT_VECTOR_SZ, evt_parse_vector_size},
+               { EVT_VECTOR_TMO, evt_parse_vector_tmo_ns},
+               { EVT_PER_PORT_POOL, evt_parse_per_port_pool},
        };
 
        for (i = 0; i < RTE_DIM(parsermap); i++) {
@@ -320,7 +545,7 @@ evt_options_dump(struct evt_options *opt)
        evt_dump("verbose_level", "%d", opt->verbose_level);
        evt_dump("socket_id", "%d", opt->socket_id);
        evt_dump("pool_sz", "%d", opt->pool_sz);
-       evt_dump("master lcore", "%d", rte_get_master_lcore());
+       evt_dump("main lcore", "%d", rte_get_main_lcore());
        evt_dump("nb_pkts", "%"PRIu64, opt->nb_pkts);
        evt_dump("nb_timers", "%"PRIu64, opt->nb_timers);
        evt_dump_begin("available lcores");