14418919fSjohnjiang /* SPDX-License-Identifier: BSD-3-Clause
24418919fSjohnjiang * Copyright(c) 2018 Vladimir Medvedkin <[email protected]>
34418919fSjohnjiang * Copyright(c) 2019 Intel Corporation
44418919fSjohnjiang */
54418919fSjohnjiang
64418919fSjohnjiang #include <stdio.h>
74418919fSjohnjiang #include <stdint.h>
84418919fSjohnjiang #include <stdlib.h>
94418919fSjohnjiang
104418919fSjohnjiang #include <rte_memory.h>
114418919fSjohnjiang #include <rte_log.h>
124418919fSjohnjiang #include <rte_rib6.h>
134418919fSjohnjiang #include <rte_fib6.h>
144418919fSjohnjiang
154418919fSjohnjiang #include "test.h"
164418919fSjohnjiang
174418919fSjohnjiang typedef int32_t (*rte_fib6_test)(void);
184418919fSjohnjiang
194418919fSjohnjiang static int32_t test_create_invalid(void);
204418919fSjohnjiang static int32_t test_multiple_create(void);
214418919fSjohnjiang static int32_t test_free_null(void);
224418919fSjohnjiang static int32_t test_add_del_invalid(void);
234418919fSjohnjiang static int32_t test_get_invalid(void);
244418919fSjohnjiang static int32_t test_lookup(void);
254418919fSjohnjiang
264418919fSjohnjiang #define MAX_ROUTES (1 << 16)
274418919fSjohnjiang /** Maximum number of tbl8 for 2-byte entries */
284418919fSjohnjiang #define MAX_TBL8 (1 << 15)
294418919fSjohnjiang
304418919fSjohnjiang /*
314418919fSjohnjiang * Check that rte_fib6_create fails gracefully for incorrect user input
324418919fSjohnjiang * arguments
334418919fSjohnjiang */
344418919fSjohnjiang int32_t
test_create_invalid(void)354418919fSjohnjiang test_create_invalid(void)
364418919fSjohnjiang {
374418919fSjohnjiang struct rte_fib6 *fib = NULL;
384418919fSjohnjiang struct rte_fib6_conf config;
394418919fSjohnjiang
404418919fSjohnjiang config.max_routes = MAX_ROUTES;
414418919fSjohnjiang config.default_nh = 0;
424418919fSjohnjiang config.type = RTE_FIB6_DUMMY;
434418919fSjohnjiang
444418919fSjohnjiang /* rte_fib6_create: fib name == NULL */
454418919fSjohnjiang fib = rte_fib6_create(NULL, SOCKET_ID_ANY, &config);
464418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
474418919fSjohnjiang "Call succeeded with invalid parameters\n");
484418919fSjohnjiang
494418919fSjohnjiang /* rte_fib6_create: config == NULL */
504418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, NULL);
514418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
524418919fSjohnjiang "Call succeeded with invalid parameters\n");
534418919fSjohnjiang
544418919fSjohnjiang /* socket_id < -1 is invalid */
554418919fSjohnjiang fib = rte_fib6_create(__func__, -2, &config);
564418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
574418919fSjohnjiang "Call succeeded with invalid parameters\n");
584418919fSjohnjiang
594418919fSjohnjiang /* rte_fib6_create: max_routes = 0 */
604418919fSjohnjiang config.max_routes = 0;
614418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
624418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
634418919fSjohnjiang "Call succeeded with invalid parameters\n");
644418919fSjohnjiang config.max_routes = MAX_ROUTES;
654418919fSjohnjiang
66*2d9fd380Sjfb8856606 config.type = RTE_FIB6_TRIE + 1;
674418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
684418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
694418919fSjohnjiang "Call succeeded with invalid parameters\n");
704418919fSjohnjiang
714418919fSjohnjiang config.type = RTE_FIB6_TRIE;
724418919fSjohnjiang config.trie.num_tbl8 = MAX_TBL8;
734418919fSjohnjiang
744418919fSjohnjiang config.trie.nh_sz = RTE_FIB6_TRIE_8B + 1;
754418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
764418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
774418919fSjohnjiang "Call succeeded with invalid parameters\n");
784418919fSjohnjiang config.trie.nh_sz = RTE_FIB6_TRIE_8B;
794418919fSjohnjiang
804418919fSjohnjiang config.trie.num_tbl8 = 0;
814418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
824418919fSjohnjiang RTE_TEST_ASSERT(fib == NULL,
834418919fSjohnjiang "Call succeeded with invalid parameters\n");
844418919fSjohnjiang
854418919fSjohnjiang return TEST_SUCCESS;
864418919fSjohnjiang }
874418919fSjohnjiang
884418919fSjohnjiang /*
894418919fSjohnjiang * Create fib table then delete fib table 10 times
904418919fSjohnjiang * Use a slightly different rules size each time
914418919fSjohnjiang */
924418919fSjohnjiang int32_t
test_multiple_create(void)934418919fSjohnjiang test_multiple_create(void)
944418919fSjohnjiang {
954418919fSjohnjiang struct rte_fib6 *fib = NULL;
964418919fSjohnjiang struct rte_fib6_conf config;
974418919fSjohnjiang int32_t i;
984418919fSjohnjiang
994418919fSjohnjiang config.default_nh = 0;
1004418919fSjohnjiang config.type = RTE_FIB6_DUMMY;
1014418919fSjohnjiang
1024418919fSjohnjiang for (i = 0; i < 100; i++) {
1034418919fSjohnjiang config.max_routes = MAX_ROUTES - i;
1044418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
1054418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
1064418919fSjohnjiang rte_fib6_free(fib);
1074418919fSjohnjiang }
1084418919fSjohnjiang /* Can not test free so return success */
1094418919fSjohnjiang return TEST_SUCCESS;
1104418919fSjohnjiang }
1114418919fSjohnjiang
1124418919fSjohnjiang /*
1134418919fSjohnjiang * Call rte_fib6_free for NULL pointer user input. Note: free has no return and
1144418919fSjohnjiang * therefore it is impossible to check for failure but this test is added to
1154418919fSjohnjiang * increase function coverage metrics and to validate that freeing null does
1164418919fSjohnjiang * not crash.
1174418919fSjohnjiang */
1184418919fSjohnjiang int32_t
test_free_null(void)1194418919fSjohnjiang test_free_null(void)
1204418919fSjohnjiang {
1214418919fSjohnjiang struct rte_fib6 *fib = NULL;
1224418919fSjohnjiang struct rte_fib6_conf config;
1234418919fSjohnjiang
1244418919fSjohnjiang config.max_routes = MAX_ROUTES;
1254418919fSjohnjiang config.default_nh = 0;
1264418919fSjohnjiang config.type = RTE_FIB6_DUMMY;
1274418919fSjohnjiang
1284418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
1294418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
1304418919fSjohnjiang
1314418919fSjohnjiang rte_fib6_free(fib);
1324418919fSjohnjiang rte_fib6_free(NULL);
1334418919fSjohnjiang
1344418919fSjohnjiang return TEST_SUCCESS;
1354418919fSjohnjiang }
1364418919fSjohnjiang
1374418919fSjohnjiang /*
1384418919fSjohnjiang * Check that rte_fib6_add and rte_fib6_delete fails gracefully
1394418919fSjohnjiang * for incorrect user input arguments
1404418919fSjohnjiang */
1414418919fSjohnjiang int32_t
test_add_del_invalid(void)1424418919fSjohnjiang test_add_del_invalid(void)
1434418919fSjohnjiang {
1444418919fSjohnjiang struct rte_fib6 *fib = NULL;
1454418919fSjohnjiang struct rte_fib6_conf config;
1464418919fSjohnjiang uint64_t nh = 100;
1474418919fSjohnjiang uint8_t ip[RTE_FIB6_IPV6_ADDR_SIZE] = {0};
1484418919fSjohnjiang int ret;
1494418919fSjohnjiang uint8_t depth = 24;
1504418919fSjohnjiang
1514418919fSjohnjiang config.max_routes = MAX_ROUTES;
1524418919fSjohnjiang config.default_nh = 0;
1534418919fSjohnjiang config.type = RTE_FIB6_DUMMY;
1544418919fSjohnjiang
1554418919fSjohnjiang /* rte_fib6_add: fib == NULL */
1564418919fSjohnjiang ret = rte_fib6_add(NULL, ip, depth, nh);
1574418919fSjohnjiang RTE_TEST_ASSERT(ret < 0,
1584418919fSjohnjiang "Call succeeded with invalid parameters\n");
1594418919fSjohnjiang
1604418919fSjohnjiang /* rte_fib6_delete: fib == NULL */
1614418919fSjohnjiang ret = rte_fib6_delete(NULL, ip, depth);
1624418919fSjohnjiang RTE_TEST_ASSERT(ret < 0,
1634418919fSjohnjiang "Call succeeded with invalid parameters\n");
1644418919fSjohnjiang
1654418919fSjohnjiang /*Create valid fib to use in rest of test. */
1664418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
1674418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
1684418919fSjohnjiang
1694418919fSjohnjiang /* rte_fib6_add: depth > RTE_FIB6_MAXDEPTH */
1704418919fSjohnjiang ret = rte_fib6_add(fib, ip, RTE_FIB6_MAXDEPTH + 1, nh);
1714418919fSjohnjiang RTE_TEST_ASSERT(ret < 0,
1724418919fSjohnjiang "Call succeeded with invalid parameters\n");
1734418919fSjohnjiang
1744418919fSjohnjiang /* rte_fib6_delete: depth > RTE_FIB6_MAXDEPTH */
1754418919fSjohnjiang ret = rte_fib6_delete(fib, ip, RTE_FIB6_MAXDEPTH + 1);
1764418919fSjohnjiang RTE_TEST_ASSERT(ret < 0,
1774418919fSjohnjiang "Call succeeded with invalid parameters\n");
1784418919fSjohnjiang
1794418919fSjohnjiang rte_fib6_free(fib);
1804418919fSjohnjiang
1814418919fSjohnjiang return TEST_SUCCESS;
1824418919fSjohnjiang }
1834418919fSjohnjiang
1844418919fSjohnjiang /*
1854418919fSjohnjiang * Check that rte_fib6_get_dp and rte_fib6_get_rib fails gracefully
1864418919fSjohnjiang * for incorrect user input arguments
1874418919fSjohnjiang */
1884418919fSjohnjiang int32_t
test_get_invalid(void)1894418919fSjohnjiang test_get_invalid(void)
1904418919fSjohnjiang {
1914418919fSjohnjiang void *p;
1924418919fSjohnjiang
1934418919fSjohnjiang p = rte_fib6_get_dp(NULL);
1944418919fSjohnjiang RTE_TEST_ASSERT(p == NULL,
1954418919fSjohnjiang "Call succeeded with invalid parameters\n");
1964418919fSjohnjiang
1974418919fSjohnjiang p = rte_fib6_get_rib(NULL);
1984418919fSjohnjiang RTE_TEST_ASSERT(p == NULL,
1994418919fSjohnjiang "Call succeeded with invalid parameters\n");
2004418919fSjohnjiang
2014418919fSjohnjiang return TEST_SUCCESS;
2024418919fSjohnjiang }
2034418919fSjohnjiang
2044418919fSjohnjiang /*
2054418919fSjohnjiang * Add routes for one supernet with all possible depths and do lookup
2064418919fSjohnjiang * on each step
2074418919fSjohnjiang * After delete routes with doing lookup on each step
2084418919fSjohnjiang */
2094418919fSjohnjiang static int
lookup_and_check_asc(struct rte_fib6 * fib,uint8_t ip_arr[RTE_FIB6_MAXDEPTH][RTE_FIB6_IPV6_ADDR_SIZE],uint8_t ip_missing[][RTE_FIB6_IPV6_ADDR_SIZE],uint64_t def_nh,uint32_t n)2104418919fSjohnjiang lookup_and_check_asc(struct rte_fib6 *fib,
2114418919fSjohnjiang uint8_t ip_arr[RTE_FIB6_MAXDEPTH][RTE_FIB6_IPV6_ADDR_SIZE],
2124418919fSjohnjiang uint8_t ip_missing[][RTE_FIB6_IPV6_ADDR_SIZE], uint64_t def_nh,
2134418919fSjohnjiang uint32_t n)
2144418919fSjohnjiang {
2154418919fSjohnjiang uint64_t nh_arr[RTE_FIB6_MAXDEPTH];
2164418919fSjohnjiang int ret;
2174418919fSjohnjiang uint32_t i = 0;
2184418919fSjohnjiang
2194418919fSjohnjiang ret = rte_fib6_lookup_bulk(fib, ip_arr, nh_arr, RTE_FIB6_MAXDEPTH);
2204418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to lookup\n");
2214418919fSjohnjiang
2224418919fSjohnjiang for (; i <= RTE_FIB6_MAXDEPTH - n; i++)
2234418919fSjohnjiang RTE_TEST_ASSERT(nh_arr[i] == n,
2244418919fSjohnjiang "Failed to get proper nexthop\n");
2254418919fSjohnjiang
2264418919fSjohnjiang for (; i < RTE_FIB6_MAXDEPTH; i++)
2274418919fSjohnjiang RTE_TEST_ASSERT(nh_arr[i] == --n,
2284418919fSjohnjiang "Failed to get proper nexthop\n");
2294418919fSjohnjiang
2304418919fSjohnjiang ret = rte_fib6_lookup_bulk(fib, ip_missing, nh_arr, 1);
2314418919fSjohnjiang RTE_TEST_ASSERT((ret == 0) && (nh_arr[0] == def_nh),
2324418919fSjohnjiang "Failed to get proper nexthop\n");
2334418919fSjohnjiang
2344418919fSjohnjiang return TEST_SUCCESS;
2354418919fSjohnjiang }
2364418919fSjohnjiang
2374418919fSjohnjiang static int
lookup_and_check_desc(struct rte_fib6 * fib,uint8_t ip_arr[RTE_FIB6_MAXDEPTH][RTE_FIB6_IPV6_ADDR_SIZE],uint8_t ip_missing[][RTE_FIB6_IPV6_ADDR_SIZE],uint64_t def_nh,uint32_t n)2384418919fSjohnjiang lookup_and_check_desc(struct rte_fib6 *fib,
2394418919fSjohnjiang uint8_t ip_arr[RTE_FIB6_MAXDEPTH][RTE_FIB6_IPV6_ADDR_SIZE],
2404418919fSjohnjiang uint8_t ip_missing[][RTE_FIB6_IPV6_ADDR_SIZE], uint64_t def_nh,
2414418919fSjohnjiang uint32_t n)
2424418919fSjohnjiang {
2434418919fSjohnjiang uint64_t nh_arr[RTE_FIB6_MAXDEPTH];
2444418919fSjohnjiang int ret;
2454418919fSjohnjiang uint32_t i = 0;
2464418919fSjohnjiang
2474418919fSjohnjiang ret = rte_fib6_lookup_bulk(fib, ip_arr, nh_arr, RTE_FIB6_MAXDEPTH);
2484418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to lookup\n");
2494418919fSjohnjiang
2504418919fSjohnjiang for (; i < n; i++)
2514418919fSjohnjiang RTE_TEST_ASSERT(nh_arr[i] == RTE_FIB6_MAXDEPTH - i,
2524418919fSjohnjiang "Failed to get proper nexthop\n");
2534418919fSjohnjiang
2544418919fSjohnjiang for (; i < RTE_FIB6_MAXDEPTH; i++)
2554418919fSjohnjiang RTE_TEST_ASSERT(nh_arr[i] == def_nh,
2564418919fSjohnjiang "Failed to get proper nexthop\n");
2574418919fSjohnjiang
2584418919fSjohnjiang ret = rte_fib6_lookup_bulk(fib, ip_missing, nh_arr, 1);
2594418919fSjohnjiang RTE_TEST_ASSERT((ret == 0) && (nh_arr[0] == def_nh),
2604418919fSjohnjiang "Failed to get proper nexthop\n");
2614418919fSjohnjiang
2624418919fSjohnjiang return TEST_SUCCESS;
2634418919fSjohnjiang }
2644418919fSjohnjiang
2654418919fSjohnjiang static int
check_fib(struct rte_fib6 * fib)2664418919fSjohnjiang check_fib(struct rte_fib6 *fib)
2674418919fSjohnjiang {
2684418919fSjohnjiang uint64_t def_nh = 100;
2694418919fSjohnjiang uint8_t ip_arr[RTE_FIB6_MAXDEPTH][RTE_FIB6_IPV6_ADDR_SIZE];
2704418919fSjohnjiang uint8_t ip_add[RTE_FIB6_IPV6_ADDR_SIZE] = {0};
2714418919fSjohnjiang uint8_t ip_missing[1][RTE_FIB6_IPV6_ADDR_SIZE] = { {255} };
2724418919fSjohnjiang uint32_t i, j;
2734418919fSjohnjiang int ret;
2744418919fSjohnjiang
2754418919fSjohnjiang ip_add[0] = 128;
2764418919fSjohnjiang ip_missing[0][0] = 127;
2774418919fSjohnjiang for (i = 0; i < RTE_FIB6_MAXDEPTH; i++) {
2784418919fSjohnjiang for (j = 0; j < RTE_FIB6_IPV6_ADDR_SIZE; j++) {
2794418919fSjohnjiang ip_arr[i][j] = ip_add[j] |
2804418919fSjohnjiang ~get_msk_part(RTE_FIB6_MAXDEPTH - i, j);
2814418919fSjohnjiang }
2824418919fSjohnjiang }
2834418919fSjohnjiang
2844418919fSjohnjiang ret = lookup_and_check_desc(fib, ip_arr, ip_missing, def_nh, 0);
2854418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS, "Lookup and check fails\n");
2864418919fSjohnjiang
2874418919fSjohnjiang for (i = 1; i <= RTE_FIB6_MAXDEPTH; i++) {
2884418919fSjohnjiang ret = rte_fib6_add(fib, ip_add, i, i);
2894418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to add a route\n");
2904418919fSjohnjiang ret = lookup_and_check_asc(fib, ip_arr, ip_missing, def_nh, i);
2914418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
2924418919fSjohnjiang "Lookup and check fails\n");
2934418919fSjohnjiang }
2944418919fSjohnjiang
2954418919fSjohnjiang for (i = RTE_FIB6_MAXDEPTH; i > 1; i--) {
2964418919fSjohnjiang ret = rte_fib6_delete(fib, ip_add, i);
2974418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to delete a route\n");
2984418919fSjohnjiang ret = lookup_and_check_asc(fib, ip_arr, ip_missing,
2994418919fSjohnjiang def_nh, i - 1);
3004418919fSjohnjiang
3014418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3024418919fSjohnjiang "Lookup and check fails\n");
3034418919fSjohnjiang }
3044418919fSjohnjiang ret = rte_fib6_delete(fib, ip_add, i);
3054418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to delete a route\n");
3064418919fSjohnjiang ret = lookup_and_check_desc(fib, ip_arr, ip_missing, def_nh, 0);
3074418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3084418919fSjohnjiang "Lookup and check fails\n");
3094418919fSjohnjiang
3104418919fSjohnjiang for (i = 0; i < RTE_FIB6_MAXDEPTH; i++) {
3114418919fSjohnjiang ret = rte_fib6_add(fib, ip_add, RTE_FIB6_MAXDEPTH - i,
3124418919fSjohnjiang RTE_FIB6_MAXDEPTH - i);
3134418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to add a route\n");
3144418919fSjohnjiang ret = lookup_and_check_desc(fib, ip_arr, ip_missing,
3154418919fSjohnjiang def_nh, i + 1);
3164418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3174418919fSjohnjiang "Lookup and check fails\n");
3184418919fSjohnjiang }
3194418919fSjohnjiang
3204418919fSjohnjiang for (i = 1; i <= RTE_FIB6_MAXDEPTH; i++) {
3214418919fSjohnjiang ret = rte_fib6_delete(fib, ip_add, i);
3224418919fSjohnjiang RTE_TEST_ASSERT(ret == 0, "Failed to delete a route\n");
3234418919fSjohnjiang ret = lookup_and_check_desc(fib, ip_arr, ip_missing, def_nh,
3244418919fSjohnjiang RTE_FIB6_MAXDEPTH - i);
3254418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3264418919fSjohnjiang "Lookup and check fails\n");
3274418919fSjohnjiang }
3284418919fSjohnjiang
3294418919fSjohnjiang return TEST_SUCCESS;
3304418919fSjohnjiang }
3314418919fSjohnjiang
3324418919fSjohnjiang int32_t
test_lookup(void)3334418919fSjohnjiang test_lookup(void)
3344418919fSjohnjiang {
3354418919fSjohnjiang struct rte_fib6 *fib = NULL;
3364418919fSjohnjiang struct rte_fib6_conf config;
3374418919fSjohnjiang uint64_t def_nh = 100;
3384418919fSjohnjiang int ret;
3394418919fSjohnjiang
3404418919fSjohnjiang config.max_routes = MAX_ROUTES;
3414418919fSjohnjiang config.default_nh = def_nh;
3424418919fSjohnjiang config.type = RTE_FIB6_DUMMY;
3434418919fSjohnjiang
3444418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
3454418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
3464418919fSjohnjiang ret = check_fib(fib);
3474418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3484418919fSjohnjiang "Check_fib fails for DUMMY type\n");
3494418919fSjohnjiang rte_fib6_free(fib);
3504418919fSjohnjiang
3514418919fSjohnjiang config.type = RTE_FIB6_TRIE;
3524418919fSjohnjiang
3534418919fSjohnjiang config.trie.nh_sz = RTE_FIB6_TRIE_2B;
3544418919fSjohnjiang config.trie.num_tbl8 = MAX_TBL8 - 1;
3554418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
3564418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
3574418919fSjohnjiang ret = check_fib(fib);
3584418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3594418919fSjohnjiang "Check_fib fails for TRIE_2B type\n");
3604418919fSjohnjiang rte_fib6_free(fib);
3614418919fSjohnjiang
3624418919fSjohnjiang config.trie.nh_sz = RTE_FIB6_TRIE_4B;
3634418919fSjohnjiang config.trie.num_tbl8 = MAX_TBL8;
3644418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
3654418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
3664418919fSjohnjiang ret = check_fib(fib);
3674418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3684418919fSjohnjiang "Check_fib fails for TRIE_4B type\n");
3694418919fSjohnjiang rte_fib6_free(fib);
3704418919fSjohnjiang
3714418919fSjohnjiang config.trie.nh_sz = RTE_FIB6_TRIE_8B;
3724418919fSjohnjiang config.trie.num_tbl8 = MAX_TBL8;
3734418919fSjohnjiang fib = rte_fib6_create(__func__, SOCKET_ID_ANY, &config);
3744418919fSjohnjiang RTE_TEST_ASSERT(fib != NULL, "Failed to create FIB\n");
3754418919fSjohnjiang ret = check_fib(fib);
3764418919fSjohnjiang RTE_TEST_ASSERT(ret == TEST_SUCCESS,
3774418919fSjohnjiang "Check_fib fails for TRIE_8B type\n");
3784418919fSjohnjiang rte_fib6_free(fib);
3794418919fSjohnjiang
3804418919fSjohnjiang return TEST_SUCCESS;
3814418919fSjohnjiang }
3824418919fSjohnjiang
3834418919fSjohnjiang static struct unit_test_suite fib6_fast_tests = {
3844418919fSjohnjiang .suite_name = "fib6 autotest",
3854418919fSjohnjiang .setup = NULL,
3864418919fSjohnjiang .teardown = NULL,
3874418919fSjohnjiang .unit_test_cases = {
3884418919fSjohnjiang TEST_CASE(test_create_invalid),
3894418919fSjohnjiang TEST_CASE(test_free_null),
3904418919fSjohnjiang TEST_CASE(test_add_del_invalid),
3914418919fSjohnjiang TEST_CASE(test_get_invalid),
3924418919fSjohnjiang TEST_CASE(test_lookup),
3934418919fSjohnjiang TEST_CASES_END()
3944418919fSjohnjiang }
3954418919fSjohnjiang };
3964418919fSjohnjiang
3974418919fSjohnjiang static struct unit_test_suite fib6_slow_tests = {
3984418919fSjohnjiang .suite_name = "fib6 slow autotest",
3994418919fSjohnjiang .setup = NULL,
4004418919fSjohnjiang .teardown = NULL,
4014418919fSjohnjiang .unit_test_cases = {
4024418919fSjohnjiang TEST_CASE(test_multiple_create),
4034418919fSjohnjiang TEST_CASES_END()
4044418919fSjohnjiang }
4054418919fSjohnjiang };
4064418919fSjohnjiang
4074418919fSjohnjiang /*
4084418919fSjohnjiang * Do all unit tests.
4094418919fSjohnjiang */
4104418919fSjohnjiang static int
test_fib6(void)4114418919fSjohnjiang test_fib6(void)
4124418919fSjohnjiang {
4134418919fSjohnjiang return unit_test_suite_runner(&fib6_fast_tests);
4144418919fSjohnjiang }
4154418919fSjohnjiang
4164418919fSjohnjiang static int
test_slow_fib6(void)4174418919fSjohnjiang test_slow_fib6(void)
4184418919fSjohnjiang {
4194418919fSjohnjiang return unit_test_suite_runner(&fib6_slow_tests);
4204418919fSjohnjiang }
4214418919fSjohnjiang
4224418919fSjohnjiang REGISTER_TEST_COMMAND(fib6_autotest, test_fib6);
4234418919fSjohnjiang REGISTER_TEST_COMMAND(fib6_slow_autotest, test_slow_fib6);
424