xref: /f-stack/dpdk/app/test/test_pdump.c (revision 2d9fd380)
14418919fSjohnjiang /* SPDX-License-Identifier: BSD-3-Clause
24418919fSjohnjiang  * Copyright(c) 2018 Intel Corporation
34418919fSjohnjiang  */
44418919fSjohnjiang #include <stdio.h>
54418919fSjohnjiang #include <unistd.h>
64418919fSjohnjiang #include <stdint.h>
74418919fSjohnjiang #include <limits.h>
84418919fSjohnjiang 
94418919fSjohnjiang #include <rte_ethdev_driver.h>
104418919fSjohnjiang #include <rte_pdump.h>
114418919fSjohnjiang #include "rte_eal.h"
124418919fSjohnjiang #include "rte_lcore.h"
134418919fSjohnjiang #include "rte_mempool.h"
144418919fSjohnjiang #include "rte_ring.h"
154418919fSjohnjiang 
164418919fSjohnjiang #include "sample_packet_forward.h"
174418919fSjohnjiang #include "test.h"
184418919fSjohnjiang #include "process.h"
194418919fSjohnjiang #include "test_pdump.h"
204418919fSjohnjiang 
21*2d9fd380Sjfb8856606 #define launch_p(ARGV) process_dup(ARGV, RTE_DIM(ARGV), __func__)
224418919fSjohnjiang 
234418919fSjohnjiang struct rte_ring *ring_server;
244418919fSjohnjiang uint16_t portid;
254418919fSjohnjiang uint16_t flag_for_send_pkts = 1;
264418919fSjohnjiang 
274418919fSjohnjiang int
test_pdump_init(void)284418919fSjohnjiang test_pdump_init(void)
294418919fSjohnjiang {
304418919fSjohnjiang 	int ret = 0;
314418919fSjohnjiang 
324418919fSjohnjiang 	ret = rte_pdump_init();
334418919fSjohnjiang 	if (ret < 0) {
344418919fSjohnjiang 		printf("rte_pdump_init failed\n");
354418919fSjohnjiang 		return -1;
364418919fSjohnjiang 	}
374418919fSjohnjiang 	ret = test_ring_setup(&ring_server, &portid);
384418919fSjohnjiang 	if (ret < 0) {
394418919fSjohnjiang 		printf("test_ring_setup failed\n");
404418919fSjohnjiang 		return -1;
414418919fSjohnjiang 	}
424418919fSjohnjiang 	printf("pdump_init success\n");
434418919fSjohnjiang 	return ret;
444418919fSjohnjiang }
454418919fSjohnjiang 
464418919fSjohnjiang int
run_pdump_client_tests(void)474418919fSjohnjiang run_pdump_client_tests(void)
484418919fSjohnjiang {
494418919fSjohnjiang 	int flags = RTE_PDUMP_FLAG_TX, ret = 0, itr;
504418919fSjohnjiang 	char deviceid[] = "net_ring_net_ringa";
514418919fSjohnjiang 	struct rte_ring *ring_client;
524418919fSjohnjiang 	struct rte_mempool *mp = NULL;
534418919fSjohnjiang 	struct rte_eth_dev *eth_dev = NULL;
544418919fSjohnjiang 	char poolname[] = "mbuf_pool_client";
554418919fSjohnjiang 
564418919fSjohnjiang 	ret = test_get_mempool(&mp, poolname);
574418919fSjohnjiang 	if (ret < 0)
584418919fSjohnjiang 		return -1;
594418919fSjohnjiang 	mp->flags = 0x0000;
60*2d9fd380Sjfb8856606 	ring_client = rte_ring_create("SR0", RING_SIZE, rte_socket_id(), 0);
614418919fSjohnjiang 	if (ring_client == NULL) {
624418919fSjohnjiang 		printf("rte_ring_create SR0 failed");
634418919fSjohnjiang 		return -1;
644418919fSjohnjiang 	}
654418919fSjohnjiang 
664418919fSjohnjiang 	eth_dev = rte_eth_dev_attach_secondary(deviceid);
674418919fSjohnjiang 	if (!eth_dev) {
684418919fSjohnjiang 		printf("Failed to probe %s", deviceid);
694418919fSjohnjiang 		return -1;
704418919fSjohnjiang 	}
714418919fSjohnjiang 	rte_eth_dev_probing_finish(eth_dev);
724418919fSjohnjiang 
734418919fSjohnjiang 	printf("\n***** flags = RTE_PDUMP_FLAG_TX *****\n");
744418919fSjohnjiang 
754418919fSjohnjiang 	for (itr = 0; itr < NUM_ITR; itr++) {
764418919fSjohnjiang 		ret = rte_pdump_enable(portid, QUEUE_ID, flags, ring_client,
774418919fSjohnjiang 				       mp, NULL);
784418919fSjohnjiang 		if (ret < 0) {
794418919fSjohnjiang 			printf("rte_pdump_enable failed\n");
804418919fSjohnjiang 			return -1;
814418919fSjohnjiang 		}
824418919fSjohnjiang 		printf("pdump_enable success\n");
834418919fSjohnjiang 
844418919fSjohnjiang 		ret = rte_pdump_disable(portid, QUEUE_ID, flags);
854418919fSjohnjiang 		if (ret < 0) {
864418919fSjohnjiang 			printf("rte_pdump_disable failed\n");
874418919fSjohnjiang 			return -1;
884418919fSjohnjiang 		}
894418919fSjohnjiang 		printf("pdump_disable success\n");
904418919fSjohnjiang 
914418919fSjohnjiang 		ret = rte_pdump_enable_by_deviceid(deviceid, QUEUE_ID, flags,
924418919fSjohnjiang 						   ring_client, mp, NULL);
934418919fSjohnjiang 		if (ret < 0) {
944418919fSjohnjiang 			printf("rte_pdump_enable_by_deviceid failed\n");
954418919fSjohnjiang 			return -1;
964418919fSjohnjiang 		}
974418919fSjohnjiang 		printf("pdump_enable_by_deviceid success\n");
984418919fSjohnjiang 
994418919fSjohnjiang 		ret = rte_pdump_disable_by_deviceid(deviceid, QUEUE_ID, flags);
1004418919fSjohnjiang 		if (ret < 0) {
1014418919fSjohnjiang 			printf("rte_pdump_disable_by_deviceid failed\n");
1024418919fSjohnjiang 			return -1;
1034418919fSjohnjiang 		}
1044418919fSjohnjiang 		printf("pdump_disable_by_deviceid success\n");
1054418919fSjohnjiang 
1064418919fSjohnjiang 		if (itr == 0) {
1074418919fSjohnjiang 			flags = RTE_PDUMP_FLAG_RX;
1084418919fSjohnjiang 			printf("\n***** flags = RTE_PDUMP_FLAG_RX *****\n");
1094418919fSjohnjiang 		} else if (itr == 1) {
1104418919fSjohnjiang 			flags = RTE_PDUMP_FLAG_RXTX;
1114418919fSjohnjiang 			printf("\n***** flags = RTE_PDUMP_FLAG_RXTX *****\n");
1124418919fSjohnjiang 		}
1134418919fSjohnjiang 	}
1144418919fSjohnjiang 	if (ring_client != NULL)
1154418919fSjohnjiang 		test_ring_free(ring_client);
1164418919fSjohnjiang 	if (mp != NULL)
1174418919fSjohnjiang 		test_mp_free(mp);
1184418919fSjohnjiang 
1194418919fSjohnjiang 	return ret;
1204418919fSjohnjiang }
1214418919fSjohnjiang 
1224418919fSjohnjiang int
test_pdump_uninit(void)1234418919fSjohnjiang test_pdump_uninit(void)
1244418919fSjohnjiang {
1254418919fSjohnjiang 	int ret = 0;
1264418919fSjohnjiang 
1274418919fSjohnjiang 	ret = rte_pdump_uninit();
1284418919fSjohnjiang 	if (ret < 0) {
1294418919fSjohnjiang 		printf("rte_pdump_uninit failed\n");
1304418919fSjohnjiang 		return -1;
1314418919fSjohnjiang 	}
1324418919fSjohnjiang 	if (ring_server != NULL)
1334418919fSjohnjiang 		test_ring_free(ring_server);
1344418919fSjohnjiang 	printf("pdump_uninit success\n");
1354418919fSjohnjiang 	test_vdev_uninit("net_ring_net_ringa");
1364418919fSjohnjiang 	return ret;
1374418919fSjohnjiang }
1384418919fSjohnjiang 
1394418919fSjohnjiang void *
send_pkts(void * empty)1404418919fSjohnjiang send_pkts(void *empty)
1414418919fSjohnjiang {
1424418919fSjohnjiang 	int ret = 0;
1434418919fSjohnjiang 	struct rte_mbuf *pbuf[NUM_PACKETS] = { };
1444418919fSjohnjiang 	struct rte_mempool *mp;
1454418919fSjohnjiang 	char poolname[] = "mbuf_pool_server";
1464418919fSjohnjiang 
1474418919fSjohnjiang 	ret = test_get_mbuf_from_pool(&mp, pbuf, poolname);
1484418919fSjohnjiang 	if (ret < 0)
1494418919fSjohnjiang 		printf("get_mbuf_from_pool failed\n");
1504418919fSjohnjiang 	do {
1514418919fSjohnjiang 		ret = test_packet_forward(pbuf, portid, QUEUE_ID);
1524418919fSjohnjiang 		if (ret < 0)
1534418919fSjohnjiang 			printf("send pkts Failed\n");
1544418919fSjohnjiang 	} while (flag_for_send_pkts);
1554418919fSjohnjiang 	test_put_mbuf_to_pool(mp, pbuf);
1564418919fSjohnjiang 	return empty;
1574418919fSjohnjiang }
1584418919fSjohnjiang 
1594418919fSjohnjiang /*
1604418919fSjohnjiang  * This function is called in the primary i.e. main test, to spawn off secondary
1614418919fSjohnjiang  * processes to run actual mp tests. Uses fork() and exec pair
1624418919fSjohnjiang  */
1634418919fSjohnjiang 
1644418919fSjohnjiang int
run_pdump_server_tests(void)1654418919fSjohnjiang run_pdump_server_tests(void)
1664418919fSjohnjiang {
1674418919fSjohnjiang 	int ret = 0;
1684418919fSjohnjiang 	char coremask[10];
1694418919fSjohnjiang 
1704418919fSjohnjiang #ifdef RTE_EXEC_ENV_LINUX
1714418919fSjohnjiang 	char tmp[PATH_MAX] = { 0 };
1724418919fSjohnjiang 	char prefix[PATH_MAX] = { 0 };
1734418919fSjohnjiang 
1744418919fSjohnjiang 	get_current_prefix(tmp, sizeof(tmp));
1754418919fSjohnjiang 	snprintf(prefix, sizeof(prefix), "--file-prefix=%s", tmp);
1764418919fSjohnjiang #else
1774418919fSjohnjiang 	const char *prefix = "";
1784418919fSjohnjiang #endif
1794418919fSjohnjiang 
1804418919fSjohnjiang 	/* good case, using secondary */
1814418919fSjohnjiang 	const char *const argv1[] = {
1824418919fSjohnjiang 		prgname, "-c", coremask, "--proc-type=secondary",
1834418919fSjohnjiang 		prefix
1844418919fSjohnjiang 	};
1854418919fSjohnjiang 
1864418919fSjohnjiang 	snprintf(coremask, sizeof(coremask), "%x",
187*2d9fd380Sjfb8856606 		 (1 << rte_get_main_lcore()));
1884418919fSjohnjiang 
1894418919fSjohnjiang 	ret = test_pdump_init();
1904418919fSjohnjiang 	ret |= launch_p(argv1);
1914418919fSjohnjiang 	ret |= test_pdump_uninit();
1924418919fSjohnjiang 	return ret;
1934418919fSjohnjiang }
1944418919fSjohnjiang 
1954418919fSjohnjiang int
test_pdump(void)1964418919fSjohnjiang test_pdump(void)
1974418919fSjohnjiang {
1984418919fSjohnjiang 	int ret = 0;
1994418919fSjohnjiang 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
2004418919fSjohnjiang 		printf("IN PRIMARY PROCESS\n");
2014418919fSjohnjiang 		ret = run_pdump_server_tests();
2024418919fSjohnjiang 		if (ret < 0)
2034418919fSjohnjiang 			return TEST_FAILED;
2044418919fSjohnjiang 	} else if (rte_eal_process_type() == RTE_PROC_SECONDARY) {
2054418919fSjohnjiang 		printf("IN SECONDARY PROCESS\n");
2064418919fSjohnjiang 		sleep(5);
2074418919fSjohnjiang 		ret = run_pdump_client_tests();
2084418919fSjohnjiang 		if (ret < 0)
2094418919fSjohnjiang 			return TEST_FAILED;
2104418919fSjohnjiang 	}
2114418919fSjohnjiang 	return TEST_SUCCESS;
2124418919fSjohnjiang }
2134418919fSjohnjiang 
2144418919fSjohnjiang REGISTER_TEST_COMMAND(pdump_autotest, test_pdump);
215