This patch support memarea test about API rte_memarea_create and
rte_memarea_destroy.

Signed-off-by: Chengwen Feng <fengcheng...@huawei.com>
---
 MAINTAINERS             |   1 +
 app/test/meson.build    |   2 +
 app/test/test_memarea.c | 134 ++++++++++++++++++++++++++++++++++++++++
 3 files changed, 137 insertions(+)
 create mode 100644 app/test/test_memarea.c

diff --git a/MAINTAINERS b/MAINTAINERS
index 4d5bf986c6..eb2de32884 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -1562,6 +1562,7 @@ Memarea - EXPERIMENTAL
 M: Chengwen Feng <fengcheng...@huawei.com>
 F: lib/memarea
 F: doc/guides/prog_guide/memarea_lib.rst
+F: app/test/test_memarea*
 
 Membership - EXPERIMENTAL
 M: Yipeng Wang <yipeng1.w...@intel.com>
diff --git a/app/test/meson.build b/app/test/meson.build
index d5cad72116..778de8d65d 100644
--- a/app/test/meson.build
+++ b/app/test/meson.build
@@ -84,6 +84,7 @@ test_sources = files(
         'test_malloc.c',
         'test_malloc_perf.c',
         'test_mbuf.c',
+        'test_memarea.c',
         'test_member.c',
         'test_member_perf.c',
         'test_memcpy.c',
@@ -199,6 +200,7 @@ fast_tests = [
         ['malloc_autotest', false, true],
         ['mbuf_autotest', false, true],
         ['mcslock_autotest', false, true],
+        ['memarea_autotest', true, true],
         ['memcpy_autotest', true, true],
         ['memory_autotest', false, true],
         ['mempool_autotest', false, true],
diff --git a/app/test/test_memarea.c b/app/test/test_memarea.c
new file mode 100644
index 0000000000..b2dbc71a50
--- /dev/null
+++ b/app/test/test_memarea.c
@@ -0,0 +1,134 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(c) 2022 HiSilicon Limited
+ */
+
+#include <stdio.h>
+#include <string.h>
+
+#include "test.h"
+
+#ifdef RTE_EXEC_ENV_WINDOWS
+static int
+test_memarea(void)
+{
+       printf("memarea not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+#else
+
+#include <rte_memarea.h>
+
+#define MEMAREA_TEST_DEFAULT_SIZE      0x1000
+
+#define MEMAREA_TEST_API_RUN(test_func) \
+       do { \
+               int ret = test_func(); \
+               if (ret < 0) \
+                       printf("%s Failed\n", #test_func); \
+               else \
+                       printf("%s Passed\n", #test_func); \
+       } while (0)
+
+static void
+test_memarea_init_def_param(struct rte_memarea_param *init)
+{
+       memset(init, 0, sizeof(struct rte_memarea_param));
+       sprintf(init->name, "%s", "test-memarea");
+       init->source = RTE_MEMAREA_SOURCE_SYSTEM_API;
+       init->total_sz = MEMAREA_TEST_DEFAULT_SIZE;
+       init->mt_safe = 1;
+}
+
+static int
+test_memarea_create_bad_param(void)
+{
+       struct rte_memarea_param init;
+       struct rte_memarea *ma;
+       int i;
+
+       /* test for NULL */
+       ma = rte_memarea_create(NULL);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       /* test for invalid name */
+       memset(&init, 0, sizeof(init));
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+       memset(&init.name, 1, sizeof(init.name));
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       /* test for invalid source */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_USER_MEMAREA + 1;
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       /* test for total_sz */
+       test_memarea_init_def_param(&init);
+       init.total_sz = 0;
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       /* test for user address NULL */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_USER_ADDR;
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       /* test for user address align invalid */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_USER_ADDR;
+       for (i = 1; i < RTE_CACHE_LINE_SIZE; i++) {
+               init.user_addr = (void *)((uintptr_t)i);
+               ma = rte_memarea_create(&init);
+               RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+       }
+
+       /* test for user memarea NULL */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_USER_MEMAREA;
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma == NULL, "Expected NULL");
+
+       return 0;
+}
+
+static int
+test_memarea_create_destroy(void)
+{
+       struct rte_memarea_param init;
+       uint8_t user_buffer[MEMAREA_TEST_DEFAULT_SIZE + RTE_CACHE_LINE_SIZE];
+       struct rte_memarea *ma;
+
+       /* test for create with system API */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_SYSTEM_API;
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma != NULL, "Expected Non-NULL");
+       rte_memarea_destroy(ma);
+
+       /* test for create with user-address */
+       test_memarea_init_def_param(&init);
+       init.source = RTE_MEMAREA_SOURCE_USER_ADDR;
+       init.user_addr = (void *)(((uintptr_t)user_buffer + 
RTE_CACHE_LINE_SIZE) &
+                                 ~(RTE_CACHE_LINE_SIZE - 1));
+       ma = rte_memarea_create(&init);
+       RTE_TEST_ASSERT(ma != NULL, "Expected Non-NULL");
+       rte_memarea_destroy(ma);
+
+       return 0;
+}
+
+static int
+test_memarea(void)
+{
+       MEMAREA_TEST_API_RUN(test_memarea_create_bad_param);
+       MEMAREA_TEST_API_RUN(test_memarea_create_destroy);
+       return 0;
+}
+
+#endif /* !RTE_EXEC_ENV_WINDOWS */
+
+REGISTER_TEST_COMMAND(memarea_autotest, test_memarea);
-- 
2.17.1

Reply via email to