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