xref: /f-stack/dpdk/app/test/test_fib.c (revision 2d9fd380)
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