graph: remove useless duplicate name check
[dpdk.git] / app / test / test_event_eth_rx_adapter.c
index add4d8a..e358a70 100644 (file)
@@ -1,18 +1,37 @@
 /* SPDX-License-Identifier: BSD-3-Clause
  * Copyright(c) 2017 Intel Corporation
  */
+
+#include "test.h"
+
 #include <string.h>
 #include <rte_common.h>
 #include <rte_mempool.h>
 #include <rte_mbuf.h>
 #include <rte_ethdev.h>
+
+#ifdef RTE_EXEC_ENV_WINDOWS
+static int
+test_event_eth_rx_adapter_common(void)
+{
+       printf("event_eth_rx_adapter not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_event_eth_rx_intr_adapter_common(void)
+{
+       printf("event_eth_rx_intr_adapter not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+#else
+
 #include <rte_eventdev.h>
 #include <rte_bus_vdev.h>
 
 #include <rte_event_eth_rx_adapter.h>
 
-#include "test.h"
-
 #define MAX_NUM_RX_QUEUE       64
 #define NB_MBUFS               (8192 * num_ports * MAX_NUM_RX_QUEUE)
 #define MBUF_CACHE_SIZE                512
@@ -103,7 +122,7 @@ port_init_rx_intr(uint16_t port, struct rte_mempool *mp)
 {
        static const struct rte_eth_conf port_conf_default = {
                .rxmode = {
-                       .mq_mode = ETH_MQ_RX_NONE,
+                       .mq_mode = RTE_ETH_MQ_RX_NONE,
                },
                .intr_conf = {
                        .rxq = 1,
@@ -118,7 +137,7 @@ port_init(uint16_t port, struct rte_mempool *mp)
 {
        static const struct rte_eth_conf port_conf_default = {
                .rxmode = {
-                       .mq_mode = ETH_MQ_RX_NONE,
+                       .mq_mode = RTE_ETH_MQ_RX_NONE,
                },
        };
 
@@ -387,6 +406,148 @@ adapter_create(void)
        return err;
 }
 
+static int
+adapter_create_with_params(void)
+{
+       int err;
+       struct rte_event_dev_info dev_info;
+       struct rte_event_port_conf rx_p_conf;
+       struct rte_event_eth_rx_adapter_params rxa_params;
+
+       memset(&rx_p_conf, 0, sizeof(rx_p_conf));
+
+       err = rte_event_dev_info_get(TEST_DEV_ID, &dev_info);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       rx_p_conf.new_event_threshold = dev_info.max_num_events;
+       rx_p_conf.dequeue_depth = dev_info.max_event_port_dequeue_depth;
+       rx_p_conf.enqueue_depth = dev_info.max_event_port_enqueue_depth;
+
+       rxa_params.use_queue_event_buf = false;
+       rxa_params.event_buf_size = 0;
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       rxa_params.use_queue_event_buf = true;
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == -EEXIST, "Expected -EEXIST got %d", err);
+
+       return TEST_SUCCESS;
+}
+
+static int
+adapter_queue_event_buf_test(void)
+{
+       int err;
+       struct rte_event ev;
+       uint32_t cap;
+
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
+
+       err = rte_event_eth_rx_adapter_caps_get(TEST_DEV_ID, TEST_ETHDEV_ID,
+                                        &cap);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       ev.queue_id = 0;
+       ev.sched_type = RTE_SCHED_TYPE_ATOMIC;
+       ev.priority = 0;
+
+       queue_config.rx_queue_flags = 0;
+       if (cap & RTE_EVENT_ETH_RX_ADAPTER_CAP_OVERRIDE_FLOW_ID) {
+               ev.flow_id = 1;
+               queue_config.rx_queue_flags =
+                       RTE_EVENT_ETH_RX_ADAPTER_QUEUE_FLOW_ID_VALID;
+       }
+       queue_config.ev = ev;
+       queue_config.servicing_weight = 1;
+       queue_config.event_buf_size = 0;
+
+       err = rte_event_eth_rx_adapter_queue_add(TEST_INST_ID,
+                                       TEST_ETHDEV_ID, 0,
+                                       &queue_config);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       queue_config.event_buf_size = 1024;
+
+       err = rte_event_eth_rx_adapter_queue_add(TEST_INST_ID,
+                                       TEST_ETHDEV_ID, 0,
+                                       &queue_config);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_queue_del(TEST_INST_ID,
+                                               TEST_ETHDEV_ID,
+                                               0);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       return TEST_SUCCESS;
+}
+
+static int
+adapter_queue_stats_test(void)
+{
+       int err;
+       struct rte_event ev;
+       uint32_t cap;
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
+       struct rte_event_eth_rx_adapter_queue_stats q_stats;
+
+       err = rte_event_eth_rx_adapter_queue_stats_get(TEST_INST_ID,
+                                               TEST_ETHDEV_ID, 0,
+                                               &q_stats);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       err = rte_event_eth_rx_adapter_queue_stats_reset(TEST_INST_ID,
+                                               TEST_ETHDEV_ID, 0);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       err = rte_event_eth_rx_adapter_caps_get(TEST_DEV_ID, TEST_ETHDEV_ID,
+                                        &cap);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       ev.queue_id = 0;
+       ev.sched_type = RTE_SCHED_TYPE_ATOMIC;
+       ev.priority = 0;
+
+       queue_config.rx_queue_flags = 0;
+       if (cap & RTE_EVENT_ETH_RX_ADAPTER_CAP_OVERRIDE_FLOW_ID) {
+               ev.flow_id = 1;
+               queue_config.rx_queue_flags =
+                       RTE_EVENT_ETH_RX_ADAPTER_QUEUE_FLOW_ID_VALID;
+       }
+       queue_config.ev = ev;
+       queue_config.servicing_weight = 1;
+       queue_config.event_buf_size = 1024;
+
+       err = rte_event_eth_rx_adapter_queue_add(TEST_INST_ID,
+                                       TEST_ETHDEV_ID, 0,
+                                       &queue_config);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_queue_stats_get(TEST_INST_ID,
+                                               TEST_ETHDEV_ID, 0,
+                                               &q_stats);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_queue_stats_reset(TEST_INST_ID,
+                                               TEST_ETHDEV_ID, 0);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_queue_del(TEST_INST_ID,
+                                               TEST_ETHDEV_ID,
+                                               0);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       return TEST_SUCCESS;
+}
+
 static void
 adapter_free(void)
 {
@@ -428,6 +589,50 @@ adapter_create_free(void)
        return TEST_SUCCESS;
 }
 
+static int
+adapter_create_free_with_params(void)
+{
+       int err;
+
+       struct rte_event_port_conf rx_p_conf = {
+                       .dequeue_depth = 8,
+                       .enqueue_depth = 8,
+                       .new_event_threshold = 1200,
+       };
+
+       struct rte_event_eth_rx_adapter_params rxa_params = {
+                       .event_buf_size = 1024
+       };
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, NULL, NULL);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == -EEXIST, "Expected -EEXIST %d got %d", -EEXIST, err);
+
+       rxa_params.event_buf_size = 0;
+       err = rte_event_eth_rx_adapter_create_with_params(TEST_INST_ID,
+                               TEST_DEV_ID, &rx_p_conf, &rxa_params);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       err = rte_event_eth_rx_adapter_free(TEST_INST_ID);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       err = rte_event_eth_rx_adapter_free(TEST_INST_ID);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL %d got %d", -EINVAL, err);
+
+       err = rte_event_eth_rx_adapter_free(1);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL %d got %d", -EINVAL, err);
+
+       return TEST_SUCCESS;
+}
+
 static int
 adapter_queue_add_del(void)
 {
@@ -435,7 +640,7 @@ adapter_queue_add_del(void)
        struct rte_event ev;
        uint32_t cap;
 
-       struct rte_event_eth_rx_adapter_queue_conf queue_config;
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
 
        err = rte_event_eth_rx_adapter_caps_get(TEST_DEV_ID, TEST_ETHDEV_ID,
                                         &cap);
@@ -523,7 +728,7 @@ adapter_multi_eth_add_del(void)
        uint16_t port_index, port_index_base, drv_id = 0;
        char driver_name[50];
 
-       struct rte_event_eth_rx_adapter_queue_conf queue_config;
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
 
        ev.queue_id = 0;
        ev.sched_type = RTE_SCHED_TYPE_ATOMIC;
@@ -594,7 +799,7 @@ adapter_intr_queue_add_del(void)
        struct rte_event ev;
        uint32_t cap;
        uint16_t eth_port;
-       struct rte_event_eth_rx_adapter_queue_conf queue_config;
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
 
        if (!default_params.rx_intr_port_inited)
                return 0;
@@ -687,7 +892,7 @@ adapter_start_stop(void)
        ev.sched_type = RTE_SCHED_TYPE_ATOMIC;
        ev.priority = 0;
 
-       struct rte_event_eth_rx_adapter_queue_conf queue_config;
+       struct rte_event_eth_rx_adapter_queue_conf queue_config = {0};
 
        queue_config.rx_queue_flags = 0;
        if (default_params.caps &
@@ -747,18 +952,73 @@ adapter_stats(void)
        return TEST_SUCCESS;
 }
 
+static int
+adapter_queue_conf(void)
+{
+       int err;
+       struct rte_event_eth_rx_adapter_queue_conf queue_conf = {0};
+
+       /* Case 1: queue conf get without any queues in Rx adapter */
+       err = rte_event_eth_rx_adapter_queue_conf_get(TEST_INST_ID,
+                                                     TEST_ETHDEV_ID,
+                                                     0, &queue_conf);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       /* Add queue to Rx adapter */
+       queue_conf.ev.queue_id = 0;
+       queue_conf.ev.sched_type = RTE_SCHED_TYPE_ATOMIC;
+       queue_conf.ev.priority = RTE_EVENT_DEV_PRIORITY_NORMAL;
+
+       err = rte_event_eth_rx_adapter_queue_add(TEST_INST_ID,
+                                                TEST_ETHDEV_ID,
+                                                0, &queue_conf);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       /* Case 2: queue conf get with queue added to Rx adapter */
+       err = rte_event_eth_rx_adapter_queue_conf_get(TEST_INST_ID,
+                                                     TEST_ETHDEV_ID,
+                                                     0, &queue_conf);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       /* Case 3: queue conf get with invalid rx queue id */
+       err = rte_event_eth_rx_adapter_queue_conf_get(TEST_INST_ID,
+                                                     TEST_ETHDEV_ID,
+                                                     -1, &queue_conf);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       /* Case 4: queue conf get with NULL queue conf struct */
+       err = rte_event_eth_rx_adapter_queue_conf_get(TEST_INST_ID,
+                                                     TEST_ETHDEV_ID,
+                                                     0, NULL);
+       TEST_ASSERT(err == -EINVAL, "Expected -EINVAL got %d", err);
+
+       /* Delete queue from the Rx adapter */
+       err = rte_event_eth_rx_adapter_queue_del(TEST_INST_ID,
+                                                TEST_ETHDEV_ID,
+                                                0);
+       TEST_ASSERT(err == 0, "Expected 0 got %d", err);
+
+       return TEST_SUCCESS;
+}
+
 static struct unit_test_suite event_eth_rx_tests = {
        .suite_name = "rx event eth adapter test suite",
        .setup = testsuite_setup,
        .teardown = testsuite_teardown,
        .unit_test_cases = {
                TEST_CASE_ST(NULL, NULL, adapter_create_free),
+               TEST_CASE_ST(NULL, NULL, adapter_create_free_with_params),
                TEST_CASE_ST(adapter_create, adapter_free,
                                        adapter_queue_add_del),
                TEST_CASE_ST(adapter_create, adapter_free,
                                        adapter_multi_eth_add_del),
                TEST_CASE_ST(adapter_create, adapter_free, adapter_start_stop),
                TEST_CASE_ST(adapter_create, adapter_free, adapter_stats),
+               TEST_CASE_ST(adapter_create, adapter_free, adapter_queue_conf),
+               TEST_CASE_ST(adapter_create_with_params, adapter_free,
+                            adapter_queue_event_buf_test),
+               TEST_CASE_ST(adapter_create_with_params, adapter_free,
+                            adapter_queue_stats_test),
                TEST_CASES_END() /**< NULL terminate unit test array */
        }
 };
@@ -786,6 +1046,8 @@ test_event_eth_rx_intr_adapter_common(void)
        return unit_test_suite_runner(&event_eth_rx_intr_tests);
 }
 
+#endif /* !RTE_EXEC_ENV_WINDOWS */
+
 REGISTER_TEST_COMMAND(event_eth_rx_adapter_autotest,
                test_event_eth_rx_adapter_common);
 REGISTER_TEST_COMMAND(event_eth_rx_intr_adapter_autotest,