xref: /f-stack/dpdk/app/test/test_fib6.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_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