Branch data Line data Source code
1 : : /* SPDX-License-Identifier: BSD-3-Clause
2 : : * Copyright(c) 2010-2017 Intel Corporation
3 : : */
4 : :
5 : : #include <errno.h>
6 : : #include <getopt.h>
7 : : #include <stdarg.h>
8 : : #include <stdio.h>
9 : : #include <stdlib.h>
10 : : #include <signal.h>
11 : : #include <string.h>
12 : : #include <time.h>
13 : : #include <fcntl.h>
14 : : #include <sys/types.h>
15 : :
16 : : #include <sys/queue.h>
17 : : #include <sys/stat.h>
18 : :
19 : : #include <stdint.h>
20 : : #include <unistd.h>
21 : : #include <inttypes.h>
22 : :
23 : : #include <rte_common.h>
24 : : #include <rte_byteorder.h>
25 : : #include <rte_log.h>
26 : : #include <rte_debug.h>
27 : : #include <rte_cycles.h>
28 : : #include <rte_memory.h>
29 : : #include <rte_launch.h>
30 : : #include <rte_eal.h>
31 : : #include <rte_per_lcore.h>
32 : : #include <rte_lcore.h>
33 : : #include <rte_branch_prediction.h>
34 : : #include <rte_mempool.h>
35 : : #include <rte_interrupts.h>
36 : : #include <rte_ether.h>
37 : : #include <rte_ethdev.h>
38 : : #include <rte_string_fns.h>
39 : : #include <rte_flow.h>
40 : :
41 : : #include "testpmd.h"
42 : :
43 : : enum {
44 : : #define TESTPMD_OPT_AUTO_START "auto-start"
45 : : TESTPMD_OPT_AUTO_START_NUM = 'a',
46 : : #define TESTPMD_OPT_HELP "help"
47 : : TESTPMD_OPT_HELP_NUM = 'h',
48 : : #define TESTPMD_OPT_INTERACTIVE "interactive"
49 : : TESTPMD_OPT_INTERACTIVE_NUM = 'i',
50 : :
51 : : TESTPMD_OPT_LONG_MIN_NUM = 256,
52 : : #define TESTPMD_OPT_CMDLINE_FILE "cmdline-file"
53 : : TESTPMD_OPT_CMDLINE_FILE_NUM,
54 : : #define TESTPMD_OPT_CMDLINE_FILE_NOECHO "cmdline-file-noecho"
55 : : TESTPMD_OPT_CMDLINE_FILE_NOECHO_NUM,
56 : : #define TESTPMD_OPT_ETH_PEERS_CONFIGFILE "eth-peers-configfile"
57 : : TESTPMD_OPT_ETH_PEERS_CONFIGFILE_NUM,
58 : : #define TESTPMD_OPT_ETH_PEER "eth-peer"
59 : : TESTPMD_OPT_ETH_PEER_NUM,
60 : : #define TESTPMD_OPT_TX_FIRST "tx-first"
61 : : TESTPMD_OPT_TX_FIRST_NUM,
62 : : #define TESTPMD_OPT_STATS_PERIOD "stats-period"
63 : : TESTPMD_OPT_STATS_PERIOD_NUM,
64 : : #define TESTPMD_OPT_DISPLAY_XSTATS "display-xstats"
65 : : TESTPMD_OPT_DISPLAY_XSTATS_NUM,
66 : : #define TESTPMD_OPT_NB_CORES "nb-cores"
67 : : TESTPMD_OPT_NB_CORES_NUM,
68 : : #define TESTPMD_OPT_NB_PORTS "nb-ports"
69 : : TESTPMD_OPT_NB_PORTS_NUM,
70 : : #define TESTPMD_OPT_COREMASK "coremask"
71 : : TESTPMD_OPT_COREMASK_NUM,
72 : : #define TESTPMD_OPT_PORTMASK "portmask"
73 : : TESTPMD_OPT_PORTMASK_NUM,
74 : : #define TESTPMD_OPT_PORTLIST "portlist"
75 : : TESTPMD_OPT_PORTLIST_NUM,
76 : : #define TESTPMD_OPT_NUMA "numa"
77 : : TESTPMD_OPT_NUMA_NUM,
78 : : #define TESTPMD_OPT_NO_NUMA "no-numa"
79 : : TESTPMD_OPT_NO_NUMA_NUM,
80 : : #define TESTPMD_OPT_MP_ANON "mp-anon"
81 : : TESTPMD_OPT_MP_ANON_NUM,
82 : : #define TESTPMD_OPT_PORT_NUMA_CONFIG "port-numa-config"
83 : : TESTPMD_OPT_PORT_NUMA_CONFIG_NUM,
84 : : #define TESTPMD_OPT_RING_NUMA_CONFIG "ring-numa-config"
85 : : TESTPMD_OPT_RING_NUMA_CONFIG_NUM,
86 : : #define TESTPMD_OPT_SOCKET_NUM "socket-num"
87 : : TESTPMD_OPT_SOCKET_NUM_NUM,
88 : : #define TESTPMD_OPT_MBUF_SIZE "mbuf-size"
89 : : TESTPMD_OPT_MBUF_SIZE_NUM,
90 : : #define TESTPMD_OPT_TOTAL_NUM_MBUFS "total-num-mbufs"
91 : : TESTPMD_OPT_TOTAL_NUM_MBUFS_NUM,
92 : : #define TESTPMD_OPT_MAX_PKT_LEN "max-pkt-len"
93 : : TESTPMD_OPT_MAX_PKT_LEN_NUM,
94 : : #define TESTPMD_OPT_MAX_LRO_PKT_SIZE "max-lro-pkt-size"
95 : : TESTPMD_OPT_MAX_LRO_PKT_SIZE_NUM,
96 : : #define TESTPMD_OPT_LATENCYSTATS "latencystats"
97 : : TESTPMD_OPT_LATENCYSTATS_NUM,
98 : : #define TESTPMD_OPT_BITRATE_STATS "bitrate-stats"
99 : : TESTPMD_OPT_BITRATE_STATS_NUM,
100 : : #define TESTPMD_OPT_DISABLE_CRC_STRIP "disable-crc-strip"
101 : : TESTPMD_OPT_DISABLE_CRC_STRIP_NUM,
102 : : #define TESTPMD_OPT_ENABLE_LRO "enable-lro"
103 : : TESTPMD_OPT_ENABLE_LRO_NUM,
104 : : #define TESTPMD_OPT_ENABLE_RX_CKSUM "enable-rx-cksum"
105 : : TESTPMD_OPT_ENABLE_RX_CKSUM_NUM,
106 : : #define TESTPMD_OPT_ENABLE_RX_TIMESTAMP "enable-rx-timestamp"
107 : : TESTPMD_OPT_ENABLE_RX_TIMESTAMP_NUM,
108 : : #define TESTPMD_OPT_ENABLE_SCATTER "enable-scatter"
109 : : TESTPMD_OPT_ENABLE_SCATTER_NUM,
110 : : #define TESTPMD_OPT_ENABLE_HW_VLAN "enable-hw-vlan"
111 : : TESTPMD_OPT_ENABLE_HW_VLAN_NUM,
112 : : #define TESTPMD_OPT_ENABLE_HW_VLAN_FILTER "enable-hw-vlan-filter"
113 : : TESTPMD_OPT_ENABLE_HW_VLAN_FILTER_NUM,
114 : : #define TESTPMD_OPT_ENABLE_HW_VLAN_STRIP "enable-hw-vlan-strip"
115 : : TESTPMD_OPT_ENABLE_HW_VLAN_STRIP_NUM,
116 : : #define TESTPMD_OPT_ENABLE_HW_VLAN_EXTEND "enable-hw-vlan-extend"
117 : : TESTPMD_OPT_ENABLE_HW_VLAN_EXTEND_NUM,
118 : : #define TESTPMD_OPT_ENABLE_HW_QINQ_STRIP "enable-hw-qinq-strip"
119 : : TESTPMD_OPT_ENABLE_HW_QINQ_STRIP_NUM,
120 : : #define TESTPMD_OPT_ENABLE_DROP_EN "enable-drop-en"
121 : : TESTPMD_OPT_ENABLE_DROP_EN_NUM,
122 : : #define TESTPMD_OPT_DISABLE_RSS "disable-rss"
123 : : TESTPMD_OPT_DISABLE_RSS_NUM,
124 : : #define TESTPMD_OPT_ENABLE_RSS "enable-rss"
125 : : TESTPMD_OPT_ENABLE_RSS_NUM,
126 : : #define TESTPMD_OPT_PORT_TOPOLOGY "port-topology"
127 : : TESTPMD_OPT_PORT_TOPOLOGY_NUM,
128 : : #define TESTPMD_OPT_FORWARD_MODE "forward-mode"
129 : : TESTPMD_OPT_FORWARD_MODE_NUM,
130 : : #define TESTPMD_OPT_RSS_IP "rss-ip"
131 : : TESTPMD_OPT_RSS_IP_NUM,
132 : : #define TESTPMD_OPT_RSS_UDP "rss-udp"
133 : : TESTPMD_OPT_RSS_UDP_NUM,
134 : : #define TESTPMD_OPT_RSS_LEVEL_OUTER "rss-level-outer"
135 : : TESTPMD_OPT_RSS_LEVEL_OUTER_NUM,
136 : : #define TESTPMD_OPT_RSS_LEVEL_INNER "rss-level-inner"
137 : : TESTPMD_OPT_RSS_LEVEL_INNER_NUM,
138 : : #define TESTPMD_OPT_RXQ "rxq"
139 : : TESTPMD_OPT_RXQ_NUM,
140 : : #define TESTPMD_OPT_TXQ "txq"
141 : : TESTPMD_OPT_TXQ_NUM,
142 : : #define TESTPMD_OPT_RXD "rxd"
143 : : TESTPMD_OPT_RXD_NUM,
144 : : #define TESTPMD_OPT_TXD "txd"
145 : : TESTPMD_OPT_TXD_NUM,
146 : : #define TESTPMD_OPT_HAIRPINQ "hairpinq"
147 : : TESTPMD_OPT_HAIRPINQ_NUM,
148 : : #define TESTPMD_OPT_HAIRPIN_MODE "hairpin-mode"
149 : : TESTPMD_OPT_HAIRPIN_MODE_NUM,
150 : : #define TESTPMD_OPT_HAIRPIN_MAP "hairpin-map"
151 : : TESTPMD_OPT_HAIRPIN_MAP_NUM,
152 : : #define TESTPMD_OPT_BURST "burst"
153 : : TESTPMD_OPT_BURST_NUM,
154 : : #define TESTPMD_OPT_FLOWGEN_CLONES "flowgen-clones"
155 : : TESTPMD_OPT_FLOWGEN_CLONES_NUM,
156 : : #define TESTPMD_OPT_FLOWGEN_FLOWS "flowgen-flows"
157 : : TESTPMD_OPT_FLOWGEN_FLOWS_NUM,
158 : : #define TESTPMD_OPT_MBCACHE "mbcache"
159 : : TESTPMD_OPT_MBCACHE_NUM,
160 : : #define TESTPMD_OPT_TXPT "txpt"
161 : : TESTPMD_OPT_TXPT_NUM,
162 : : #define TESTPMD_OPT_TXHT "txht"
163 : : TESTPMD_OPT_TXHT_NUM,
164 : : #define TESTPMD_OPT_TXWT "txwt"
165 : : TESTPMD_OPT_TXWT_NUM,
166 : : #define TESTPMD_OPT_TXFREET "txfreet"
167 : : TESTPMD_OPT_TXFREET_NUM,
168 : : #define TESTPMD_OPT_TXRST "txrst"
169 : : TESTPMD_OPT_TXRST_NUM,
170 : : #define TESTPMD_OPT_RXPT "rxpt"
171 : : TESTPMD_OPT_RXPT_NUM,
172 : : #define TESTPMD_OPT_RXHT "rxht"
173 : : TESTPMD_OPT_RXHT_NUM,
174 : : #define TESTPMD_OPT_RXWT "rxwt"
175 : : TESTPMD_OPT_RXWT_NUM,
176 : : #define TESTPMD_OPT_RXFREET "rxfreet"
177 : : TESTPMD_OPT_RXFREET_NUM,
178 : : #define TESTPMD_OPT_NO_FLUSH_RX "no-flush-rx"
179 : : TESTPMD_OPT_NO_FLUSH_RX_NUM,
180 : : #define TESTPMD_OPT_FLOW_ISOLATE_ALL "flow-isolate-all"
181 : : TESTPMD_OPT_FLOW_ISOLATE_ALL_NUM,
182 : : #define TESTPMD_OPT_DISABLE_FLOW_FLUSH "disable-flow-flush"
183 : : TESTPMD_OPT_DISABLE_FLOW_FLUSH_NUM,
184 : : #define TESTPMD_OPT_RXOFFS "rxoffs"
185 : : TESTPMD_OPT_RXOFFS_NUM,
186 : : #define TESTPMD_OPT_RXPKTS "rxpkts"
187 : : TESTPMD_OPT_RXPKTS_NUM,
188 : : #define TESTPMD_OPT_RXHDRS "rxhdrs"
189 : : TESTPMD_OPT_RXHDRS_NUM,
190 : : #define TESTPMD_OPT_TXPKTS "txpkts"
191 : : TESTPMD_OPT_TXPKTS_NUM,
192 : : #define TESTPMD_OPT_MULTI_RX_MEMPOOL "multi-rx-mempool"
193 : : TESTPMD_OPT_MULTI_RX_MEMPOOL_NUM,
194 : : #define TESTPMD_OPT_TXONLY_MULTI_FLOW "txonly-multi-flow"
195 : : TESTPMD_OPT_TXONLY_MULTI_FLOW_NUM,
196 : : #define TESTPMD_OPT_TXONLY_FLOWS "txonly-flows"
197 : : TESTPMD_OPT_TXONLY_FLOWS_NUM,
198 : : #define TESTPMD_OPT_RXQ_SHARE "rxq-share"
199 : : TESTPMD_OPT_RXQ_SHARE_NUM,
200 : : #define TESTPMD_OPT_ETH_LINK_SPEED "eth-link-speed"
201 : : TESTPMD_OPT_ETH_LINK_SPEED_NUM,
202 : : #define TESTPMD_OPT_DISABLE_LINK_CHECK "disable-link-check"
203 : : TESTPMD_OPT_DISABLE_LINK_CHECK_NUM,
204 : : #define TESTPMD_OPT_DISABLE_DEVICE_START "disable-device-start"
205 : : TESTPMD_OPT_DISABLE_DEVICE_START_NUM,
206 : : #define TESTPMD_OPT_NO_LSC_INTERRUPT "no-lsc-interrupt"
207 : : TESTPMD_OPT_NO_LSC_INTERRUPT_NUM,
208 : : #define TESTPMD_OPT_NO_RMV_INTERRUPT "no-rmv-interrupt"
209 : : TESTPMD_OPT_NO_RMV_INTERRUPT_NUM,
210 : : #define TESTPMD_OPT_PRINT_EVENT "print-event"
211 : : TESTPMD_OPT_PRINT_EVENT_NUM,
212 : : #define TESTPMD_OPT_MASK_EVENT "mask-event"
213 : : TESTPMD_OPT_MASK_EVENT_NUM,
214 : : #define TESTPMD_OPT_TX_OFFLOADS "tx-offloads"
215 : : TESTPMD_OPT_TX_OFFLOADS_NUM,
216 : : #define TESTPMD_OPT_RX_OFFLOADS "rx-offloads"
217 : : TESTPMD_OPT_RX_OFFLOADS_NUM,
218 : : #define TESTPMD_OPT_HOT_PLUG "hot-plug"
219 : : TESTPMD_OPT_HOT_PLUG_NUM,
220 : : #define TESTPMD_OPT_VXLAN_GPE_PORT "vxlan-gpe-port"
221 : : TESTPMD_OPT_VXLAN_GPE_PORT_NUM,
222 : : #define TESTPMD_OPT_GENEVE_PARSED_PORT "geneve-parsed-port"
223 : : TESTPMD_OPT_GENEVE_PARSED_PORT_NUM,
224 : : #define TESTPMD_OPT_MLOCKALL "mlockall"
225 : : TESTPMD_OPT_MLOCKALL_NUM,
226 : : #define TESTPMD_OPT_NO_MLOCKALL "no-mlockall"
227 : : TESTPMD_OPT_NO_MLOCKALL_NUM,
228 : : #define TESTPMD_OPT_MP_ALLOC "mp-alloc"
229 : : TESTPMD_OPT_MP_ALLOC_NUM,
230 : : #define TESTPMD_OPT_TX_IP "tx-ip"
231 : : TESTPMD_OPT_TX_IP_NUM,
232 : : #define TESTPMD_OPT_TX_UDP "tx-udp"
233 : : TESTPMD_OPT_TX_UDP_NUM,
234 : : #define TESTPMD_OPT_NOISY_TX_SW_BUFFER_SIZE "noisy-tx-sw-buffer-size"
235 : : TESTPMD_OPT_NOISY_TX_SW_BUFFER_SIZE_NUM,
236 : : #define TESTPMD_OPT_NOISY_TX_SW_BUFFER_FLUSHTIME "noisy-tx-sw-buffer-flushtime"
237 : : TESTPMD_OPT_NOISY_TX_SW_BUFFER_FLUSHTIME_NUM,
238 : : #define TESTPMD_OPT_NOISY_LKUP_MEMORY "noisy-lkup-memory"
239 : : TESTPMD_OPT_NOISY_LKUP_MEMORY_NUM,
240 : : #define TESTPMD_OPT_NOISY_LKUP_NUM_WRITES "noisy-lkup-num-writes"
241 : : TESTPMD_OPT_NOISY_LKUP_NUM_WRITES_NUM,
242 : : #define TESTPMD_OPT_NOISY_LKUP_NUM_READS "noisy-lkup-num-reads"
243 : : TESTPMD_OPT_NOISY_LKUP_NUM_READS_NUM,
244 : : #define TESTPMD_OPT_NOISY_LKUP_NUM_READS_WRITES "noisy-lkup-num-reads-writes"
245 : : TESTPMD_OPT_NOISY_LKUP_NUM_READS_WRITES_NUM,
246 : : #define TESTPMD_OPT_NOISY_FORWARD_MODE "noisy-forward-mode"
247 : : TESTPMD_OPT_NOISY_FORWARD_MODE_NUM,
248 : : #define TESTPMD_OPT_NO_IOVA_CONTIG "no-iova-contig"
249 : : TESTPMD_OPT_NO_IOVA_CONTIG_NUM,
250 : : #define TESTPMD_OPT_RX_MQ_MODE "rx-mq-mode"
251 : : TESTPMD_OPT_RX_MQ_MODE_NUM,
252 : : #define TESTPMD_OPT_RECORD_CORE_CYCLES "record-core-cycles"
253 : : TESTPMD_OPT_RECORD_CORE_CYCLES_NUM,
254 : : #define TESTPMD_OPT_RECORD_BURST_STATS "record-burst-stats"
255 : : TESTPMD_OPT_RECORD_BURST_STATS_NUM,
256 : : #define TESTPMD_OPT_NUM_PROCS "num-procs"
257 : : TESTPMD_OPT_NUM_PROCS_NUM,
258 : : #define TESTPMD_OPT_PROC_ID "proc-id"
259 : : TESTPMD_OPT_PROC_ID_NUM,
260 : :
261 : : TESTPMD_OPT_LONG_MAX_NUM
262 : : };
263 : :
264 : : static const char short_options[] = {
265 : : "a" /* auto-start */
266 : : "h" /* help */
267 : : "i" /* interactive */
268 : : };
269 : :
270 : : #define NO_ARG(opt) { opt, no_argument, NULL, opt ## _NUM }
271 : : #define REQUIRED_ARG(opt) { opt, required_argument, NULL, opt ## _NUM }
272 : : #define OPTIONAL_ARG(opt) { opt, optional_argument, NULL, opt ## _NUM }
273 : : static const struct option long_options[] = {
274 : : NO_ARG(TESTPMD_OPT_AUTO_START),
275 : : NO_ARG(TESTPMD_OPT_HELP),
276 : : NO_ARG(TESTPMD_OPT_INTERACTIVE),
277 : : REQUIRED_ARG(TESTPMD_OPT_CMDLINE_FILE),
278 : : REQUIRED_ARG(TESTPMD_OPT_CMDLINE_FILE_NOECHO),
279 : : REQUIRED_ARG(TESTPMD_OPT_ETH_PEERS_CONFIGFILE),
280 : : REQUIRED_ARG(TESTPMD_OPT_ETH_PEER),
281 : : NO_ARG(TESTPMD_OPT_TX_FIRST),
282 : : REQUIRED_ARG(TESTPMD_OPT_STATS_PERIOD),
283 : : REQUIRED_ARG(TESTPMD_OPT_DISPLAY_XSTATS),
284 : : REQUIRED_ARG(TESTPMD_OPT_NB_CORES),
285 : : REQUIRED_ARG(TESTPMD_OPT_NB_PORTS),
286 : : REQUIRED_ARG(TESTPMD_OPT_COREMASK),
287 : : REQUIRED_ARG(TESTPMD_OPT_PORTMASK),
288 : : REQUIRED_ARG(TESTPMD_OPT_PORTLIST),
289 : : NO_ARG(TESTPMD_OPT_NUMA),
290 : : NO_ARG(TESTPMD_OPT_NO_NUMA),
291 : : NO_ARG(TESTPMD_OPT_MP_ANON), /* deprecated */
292 : : REQUIRED_ARG(TESTPMD_OPT_PORT_NUMA_CONFIG),
293 : : REQUIRED_ARG(TESTPMD_OPT_RING_NUMA_CONFIG),
294 : : REQUIRED_ARG(TESTPMD_OPT_SOCKET_NUM),
295 : : REQUIRED_ARG(TESTPMD_OPT_MBUF_SIZE),
296 : : REQUIRED_ARG(TESTPMD_OPT_TOTAL_NUM_MBUFS),
297 : : REQUIRED_ARG(TESTPMD_OPT_MAX_PKT_LEN),
298 : : REQUIRED_ARG(TESTPMD_OPT_MAX_LRO_PKT_SIZE),
299 : : #ifdef RTE_LIB_LATENCYSTATS
300 : : REQUIRED_ARG(TESTPMD_OPT_LATENCYSTATS),
301 : : #endif
302 : : #ifdef RTE_LIB_BITRATESTATS
303 : : REQUIRED_ARG(TESTPMD_OPT_BITRATE_STATS),
304 : : #endif
305 : : NO_ARG(TESTPMD_OPT_DISABLE_CRC_STRIP),
306 : : NO_ARG(TESTPMD_OPT_ENABLE_LRO),
307 : : NO_ARG(TESTPMD_OPT_ENABLE_RX_CKSUM),
308 : : NO_ARG(TESTPMD_OPT_ENABLE_RX_TIMESTAMP),
309 : : NO_ARG(TESTPMD_OPT_ENABLE_SCATTER),
310 : : NO_ARG(TESTPMD_OPT_ENABLE_HW_VLAN),
311 : : NO_ARG(TESTPMD_OPT_ENABLE_HW_VLAN_FILTER),
312 : : NO_ARG(TESTPMD_OPT_ENABLE_HW_VLAN_STRIP),
313 : : NO_ARG(TESTPMD_OPT_ENABLE_HW_VLAN_EXTEND),
314 : : NO_ARG(TESTPMD_OPT_ENABLE_HW_QINQ_STRIP),
315 : : NO_ARG(TESTPMD_OPT_ENABLE_DROP_EN),
316 : : NO_ARG(TESTPMD_OPT_DISABLE_RSS),
317 : : NO_ARG(TESTPMD_OPT_ENABLE_RSS),
318 : : REQUIRED_ARG(TESTPMD_OPT_PORT_TOPOLOGY),
319 : : REQUIRED_ARG(TESTPMD_OPT_FORWARD_MODE),
320 : : NO_ARG(TESTPMD_OPT_RSS_IP),
321 : : NO_ARG(TESTPMD_OPT_RSS_UDP),
322 : : NO_ARG(TESTPMD_OPT_RSS_LEVEL_OUTER),
323 : : NO_ARG(TESTPMD_OPT_RSS_LEVEL_INNER),
324 : : REQUIRED_ARG(TESTPMD_OPT_RXQ),
325 : : REQUIRED_ARG(TESTPMD_OPT_TXQ),
326 : : REQUIRED_ARG(TESTPMD_OPT_RXD),
327 : : REQUIRED_ARG(TESTPMD_OPT_TXD),
328 : : REQUIRED_ARG(TESTPMD_OPT_HAIRPINQ),
329 : : REQUIRED_ARG(TESTPMD_OPT_HAIRPIN_MODE),
330 : : REQUIRED_ARG(TESTPMD_OPT_HAIRPIN_MAP),
331 : : REQUIRED_ARG(TESTPMD_OPT_BURST),
332 : : REQUIRED_ARG(TESTPMD_OPT_FLOWGEN_CLONES),
333 : : REQUIRED_ARG(TESTPMD_OPT_FLOWGEN_FLOWS),
334 : : REQUIRED_ARG(TESTPMD_OPT_MBCACHE),
335 : : REQUIRED_ARG(TESTPMD_OPT_TXPT),
336 : : REQUIRED_ARG(TESTPMD_OPT_TXHT),
337 : : REQUIRED_ARG(TESTPMD_OPT_TXWT),
338 : : REQUIRED_ARG(TESTPMD_OPT_TXFREET),
339 : : REQUIRED_ARG(TESTPMD_OPT_TXRST),
340 : : REQUIRED_ARG(TESTPMD_OPT_RXPT),
341 : : REQUIRED_ARG(TESTPMD_OPT_RXHT),
342 : : REQUIRED_ARG(TESTPMD_OPT_RXWT),
343 : : REQUIRED_ARG(TESTPMD_OPT_RXFREET),
344 : : NO_ARG(TESTPMD_OPT_NO_FLUSH_RX),
345 : : NO_ARG(TESTPMD_OPT_FLOW_ISOLATE_ALL),
346 : : NO_ARG(TESTPMD_OPT_DISABLE_FLOW_FLUSH),
347 : : REQUIRED_ARG(TESTPMD_OPT_RXOFFS),
348 : : REQUIRED_ARG(TESTPMD_OPT_RXPKTS),
349 : : REQUIRED_ARG(TESTPMD_OPT_RXHDRS),
350 : : REQUIRED_ARG(TESTPMD_OPT_TXPKTS),
351 : : NO_ARG(TESTPMD_OPT_MULTI_RX_MEMPOOL),
352 : : NO_ARG(TESTPMD_OPT_TXONLY_MULTI_FLOW),
353 : : REQUIRED_ARG(TESTPMD_OPT_TXONLY_FLOWS),
354 : : NO_ARG(TESTPMD_OPT_RXQ_SHARE),
355 : : REQUIRED_ARG(TESTPMD_OPT_ETH_LINK_SPEED),
356 : : NO_ARG(TESTPMD_OPT_DISABLE_LINK_CHECK),
357 : : NO_ARG(TESTPMD_OPT_DISABLE_DEVICE_START),
358 : : NO_ARG(TESTPMD_OPT_NO_LSC_INTERRUPT),
359 : : NO_ARG(TESTPMD_OPT_NO_RMV_INTERRUPT),
360 : : REQUIRED_ARG(TESTPMD_OPT_PRINT_EVENT),
361 : : REQUIRED_ARG(TESTPMD_OPT_MASK_EVENT),
362 : : REQUIRED_ARG(TESTPMD_OPT_TX_OFFLOADS),
363 : : REQUIRED_ARG(TESTPMD_OPT_RX_OFFLOADS),
364 : : NO_ARG(TESTPMD_OPT_HOT_PLUG),
365 : : REQUIRED_ARG(TESTPMD_OPT_VXLAN_GPE_PORT),
366 : : REQUIRED_ARG(TESTPMD_OPT_GENEVE_PARSED_PORT),
367 : : #ifndef RTE_EXEC_ENV_WINDOWS
368 : : NO_ARG(TESTPMD_OPT_MLOCKALL),
369 : : NO_ARG(TESTPMD_OPT_NO_MLOCKALL),
370 : : #endif
371 : : REQUIRED_ARG(TESTPMD_OPT_MP_ALLOC),
372 : : REQUIRED_ARG(TESTPMD_OPT_TX_IP),
373 : : REQUIRED_ARG(TESTPMD_OPT_TX_UDP),
374 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_TX_SW_BUFFER_SIZE),
375 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_TX_SW_BUFFER_FLUSHTIME),
376 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_LKUP_MEMORY),
377 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_LKUP_NUM_WRITES),
378 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_LKUP_NUM_READS),
379 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_LKUP_NUM_READS_WRITES),
380 : : REQUIRED_ARG(TESTPMD_OPT_NOISY_FORWARD_MODE),
381 : : NO_ARG(TESTPMD_OPT_NO_IOVA_CONTIG),
382 : : REQUIRED_ARG(TESTPMD_OPT_RX_MQ_MODE),
383 : : NO_ARG(TESTPMD_OPT_RECORD_CORE_CYCLES),
384 : : NO_ARG(TESTPMD_OPT_RECORD_BURST_STATS),
385 : : REQUIRED_ARG(TESTPMD_OPT_NUM_PROCS),
386 : : REQUIRED_ARG(TESTPMD_OPT_PROC_ID),
387 : : { 0, 0, NULL, 0 }
388 : : };
389 : : #undef NO_ARG
390 : : #undef REQUIRED_ARG
391 : : #undef OPTIONAL_ARG
392 : :
393 : : static void
394 : 0 : usage(char* progname)
395 : : {
396 : : printf("\nUsage: %s [EAL options] -- [testpmd options]\n\n",
397 : : progname);
398 : : printf(" --interactive: run in interactive mode.\n");
399 : : printf(" --cmdline-file: execute cli commands before startup, echoing each command as it is run.\n");
400 : : printf(" --cmdline-file-noecho: execute cli commands before startup, without echoing each command.\n");
401 : : printf(" --auto-start: start forwarding on init "
402 : : "[always when non-interactive].\n");
403 : : printf(" --help: display this message and quit.\n");
404 : : printf(" --tx-first: start forwarding sending a burst first "
405 : : "(only if interactive is disabled).\n");
406 : : printf(" --stats-period=PERIOD: statistics will be shown "
407 : : "every PERIOD seconds (only if interactive is disabled).\n");
408 : : printf(" --display-xstats xstat_name1[,...]: comma-separated list of "
409 : : "extended statistics to show. Used with --stats-period "
410 : : "specified or interactive commands that show Rx/Tx statistics "
411 : : "(i.e. 'show port stats').\n");
412 : : printf(" --num-procs=N: set the total number of multi-process instances.\n");
413 : : printf(" --proc-id=id: set the id of the current process from "
414 : : "multi-process instances (0 <= id < num-procs).\n");
415 : 0 : printf(" --nb-cores=N: set the number of forwarding cores "
416 : : "(1 <= N <= %d).\n", nb_lcores);
417 : 0 : printf(" --nb-ports=N: set the number of forwarding ports "
418 : : "(1 <= N <= %d).\n", nb_ports);
419 : : printf(" --coremask=COREMASK: hexadecimal bitmask of cores running "
420 : : "the packet forwarding test. The main lcore is reserved for "
421 : : "command line parsing only, and cannot be masked on for "
422 : : "packet forwarding.\n");
423 : : printf(" --portmask=PORTMASK: hexadecimal bitmask of ports used "
424 : : "by the packet forwarding test.\n");
425 : : printf(" --portlist=PORTLIST: list of forwarding ports\n");
426 : : printf(" --numa: enable NUMA-aware allocation of RX/TX rings and of "
427 : : "RX memory buffers (mbufs).\n");
428 : : printf(" --no-numa: disable NUMA-aware allocation.\n");
429 : : printf(" --port-numa-config=(port,socket)[,(port,socket)]: "
430 : : "specify the socket on which the memory pool "
431 : : "used by the port will be allocated.\n");
432 : : printf(" --ring-numa-config=(port,flag,socket)[,(port,flag,socket)]: "
433 : : "specify the socket on which the TX/RX rings for "
434 : : "the port will be allocated "
435 : : "(flag: 1 for RX; 2 for TX; 3 for RX and TX).\n");
436 : : printf(" --socket-num=N: set socket from which all memory is allocated "
437 : : "in NUMA mode.\n");
438 : : printf(" --mbuf-size=N,[N1[,..Nn]: set the data size of mbuf to "
439 : : "N bytes. If multiple numbers are specified the extra pools "
440 : : "will be created to receive packets based on the features "
441 : : "supported, like packet split, multi-rx-mempool.\n");
442 : : printf(" --total-num-mbufs=N: set the number of mbufs to be allocated "
443 : : "in mbuf pools.\n");
444 : : printf(" --max-pkt-len=N: set the maximum size of packet to N bytes.\n");
445 : : printf(" --max-lro-pkt-size=N: set the maximum LRO aggregated packet "
446 : : "size to N bytes.\n");
447 : : printf(" --eth-peers-configfile=name: config file with ethernet addresses "
448 : : "of peer ports.\n");
449 : : printf(" --eth-peer=X,M:M:M:M:M:M: set the MAC address of the X peer "
450 : : "port (0 <= X < %d).\n", RTE_MAX_ETHPORTS);
451 : : printf(" --disable-crc-strip: disable CRC stripping by hardware.\n");
452 : : printf(" --enable-scatter: enable scattered Rx.\n");
453 : : printf(" --enable-lro: enable large receive offload.\n");
454 : : printf(" --enable-rx-cksum: enable rx hardware checksum offload.\n");
455 : : printf(" --enable-rx-timestamp: enable rx hardware timestamp offload.\n");
456 : : printf(" --enable-hw-vlan: enable hardware vlan.\n");
457 : : printf(" --enable-hw-vlan-filter: enable hardware vlan filter.\n");
458 : : printf(" --enable-hw-vlan-strip: enable hardware vlan strip.\n");
459 : : printf(" --enable-hw-vlan-extend: enable hardware vlan extend.\n");
460 : : printf(" --enable-hw-qinq-strip: enable hardware qinq strip.\n");
461 : : printf(" --enable-drop-en: enable per queue packet drop.\n");
462 : : printf(" --disable-rss: disable rss.\n");
463 : : printf(" --enable-rss: Force rss even for single-queue operation.\n");
464 : : printf(" --port-topology=<paired|chained|loop>: set port topology (paired "
465 : : "is default).\n");
466 : 0 : printf(" --forward-mode=N: set forwarding mode (N: %s).\n",
467 : : list_pkt_forwarding_modes());
468 : : printf(" --forward-mode=5tswap: set forwarding mode to "
469 : : "swap L2,L3,L4 for MAC, IPv4/IPv6 and TCP/UDP only.\n");
470 : : printf(" --rss-ip: set RSS functions to IPv4/IPv6 only .\n");
471 : : printf(" --rss-udp: set RSS functions to IPv4/IPv6 + UDP.\n");
472 : : printf(" --rss-level-inner: set RSS hash level to innermost\n");
473 : : printf(" --rss-level-outer: set RSS hash level to outermost\n");
474 : : printf(" --rxq=N: set the number of RX queues per port to N.\n");
475 : : printf(" --rxd=N: set the number of descriptors in RX rings to N.\n");
476 : : printf(" --txq=N: set the number of TX queues per port to N.\n");
477 : : printf(" --txd=N: set the number of descriptors in TX rings to N.\n");
478 : : printf(" --hairpinq=N: set the number of hairpin queues per port to "
479 : : "N.\n");
480 : : printf(" --burst=N: set the number of packets per burst to N.\n");
481 : : printf(" --flowgen-clones=N: set the number of single packet clones to send in flowgen mode. Should be less than burst value.\n");
482 : : printf(" --flowgen-flows=N: set the number of flows in flowgen mode to N (1 <= N <= INT32_MAX).\n");
483 : : printf(" --mbcache=N: set the cache of mbuf memory pool to N.\n");
484 : : printf(" --rxpt=N: set prefetch threshold register of RX rings to N.\n");
485 : : printf(" --rxht=N: set the host threshold register of RX rings to N.\n");
486 : : printf(" --rxfreet=N: set the free threshold of RX descriptors to N "
487 : : "(0 <= N < value of rxd).\n");
488 : : printf(" --rxwt=N: set the write-back threshold register of RX rings to N.\n");
489 : : printf(" --txpt=N: set the prefetch threshold register of TX rings to N.\n");
490 : : printf(" --txht=N: set the nhost threshold register of TX rings to N.\n");
491 : : printf(" --txwt=N: set the write-back threshold register of TX rings to N.\n");
492 : : printf(" --txfreet=N: set the transmit free threshold of TX rings to N "
493 : : "(0 <= N <= value of txd).\n");
494 : : printf(" --txrst=N: set the transmit RS bit threshold of TX rings to N "
495 : : "(0 <= N <= value of txd).\n");
496 : : printf(" --no-flush-rx: Don't flush RX streams before forwarding."
497 : : " Used mainly with PCAP drivers.\n");
498 : : printf(" --rxoffs=X[,Y]*: set RX segment offsets for split.\n");
499 : : printf(" --rxpkts=X[,Y]*: set RX segment sizes to split.\n");
500 : : printf(" --rxhdrs=eth[,ipv4]*: set RX segment protocol to split.\n");
501 : : printf(" --txpkts=X[,Y]*: set TX segment sizes"
502 : : " or total packet length.\n");
503 : : printf(" --multi-rx-mempool: enable multi-rx-mempool support\n");
504 : : printf(" --txonly-multi-flow: generate multiple flows in txonly mode\n");
505 : : printf(" --txonly-nb-flows=N: number of flows per lcore in txonly"
506 : : " multi-flow mode (1-64, default 64)\n");
507 : : printf(" --tx-ip=src,dst: IP addresses in Tx-only mode\n");
508 : : printf(" --tx-udp=src[,dst]: UDP ports in Tx-only mode\n");
509 : : printf(" --eth-link-speed: force link speed.\n");
510 : : printf(" --rxq-share: enable Rx queue sharing per switch and Rx domain\n");
511 : : printf(" --disable-link-check: disable check on link status when "
512 : : "starting/stopping ports.\n");
513 : : printf(" --disable-device-start: do not automatically start port\n");
514 : : printf(" --no-lsc-interrupt: disable link status change interrupt.\n");
515 : : printf(" --no-rmv-interrupt: disable device removal interrupt.\n");
516 : : #ifdef RTE_LIB_BITRATESTATS
517 : : printf(" --bitrate-stats=N: set the logical core N to perform "
518 : : "bit-rate calculation.\n");
519 : : #endif
520 : : #ifdef RTE_LIB_LATENCYSTATS
521 : : printf(" --latencystats=N: enable latency and jitter statistics "
522 : : "monitoring on forwarding lcore id N.\n");
523 : : #endif
524 : : printf(" --print-event <unknown|intr_lsc|queue_state|intr_reset|vf_mbox|macsec|intr_rmv|flow_aged|err_recovering|recovery_success|recovery_failed|all>: "
525 : : "enable print of designated event or all of them.\n");
526 : : printf(" --mask-event <unknown|intr_lsc|queue_state|intr_reset|vf_mbox|macsec|intr_rmv|flow_aged|err_recovering|recovery_success|recovery_failed||all>: "
527 : : "disable print of designated event or all of them.\n");
528 : : printf(" --flow-isolate-all: "
529 : : "requests flow API isolated mode on all ports at initialization time.\n");
530 : : printf(" --disable-flow-flush: disable port flow flush when stop port.\n");
531 : : printf(" --tx-offloads=0xXXXXXXXX: hexadecimal bitmask of TX queue offloads\n");
532 : : printf(" --rx-offloads=0xXXXXXXXX: hexadecimal bitmask of RX queue offloads\n");
533 : : printf(" --hot-plug: enable hot plug for device.\n");
534 : : printf(" --vxlan-gpe-port=N: UPD port of tunnel VXLAN-GPE\n");
535 : : printf(" --geneve-parsed-port=N: UPD port to parse GENEVE tunnel protocol\n");
536 : : #ifndef RTE_EXEC_ENV_WINDOWS
537 : : printf(" --mlockall: lock all memory\n");
538 : : printf(" --no-mlockall: do not lock all memory\n");
539 : : #endif
540 : : printf(" --mp-alloc <native|anon|xmem|xmemhuge>: mempool allocation method.\n"
541 : : " native: use regular DPDK memory to create and populate mempool\n"
542 : : " anon: use regular DPDK memory to create and anonymous memory to populate mempool\n"
543 : : " xmem: use anonymous memory to create and populate mempool\n"
544 : : " xmemhuge: use anonymous hugepage memory to create and populate mempool\n");
545 : : printf(" --noisy-forward-mode=<io|mac|macswap|5tswap>: set the sub-fwd mode, defaults to io\n");
546 : : printf(" --noisy-tx-sw-buffer-size=N: size of FIFO buffer\n");
547 : : printf(" --noisy-tx-sw-buffer-flushtime=N: flush FIFO after N ms\n");
548 : : printf(" --noisy-lkup-memory=N: allocate N MB of VNF memory\n");
549 : : printf(" --noisy-lkup-num-writes=N: do N random writes per packet\n");
550 : : printf(" --noisy-lkup-num-reads=N: do N random reads per packet\n");
551 : : printf(" --noisy-lkup-num-reads-writes=N: do N random reads and writes per packet\n");
552 : : printf(" --no-iova-contig: mempool memory can be IOVA non contiguous. "
553 : : "valid only with --mp-alloc=anon\n");
554 : : printf(" --rx-mq-mode=0xX: hexadecimal bitmask of RX mq mode can be "
555 : : "enabled\n");
556 : : printf(" --record-core-cycles: enable measurement of CPU cycles.\n");
557 : : printf(" --record-burst-stats: enable display of RX and TX bursts.\n");
558 : : printf(" --hairpin-mode=0xXX: bitmask set the hairpin port mode.\n"
559 : : " 0x10 - explicit Tx rule, 0x02 - hairpin ports paired\n"
560 : : " 0x01 - hairpin ports loop, 0x00 - hairpin port self\n");
561 : 0 : hairpin_map_usage();
562 : 0 : }
563 : :
564 : : static int
565 : 0 : init_peer_eth_addrs(const char *config_filename)
566 : : {
567 : : FILE *config_file;
568 : : portid_t i;
569 : : char buf[50];
570 : :
571 : 0 : config_file = fopen(config_filename, "r");
572 : 0 : if (config_file == NULL) {
573 : 0 : perror("Failed to open eth config file\n");
574 : 0 : return -1;
575 : : }
576 : :
577 : 0 : for (i = 0; i < RTE_MAX_ETHPORTS; i++) {
578 : :
579 : 0 : if (fgets(buf, sizeof(buf), config_file) == NULL)
580 : : break;
581 : :
582 : 0 : if (rte_ether_unformat_addr(buf, &peer_eth_addrs[i]) < 0) {
583 : 0 : fprintf(stderr, "Bad MAC address format on line %d\n",
584 : : i + 1);
585 : 0 : fclose(config_file);
586 : 0 : return -1;
587 : : }
588 : : }
589 : 0 : fclose(config_file);
590 : 0 : nb_peer_eth_addrs = (portid_t) i;
591 : 0 : return 0;
592 : : }
593 : :
594 : : /*
595 : : * Parse the coremask given as argument (hexadecimal string) and set
596 : : * the global configuration of forwarding cores.
597 : : */
598 : : static void
599 : 0 : parse_fwd_coremask(const char *coremask)
600 : : {
601 : : char *end;
602 : : unsigned long long int cm;
603 : :
604 : : /* parse hexadecimal string */
605 : 0 : end = NULL;
606 : 0 : cm = strtoull(coremask, &end, 16);
607 : 0 : if ((coremask[0] == '\0') || (end == NULL) || (*end != '\0'))
608 : 0 : rte_exit(EXIT_FAILURE, "Invalid fwd core mask\n");
609 : 0 : else if (set_fwd_lcores_mask((uint64_t) cm) < 0)
610 : 0 : rte_exit(EXIT_FAILURE, "coremask is not valid\n");
611 : 0 : }
612 : :
613 : : /*
614 : : * Parse the coremask given as argument (hexadecimal string) and set
615 : : * the global configuration of forwarding cores.
616 : : */
617 : : static void
618 : 0 : parse_fwd_portmask(const char *portmask)
619 : : {
620 : : char *end;
621 : : unsigned long long int pm;
622 : :
623 : : /* parse hexadecimal string */
624 : 0 : end = NULL;
625 : 0 : pm = strtoull(portmask, &end, 16);
626 : 0 : if ((portmask[0] == '\0') || (end == NULL) || (*end != '\0'))
627 : 0 : rte_exit(EXIT_FAILURE, "Invalid fwd port mask\n");
628 : : else
629 : 0 : set_fwd_ports_mask((uint64_t) pm);
630 : 0 : }
631 : :
632 : : static void
633 : 0 : print_invalid_socket_id_error(void)
634 : : {
635 : : unsigned int i = 0;
636 : :
637 : 0 : fprintf(stderr, "Invalid socket id, options are: ");
638 : 0 : for (i = 0; i < num_sockets; i++) {
639 : 0 : fprintf(stderr, "%u%s", socket_ids[i],
640 : 0 : (i == num_sockets - 1) ? "\n" : ",");
641 : : }
642 : 0 : }
643 : :
644 : : static int
645 : 0 : parse_portnuma_config(const char *q_arg)
646 : : {
647 : : char s[256];
648 : : const char *p, *p0 = q_arg;
649 : : char *end;
650 : : uint8_t i, socket_id;
651 : : portid_t port_id;
652 : : unsigned size;
653 : : enum fieldnames {
654 : : FLD_PORT = 0,
655 : : FLD_SOCKET,
656 : : _NUM_FLD
657 : : };
658 : : unsigned long int_fld[_NUM_FLD];
659 : : char *str_fld[_NUM_FLD];
660 : :
661 : : /* reset from value set at definition */
662 : 0 : while ((p = strchr(p0,'(')) != NULL) {
663 : 0 : ++p;
664 : 0 : if((p0 = strchr(p,')')) == NULL)
665 : : return -1;
666 : :
667 : 0 : size = p0 - p;
668 : 0 : if(size >= sizeof(s))
669 : : return -1;
670 : :
671 : : snprintf(s, sizeof(s), "%.*s", size, p);
672 : 0 : if (rte_strsplit(s, sizeof(s), str_fld, _NUM_FLD, ',') != _NUM_FLD)
673 : : return -1;
674 : 0 : for (i = 0; i < _NUM_FLD; i++) {
675 : 0 : errno = 0;
676 : 0 : int_fld[i] = strtoul(str_fld[i], &end, 0);
677 : 0 : if (errno != 0 || end == str_fld[i] || int_fld[i] > 255)
678 : : return -1;
679 : : }
680 : 0 : port_id = (portid_t)int_fld[FLD_PORT];
681 : 0 : if (port_id_is_invalid(port_id, ENABLED_WARN) ||
682 : : port_id == (portid_t)RTE_PORT_ALL) {
683 : 0 : print_valid_ports();
684 : 0 : return -1;
685 : : }
686 : 0 : socket_id = (uint8_t)int_fld[FLD_SOCKET];
687 : 0 : if (new_socket_id(socket_id)) {
688 : 0 : if (num_sockets >= RTE_MAX_NUMA_NODES) {
689 : 0 : print_invalid_socket_id_error();
690 : 0 : return -1;
691 : : }
692 : 0 : socket_ids[num_sockets++] = socket_id;
693 : : }
694 : 0 : port_numa[port_id] = socket_id;
695 : : }
696 : :
697 : : return 0;
698 : : }
699 : :
700 : : static int
701 : 0 : parse_ringnuma_config(const char *q_arg)
702 : : {
703 : : char s[256];
704 : : const char *p, *p0 = q_arg;
705 : : char *end;
706 : : uint8_t i, ring_flag, socket_id;
707 : : portid_t port_id;
708 : : unsigned size;
709 : : enum fieldnames {
710 : : FLD_PORT = 0,
711 : : FLD_FLAG,
712 : : FLD_SOCKET,
713 : : _NUM_FLD
714 : : };
715 : : unsigned long int_fld[_NUM_FLD];
716 : : char *str_fld[_NUM_FLD];
717 : : #define RX_RING_ONLY 0x1
718 : : #define TX_RING_ONLY 0x2
719 : : #define RXTX_RING 0x3
720 : :
721 : : /* reset from value set at definition */
722 : 0 : while ((p = strchr(p0,'(')) != NULL) {
723 : 0 : ++p;
724 : 0 : if((p0 = strchr(p,')')) == NULL)
725 : : return -1;
726 : :
727 : 0 : size = p0 - p;
728 : 0 : if(size >= sizeof(s))
729 : : return -1;
730 : :
731 : : snprintf(s, sizeof(s), "%.*s", size, p);
732 : 0 : if (rte_strsplit(s, sizeof(s), str_fld, _NUM_FLD, ',') != _NUM_FLD)
733 : : return -1;
734 : 0 : for (i = 0; i < _NUM_FLD; i++) {
735 : 0 : errno = 0;
736 : 0 : int_fld[i] = strtoul(str_fld[i], &end, 0);
737 : 0 : if (errno != 0 || end == str_fld[i] || int_fld[i] > 255)
738 : : return -1;
739 : : }
740 : 0 : port_id = (portid_t)int_fld[FLD_PORT];
741 : 0 : if (port_id_is_invalid(port_id, ENABLED_WARN) ||
742 : : port_id == (portid_t)RTE_PORT_ALL) {
743 : 0 : print_valid_ports();
744 : 0 : return -1;
745 : : }
746 : 0 : socket_id = (uint8_t)int_fld[FLD_SOCKET];
747 : 0 : if (new_socket_id(socket_id)) {
748 : 0 : if (num_sockets >= RTE_MAX_NUMA_NODES) {
749 : 0 : print_invalid_socket_id_error();
750 : 0 : return -1;
751 : : }
752 : 0 : socket_ids[num_sockets++] = socket_id;
753 : : }
754 : 0 : ring_flag = (uint8_t)int_fld[FLD_FLAG];
755 : 0 : if ((ring_flag < RX_RING_ONLY) || (ring_flag > RXTX_RING)) {
756 : 0 : fprintf(stderr,
757 : : "Invalid ring-flag=%d config for port =%d\n",
758 : : ring_flag,port_id);
759 : 0 : return -1;
760 : : }
761 : :
762 : 0 : switch (ring_flag & RXTX_RING) {
763 : 0 : case RX_RING_ONLY:
764 : 0 : rxring_numa[port_id] = socket_id;
765 : 0 : break;
766 : 0 : case TX_RING_ONLY:
767 : 0 : txring_numa[port_id] = socket_id;
768 : 0 : break;
769 : 0 : case RXTX_RING:
770 : 0 : rxring_numa[port_id] = socket_id;
771 : 0 : txring_numa[port_id] = socket_id;
772 : 0 : break;
773 : : default:
774 : : fprintf(stderr,
775 : : "Invalid ring-flag=%d config for port=%d\n",
776 : : ring_flag,port_id);
777 : : break;
778 : : }
779 : : }
780 : :
781 : : return 0;
782 : : }
783 : :
784 : : static int
785 : 0 : parse_event_printing_config(const char *event_arg, int enable)
786 : : {
787 : : uint32_t mask = 0;
788 : :
789 : 0 : if (!strcmp(event_arg, "unknown"))
790 : : mask = UINT32_C(1) << RTE_ETH_EVENT_UNKNOWN;
791 : 0 : else if (!strcmp(event_arg, "intr_lsc"))
792 : : mask = UINT32_C(1) << RTE_ETH_EVENT_INTR_LSC;
793 : 0 : else if (!strcmp(event_arg, "queue_state"))
794 : : mask = UINT32_C(1) << RTE_ETH_EVENT_QUEUE_STATE;
795 : 0 : else if (!strcmp(event_arg, "intr_reset"))
796 : : mask = UINT32_C(1) << RTE_ETH_EVENT_INTR_RESET;
797 : 0 : else if (!strcmp(event_arg, "vf_mbox"))
798 : : mask = UINT32_C(1) << RTE_ETH_EVENT_VF_MBOX;
799 : 0 : else if (!strcmp(event_arg, "ipsec"))
800 : : mask = UINT32_C(1) << RTE_ETH_EVENT_IPSEC;
801 : 0 : else if (!strcmp(event_arg, "macsec"))
802 : : mask = UINT32_C(1) << RTE_ETH_EVENT_MACSEC;
803 : 0 : else if (!strcmp(event_arg, "intr_rmv"))
804 : : mask = UINT32_C(1) << RTE_ETH_EVENT_INTR_RMV;
805 : 0 : else if (!strcmp(event_arg, "dev_probed"))
806 : : mask = UINT32_C(1) << RTE_ETH_EVENT_NEW;
807 : 0 : else if (!strcmp(event_arg, "dev_released"))
808 : : mask = UINT32_C(1) << RTE_ETH_EVENT_DESTROY;
809 : 0 : else if (!strcmp(event_arg, "flow_aged"))
810 : : mask = UINT32_C(1) << RTE_ETH_EVENT_FLOW_AGED;
811 : 0 : else if (!strcmp(event_arg, "err_recovering"))
812 : : mask = UINT32_C(1) << RTE_ETH_EVENT_ERR_RECOVERING;
813 : 0 : else if (!strcmp(event_arg, "recovery_success"))
814 : : mask = UINT32_C(1) << RTE_ETH_EVENT_RECOVERY_SUCCESS;
815 : 0 : else if (!strcmp(event_arg, "recovery_failed"))
816 : : mask = UINT32_C(1) << RTE_ETH_EVENT_RECOVERY_FAILED;
817 : 0 : else if (!strcmp(event_arg, "all"))
818 : : mask = ~UINT32_C(0);
819 : : else {
820 : 0 : fprintf(stderr, "Invalid event: %s\n", event_arg);
821 : 0 : return -1;
822 : : }
823 : 0 : if (enable)
824 : 0 : event_print_mask |= mask;
825 : : else
826 : 0 : event_print_mask &= ~mask;
827 : : return 0;
828 : : }
829 : :
830 : : static int
831 : 0 : parse_xstats_list(const char *in_str, struct rte_eth_xstat_name **xstats,
832 : : unsigned int *xstats_num)
833 : : {
834 : : int max_names_nb, names_nb, nonempty_names_nb;
835 : : int name, nonempty_name;
836 : : int stringlen;
837 : : char **names;
838 : : char *str;
839 : : int ret;
840 : : int i;
841 : :
842 : : names = NULL;
843 : 0 : str = strdup(in_str);
844 : 0 : if (str == NULL) {
845 : : ret = -ENOMEM;
846 : 0 : goto out;
847 : : }
848 : 0 : stringlen = strlen(str);
849 : :
850 : 0 : for (i = 0, max_names_nb = 1; str[i] != '\0'; i++) {
851 : 0 : if (str[i] == ',')
852 : 0 : max_names_nb++;
853 : : }
854 : :
855 : 0 : names = calloc(max_names_nb, sizeof(*names));
856 : 0 : if (names == NULL) {
857 : : ret = -ENOMEM;
858 : 0 : goto out;
859 : : }
860 : :
861 : 0 : names_nb = rte_strsplit(str, stringlen, names, max_names_nb, ',');
862 : 0 : if (names_nb < 0) {
863 : : ret = -EINVAL;
864 : 0 : goto out;
865 : : }
866 : :
867 : : nonempty_names_nb = 0;
868 : 0 : for (i = 0; i < names_nb; i++) {
869 : 0 : if (names[i][0] == '\0')
870 : 0 : continue;
871 : 0 : nonempty_names_nb++;
872 : : }
873 : 0 : *xstats = calloc(nonempty_names_nb, sizeof(**xstats));
874 : 0 : if (*xstats == NULL) {
875 : : ret = -ENOMEM;
876 : 0 : goto out;
877 : : }
878 : :
879 : 0 : for (name = nonempty_name = 0; name < names_nb; name++) {
880 : 0 : if (names[name][0] == '\0')
881 : 0 : continue;
882 : 0 : rte_strscpy((*xstats)[nonempty_name].name, names[name],
883 : : sizeof((*xstats)[nonempty_name].name));
884 : 0 : nonempty_name++;
885 : : }
886 : :
887 : 0 : *xstats_num = nonempty_names_nb;
888 : : ret = 0;
889 : :
890 : 0 : out:
891 : 0 : free(names);
892 : 0 : free(str);
893 : 0 : return ret;
894 : : }
895 : :
896 : : static int
897 : 0 : parse_link_speed(int n)
898 : : {
899 : : uint32_t speed = RTE_ETH_LINK_SPEED_FIXED;
900 : :
901 : 0 : switch (n) {
902 : : case 1000:
903 : : speed |= RTE_ETH_LINK_SPEED_1G;
904 : : break;
905 : 0 : case 2500:
906 : : speed |= RTE_ETH_LINK_SPEED_2_5G;
907 : 0 : break;
908 : 0 : case 5000:
909 : : speed |= RTE_ETH_LINK_SPEED_5G;
910 : 0 : break;
911 : 0 : case 10000:
912 : : speed |= RTE_ETH_LINK_SPEED_10G;
913 : 0 : break;
914 : 0 : case 25000:
915 : : speed |= RTE_ETH_LINK_SPEED_25G;
916 : 0 : break;
917 : 0 : case 40000:
918 : : speed |= RTE_ETH_LINK_SPEED_40G;
919 : 0 : break;
920 : 0 : case 50000:
921 : : speed |= RTE_ETH_LINK_SPEED_50G;
922 : 0 : break;
923 : 0 : case 100000:
924 : : speed |= RTE_ETH_LINK_SPEED_100G;
925 : 0 : break;
926 : 0 : case 200000:
927 : : speed |= RTE_ETH_LINK_SPEED_200G;
928 : 0 : break;
929 : 0 : case 400000:
930 : : speed |= RTE_ETH_LINK_SPEED_400G;
931 : 0 : break;
932 : 0 : case 800000:
933 : : speed |= RTE_ETH_LINK_SPEED_800G;
934 : 0 : break;
935 : 0 : case 100:
936 : : case 10:
937 : : default:
938 : 0 : fprintf(stderr, "Unsupported fixed speed\n");
939 : 0 : return 0;
940 : : }
941 : :
942 : 0 : return speed;
943 : : }
944 : :
945 : : void
946 : 0 : launch_args_parse(int argc, char** argv)
947 : : {
948 : : int n, opt;
949 : : int opt_idx;
950 : : portid_t pid;
951 : : enum { TX, RX };
952 : : /* Default offloads for all ports. */
953 : 0 : uint64_t rx_offloads = rx_mode.offloads;
954 : 0 : uint64_t tx_offloads = tx_mode.offloads;
955 : : struct rte_eth_dev_info dev_info;
956 : : uint16_t rec_nb_pkts;
957 : : int ret;
958 : :
959 : 0 : while ((opt = getopt_long(argc, argv, short_options, long_options,
960 : 0 : &opt_idx)) != EOF) {
961 : 0 : switch (opt) {
962 : : case 'i':
963 : : printf("Interactive-mode selected\n");
964 : 0 : interactive = 1;
965 : 0 : break;
966 : : case 'a':
967 : : printf("Auto-start selected\n");
968 : 0 : auto_start = 1;
969 : 0 : break;
970 : 0 : case 'h':
971 : 0 : usage(argv[0]);
972 : 0 : exit(EXIT_SUCCESS);
973 : : break;
974 : 0 : case TESTPMD_OPT_CMDLINE_FILE_NUM:
975 : : case TESTPMD_OPT_CMDLINE_FILE_NOECHO_NUM:
976 : 0 : if (cmdline_file_count >= RTE_DIM(cmdline_files)) {
977 : 0 : fprintf(stderr, "Too many cmdline files specified (maximum %zu)\n",
978 : : RTE_DIM(cmdline_files));
979 : 0 : exit(EXIT_FAILURE);
980 : : }
981 : 0 : printf("CLI commands to be read from %s\n", optarg);
982 : 0 : strlcpy(cmdline_files[cmdline_file_count].filename, optarg,
983 : : sizeof(cmdline_files[cmdline_file_count].filename));
984 : 0 : cmdline_files[cmdline_file_count].echo =
985 : 0 : (opt == TESTPMD_OPT_CMDLINE_FILE_NUM);
986 : 0 : cmdline_file_count++;
987 : 0 : break;
988 : : case TESTPMD_OPT_TX_FIRST_NUM:
989 : : printf("Ports to start sending a burst of "
990 : : "packets first\n");
991 : 0 : tx_first = 1;
992 : 0 : break;
993 : 0 : case TESTPMD_OPT_STATS_PERIOD_NUM: {
994 : 0 : char *end = NULL;
995 : :
996 : 0 : n = strtoul(optarg, &end, 10);
997 : 0 : if ((optarg[0] == '\0') || (end == NULL) ||
998 : 0 : (*end != '\0') || n <= 0 || n >= UINT16_MAX)
999 : 0 : rte_exit(EXIT_FAILURE, "Invalid stats-period value\n");
1000 : :
1001 : 0 : stats_period = n;
1002 : : break;
1003 : : }
1004 : 0 : case TESTPMD_OPT_DISPLAY_XSTATS_NUM: {
1005 : : char rc;
1006 : :
1007 : 0 : rc = parse_xstats_list(optarg, &xstats_display,
1008 : : &xstats_display_num);
1009 : 0 : if (rc != 0)
1010 : 0 : rte_exit(EXIT_FAILURE,
1011 : : "Failed to parse display-xstats argument: %d\n",
1012 : : rc);
1013 : : break;
1014 : : }
1015 : 0 : case TESTPMD_OPT_ETH_PEERS_CONFIGFILE_NUM:
1016 : 0 : if (init_peer_eth_addrs(optarg) != 0)
1017 : 0 : rte_exit(EXIT_FAILURE,
1018 : : "Cannot open logfile\n");
1019 : : break;
1020 : 0 : case TESTPMD_OPT_ETH_PEER_NUM: {
1021 : : char *port_end;
1022 : :
1023 : 0 : errno = 0;
1024 : 0 : n = strtoul(optarg, &port_end, 10);
1025 : 0 : if (errno != 0 || port_end == optarg || *port_end++ != ',')
1026 : 0 : rte_exit(EXIT_FAILURE,
1027 : : "Invalid eth-peer: %s", optarg);
1028 : 0 : if (n >= RTE_MAX_ETHPORTS)
1029 : 0 : rte_exit(EXIT_FAILURE,
1030 : : "eth-peer: port %d >= RTE_MAX_ETHPORTS(%d)\n",
1031 : : n, RTE_MAX_ETHPORTS);
1032 : :
1033 : 0 : if (rte_ether_unformat_addr(port_end,
1034 : : &peer_eth_addrs[n]) < 0)
1035 : 0 : rte_exit(EXIT_FAILURE,
1036 : : "Invalid ethernet address: %s\n",
1037 : : port_end);
1038 : 0 : nb_peer_eth_addrs++;
1039 : : break;
1040 : : }
1041 : 0 : case TESTPMD_OPT_TX_IP_NUM: {
1042 : : struct in_addr in;
1043 : : char *end;
1044 : :
1045 : 0 : end = strchr(optarg, ',');
1046 : 0 : if (end == optarg || !end)
1047 : 0 : rte_exit(EXIT_FAILURE,
1048 : : "Invalid tx-ip: %s", optarg);
1049 : :
1050 : 0 : *end++ = 0;
1051 : 0 : if (inet_pton(AF_INET, optarg, &in) == 0)
1052 : 0 : rte_exit(EXIT_FAILURE,
1053 : : "Invalid source IP address: %s\n",
1054 : : optarg);
1055 : 0 : tx_ip_src_addr = rte_be_to_cpu_32(in.s_addr);
1056 : :
1057 : 0 : if (inet_pton(AF_INET, end, &in) == 0)
1058 : 0 : rte_exit(EXIT_FAILURE,
1059 : : "Invalid destination IP address: %s\n",
1060 : : optarg);
1061 : 0 : tx_ip_dst_addr = rte_be_to_cpu_32(in.s_addr);
1062 : : break;
1063 : : }
1064 : 0 : case TESTPMD_OPT_TX_UDP_NUM: {
1065 : 0 : char *end = NULL;
1066 : :
1067 : 0 : errno = 0;
1068 : 0 : n = strtoul(optarg, &end, 10);
1069 : 0 : if (errno != 0 || end == optarg ||
1070 : 0 : n > UINT16_MAX ||
1071 : 0 : !(*end == '\0' || *end == ','))
1072 : 0 : rte_exit(EXIT_FAILURE,
1073 : : "Invalid UDP port: %s\n",
1074 : : optarg);
1075 : 0 : tx_udp_src_port = n;
1076 : 0 : if (*end == ',') {
1077 : 0 : char *dst = end + 1;
1078 : :
1079 : 0 : n = strtoul(dst, &end, 10);
1080 : 0 : if (errno != 0 || end == dst ||
1081 : 0 : n > UINT16_MAX || *end)
1082 : 0 : rte_exit(EXIT_FAILURE,
1083 : : "Invalid destination UDP port: %s\n",
1084 : : dst);
1085 : 0 : tx_udp_dst_port = n;
1086 : : } else {
1087 : 0 : tx_udp_dst_port = n;
1088 : : }
1089 : : break;
1090 : : }
1091 : 0 : case TESTPMD_OPT_NB_PORTS_NUM:
1092 : 0 : n = atoi(optarg);
1093 : 0 : if (n > 0 && n <= nb_ports)
1094 : 0 : nb_fwd_ports = n;
1095 : : else
1096 : 0 : rte_exit(EXIT_FAILURE,
1097 : : "Invalid port %d\n", n);
1098 : 0 : break;
1099 : 0 : case TESTPMD_OPT_NB_CORES_NUM:
1100 : 0 : n = atoi(optarg);
1101 : 0 : if (n > 0 && (lcoreid_t)n <= nb_lcores)
1102 : 0 : nb_fwd_lcores = (lcoreid_t) n;
1103 : : else
1104 : 0 : rte_exit(EXIT_FAILURE,
1105 : : "nb-cores should be > 0 and <= %d\n",
1106 : : nb_lcores);
1107 : 0 : break;
1108 : 0 : case TESTPMD_OPT_COREMASK_NUM:
1109 : 0 : parse_fwd_coremask(optarg);
1110 : 0 : break;
1111 : 0 : case TESTPMD_OPT_PORTMASK_NUM:
1112 : 0 : parse_fwd_portmask(optarg);
1113 : 0 : break;
1114 : 0 : case TESTPMD_OPT_PORTLIST_NUM:
1115 : 0 : parse_fwd_portlist(optarg);
1116 : 0 : break;
1117 : 0 : case TESTPMD_OPT_NO_NUMA_NUM:
1118 : 0 : numa_support = 0;
1119 : 0 : break;
1120 : 0 : case TESTPMD_OPT_NUMA_NUM:
1121 : 0 : numa_support = 1;
1122 : 0 : break;
1123 : 0 : case TESTPMD_OPT_MP_ANON_NUM:
1124 : 0 : mp_alloc_type = MP_ALLOC_ANON;
1125 : 0 : break;
1126 : 0 : case TESTPMD_OPT_MP_ALLOC_NUM:
1127 : 0 : if (!strcmp(optarg, "native"))
1128 : 0 : mp_alloc_type = MP_ALLOC_NATIVE;
1129 : 0 : else if (!strcmp(optarg, "anon"))
1130 : 0 : mp_alloc_type = MP_ALLOC_ANON;
1131 : 0 : else if (!strcmp(optarg, "xmem"))
1132 : 0 : mp_alloc_type = MP_ALLOC_XMEM;
1133 : 0 : else if (!strcmp(optarg, "xmemhuge"))
1134 : 0 : mp_alloc_type = MP_ALLOC_XMEM_HUGE;
1135 : 0 : else if (!strcmp(optarg, "xbuf"))
1136 : 0 : mp_alloc_type = MP_ALLOC_XBUF;
1137 : : else
1138 : 0 : rte_exit(EXIT_FAILURE,
1139 : : "mp-alloc %s invalid - must be: "
1140 : : "native, anon, xmem or xmemhuge\n",
1141 : : optarg);
1142 : : break;
1143 : 0 : case TESTPMD_OPT_PORT_NUMA_CONFIG_NUM:
1144 : 0 : if (parse_portnuma_config(optarg))
1145 : 0 : rte_exit(EXIT_FAILURE,
1146 : : "invalid port-numa configuration\n");
1147 : : break;
1148 : 0 : case TESTPMD_OPT_RING_NUMA_CONFIG_NUM:
1149 : 0 : if (parse_ringnuma_config(optarg))
1150 : 0 : rte_exit(EXIT_FAILURE,
1151 : : "invalid ring-numa configuration\n");
1152 : : break;
1153 : 0 : case TESTPMD_OPT_SOCKET_NUM_NUM:
1154 : 0 : n = atoi(optarg);
1155 : 0 : if (!new_socket_id((uint8_t)n)) {
1156 : 0 : socket_num = (uint8_t)n;
1157 : : } else {
1158 : 0 : print_invalid_socket_id_error();
1159 : 0 : rte_exit(EXIT_FAILURE,
1160 : : "Invalid socket id");
1161 : : }
1162 : 0 : break;
1163 : 0 : case TESTPMD_OPT_MBUF_SIZE_NUM: {
1164 : : unsigned int mb_sz[MAX_SEGS_BUFFER_SPLIT];
1165 : : unsigned int nb_segs, i;
1166 : :
1167 : 0 : nb_segs = parse_item_list(optarg, "mbuf-size",
1168 : : MAX_SEGS_BUFFER_SPLIT, mb_sz, 0);
1169 : 0 : if (nb_segs <= 0)
1170 : 0 : rte_exit(EXIT_FAILURE,
1171 : : "bad mbuf-size\n");
1172 : 0 : for (i = 0; i < nb_segs; i++) {
1173 : 0 : if (mb_sz[i] <= 0 || mb_sz[i] > 0xFFFF)
1174 : 0 : rte_exit(EXIT_FAILURE,
1175 : : "mbuf-size should be "
1176 : : "> 0 and < 65536\n");
1177 : 0 : mbuf_data_size[i] = (uint16_t) mb_sz[i];
1178 : : }
1179 : 0 : mbuf_data_size_n = nb_segs;
1180 : : break;
1181 : : }
1182 : 0 : case TESTPMD_OPT_TOTAL_NUM_MBUFS_NUM:
1183 : 0 : n = atoi(optarg);
1184 : 0 : if (n > MIN_TOTAL_NUM_MBUFS)
1185 : 0 : param_total_num_mbufs = (unsigned int)n;
1186 : : else
1187 : 0 : rte_exit(EXIT_FAILURE,
1188 : : "total-num-mbufs should be > %d\n",
1189 : : MIN_TOTAL_NUM_MBUFS);
1190 : 0 : break;
1191 : 0 : case TESTPMD_OPT_MAX_PKT_LEN_NUM:
1192 : 0 : n = atoi(optarg);
1193 : 0 : if (n >= RTE_ETHER_MIN_LEN)
1194 : 0 : max_rx_pkt_len = n;
1195 : : else
1196 : 0 : rte_exit(EXIT_FAILURE,
1197 : : "Invalid max-pkt-len=%d - should be > %d\n",
1198 : : n, RTE_ETHER_MIN_LEN);
1199 : 0 : break;
1200 : 0 : case TESTPMD_OPT_MAX_LRO_PKT_SIZE_NUM:
1201 : 0 : n = atoi(optarg);
1202 : 0 : rx_mode.max_lro_pkt_size = (uint32_t) n;
1203 : 0 : break;
1204 : : #ifdef RTE_LIB_LATENCYSTATS
1205 : 0 : case TESTPMD_OPT_LATENCYSTATS_NUM:
1206 : 0 : n = atoi(optarg);
1207 : 0 : if (n >= 0) {
1208 : 0 : latencystats_lcore_id = (lcoreid_t) n;
1209 : 0 : latencystats_enabled = 1;
1210 : : } else
1211 : 0 : rte_exit(EXIT_FAILURE,
1212 : : "invalid lcore id %d for latencystats"
1213 : : " must be >= 0\n", n);
1214 : :
1215 : 0 : break;
1216 : : #endif
1217 : : #ifdef RTE_LIB_BITRATESTATS
1218 : 0 : case TESTPMD_OPT_BITRATE_STATS_NUM:
1219 : 0 : n = atoi(optarg);
1220 : 0 : if (n >= 0) {
1221 : 0 : bitrate_lcore_id = (lcoreid_t) n;
1222 : 0 : bitrate_enabled = 1;
1223 : : } else
1224 : 0 : rte_exit(EXIT_FAILURE,
1225 : : "invalid lcore id %d for bitrate stats"
1226 : : " must be >= 0\n", n);
1227 : 0 : break;
1228 : : #endif
1229 : 0 : case TESTPMD_OPT_DISABLE_CRC_STRIP_NUM:
1230 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_KEEP_CRC;
1231 : 0 : break;
1232 : 0 : case TESTPMD_OPT_ENABLE_LRO_NUM:
1233 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_TCP_LRO;
1234 : 0 : break;
1235 : 0 : case TESTPMD_OPT_ENABLE_SCATTER_NUM:
1236 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_SCATTER;
1237 : 0 : break;
1238 : 0 : case TESTPMD_OPT_ENABLE_RX_CKSUM_NUM:
1239 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_CHECKSUM;
1240 : 0 : break;
1241 : 0 : case TESTPMD_OPT_ENABLE_RX_TIMESTAMP_NUM:
1242 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_TIMESTAMP;
1243 : 0 : break;
1244 : 0 : case TESTPMD_OPT_ENABLE_HW_VLAN_NUM:
1245 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_VLAN;
1246 : 0 : break;
1247 : 0 : case TESTPMD_OPT_ENABLE_HW_VLAN_FILTER_NUM:
1248 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_VLAN_FILTER;
1249 : 0 : break;
1250 : 0 : case TESTPMD_OPT_ENABLE_HW_VLAN_STRIP_NUM:
1251 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_VLAN_STRIP;
1252 : 0 : break;
1253 : 0 : case TESTPMD_OPT_ENABLE_HW_VLAN_EXTEND_NUM:
1254 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_VLAN_EXTEND;
1255 : 0 : break;
1256 : 0 : case TESTPMD_OPT_ENABLE_HW_QINQ_STRIP_NUM:
1257 : 0 : rx_offloads |= RTE_ETH_RX_OFFLOAD_QINQ_STRIP;
1258 : 0 : break;
1259 : 0 : case TESTPMD_OPT_ENABLE_DROP_EN_NUM:
1260 : 0 : rx_drop_en = 1;
1261 : 0 : break;
1262 : 0 : case TESTPMD_OPT_DISABLE_RSS_NUM:
1263 : 0 : if (force_rss)
1264 : 0 : rte_exit(EXIT_FAILURE, "Invalid option combination, %s and %s\n",
1265 : : TESTPMD_OPT_DISABLE_RSS, TESTPMD_OPT_ENABLE_RSS);
1266 : 0 : rss_hf = 0;
1267 : 0 : break;
1268 : 0 : case TESTPMD_OPT_ENABLE_RSS_NUM:
1269 : 0 : if (rss_hf == 0)
1270 : 0 : rte_exit(EXIT_FAILURE, "Invalid option combination, %s and %s\n",
1271 : : TESTPMD_OPT_DISABLE_RSS, TESTPMD_OPT_ENABLE_RSS);
1272 : 0 : force_rss = true;
1273 : 0 : break;
1274 : 0 : case TESTPMD_OPT_PORT_TOPOLOGY_NUM:
1275 : 0 : if (!strcmp(optarg, "paired"))
1276 : 0 : port_topology = PORT_TOPOLOGY_PAIRED;
1277 : 0 : else if (!strcmp(optarg, "chained"))
1278 : 0 : port_topology = PORT_TOPOLOGY_CHAINED;
1279 : 0 : else if (!strcmp(optarg, "loop"))
1280 : 0 : port_topology = PORT_TOPOLOGY_LOOP;
1281 : : else
1282 : 0 : rte_exit(EXIT_FAILURE, "port-topology %s invalid -"
1283 : : " must be: paired, chained or loop\n",
1284 : : optarg);
1285 : : break;
1286 : 0 : case TESTPMD_OPT_FORWARD_MODE_NUM:
1287 : 0 : set_pkt_forwarding_mode(optarg);
1288 : 0 : break;
1289 : 0 : case TESTPMD_OPT_RSS_IP_NUM:
1290 : 0 : rss_hf = RTE_ETH_RSS_IP;
1291 : 0 : break;
1292 : 0 : case TESTPMD_OPT_RSS_UDP_NUM:
1293 : 0 : rss_hf = RTE_ETH_RSS_UDP;
1294 : 0 : break;
1295 : 0 : case TESTPMD_OPT_RSS_LEVEL_INNER_NUM:
1296 : 0 : rss_hf |= RTE_ETH_RSS_LEVEL_INNERMOST;
1297 : 0 : break;
1298 : 0 : case TESTPMD_OPT_RSS_LEVEL_OUTER_NUM:
1299 : 0 : rss_hf |= RTE_ETH_RSS_LEVEL_OUTERMOST;
1300 : 0 : break;
1301 : 0 : case TESTPMD_OPT_RXQ_NUM:
1302 : 0 : n = atoi(optarg);
1303 : 0 : if (n >= 0 && check_nb_rxq((queueid_t)n) == 0)
1304 : 0 : nb_rxq = (queueid_t) n;
1305 : : else
1306 : 0 : rte_exit(EXIT_FAILURE, "rxq %d invalid - must be"
1307 : : " >= 0 && <= %u\n", n,
1308 : 0 : get_allowed_max_nb_rxq(&pid));
1309 : 0 : break;
1310 : 0 : case TESTPMD_OPT_TXQ_NUM:
1311 : 0 : n = atoi(optarg);
1312 : 0 : if (n >= 0 && check_nb_txq((queueid_t)n) == 0)
1313 : 0 : nb_txq = (queueid_t) n;
1314 : : else
1315 : 0 : rte_exit(EXIT_FAILURE, "txq %d invalid - must be"
1316 : : " >= 0 && <= %u\n", n,
1317 : 0 : get_allowed_max_nb_txq(&pid));
1318 : 0 : break;
1319 : 0 : case TESTPMD_OPT_HAIRPINQ_NUM:
1320 : 0 : n = atoi(optarg);
1321 : 0 : if (n >= 0 &&
1322 : 0 : check_nb_hairpinq((queueid_t)n) == 0)
1323 : 0 : nb_hairpinq = (queueid_t) n;
1324 : : else
1325 : 0 : rte_exit(EXIT_FAILURE, "txq %d invalid - must be"
1326 : : " >= 0 && <= %u\n", n,
1327 : 0 : get_allowed_max_nb_hairpinq
1328 : : (&pid));
1329 : 0 : if ((n + nb_txq) < 0 ||
1330 : 0 : check_nb_txq((queueid_t)(n + nb_txq)) != 0)
1331 : 0 : rte_exit(EXIT_FAILURE, "txq + hairpinq "
1332 : : "%d invalid - must be"
1333 : : " >= 0 && <= %u\n",
1334 : : n + nb_txq,
1335 : 0 : get_allowed_max_nb_txq(&pid));
1336 : 0 : if ((n + nb_rxq) < 0 ||
1337 : 0 : check_nb_rxq((queueid_t)(n + nb_rxq)) != 0)
1338 : 0 : rte_exit(EXIT_FAILURE, "rxq + hairpinq "
1339 : : "%d invalid - must be"
1340 : : " >= 0 && <= %u\n",
1341 : : n + nb_rxq,
1342 : 0 : get_allowed_max_nb_rxq(&pid));
1343 : : break;
1344 : 0 : case TESTPMD_OPT_HAIRPIN_MODE_NUM: {
1345 : 0 : char *end = NULL;
1346 : :
1347 : 0 : errno = 0;
1348 : 0 : n = strtoul(optarg, &end, 0);
1349 : 0 : if (errno != 0 || end == optarg)
1350 : 0 : rte_exit(EXIT_FAILURE, "hairpin mode invalid\n");
1351 : : else
1352 : 0 : hairpin_mode = (uint32_t)n;
1353 : : break;
1354 : : }
1355 : 0 : case TESTPMD_OPT_HAIRPIN_MAP_NUM:
1356 : 0 : hairpin_multiport_mode = true;
1357 : 0 : ret = parse_hairpin_map(optarg);
1358 : 0 : if (ret)
1359 : 0 : rte_exit(EXIT_FAILURE, "invalid hairpin map\n");
1360 : : break;
1361 : 0 : case TESTPMD_OPT_BURST_NUM:
1362 : 0 : n = atoi(optarg);
1363 : 0 : if (n == 0) {
1364 : : /* A burst size of zero means that the
1365 : : * PMD should be queried for
1366 : : * recommended Rx burst size. Since
1367 : : * testpmd uses a single size for all
1368 : : * ports, port 0 is queried for the
1369 : : * value, on the assumption that all
1370 : : * ports are of the same NIC model.
1371 : : */
1372 : 0 : ret = eth_dev_info_get_print_err(
1373 : : 0,
1374 : : &dev_info);
1375 : 0 : if (ret != 0)
1376 : 0 : rte_exit(EXIT_FAILURE, "Failed to get driver "
1377 : : "recommended burst size, please provide a "
1378 : : "value between 1 and %d\n", MAX_PKT_BURST);
1379 : :
1380 : 0 : rec_nb_pkts = dev_info
1381 : : .default_rxportconf.burst_size;
1382 : :
1383 : 0 : if (rec_nb_pkts == 0)
1384 : 0 : rte_exit(EXIT_FAILURE,
1385 : : "PMD does not recommend a burst size. "
1386 : : "Provided value must be between "
1387 : : "1 and %d\n", MAX_PKT_BURST);
1388 : 0 : else if (rec_nb_pkts > MAX_PKT_BURST)
1389 : 0 : rte_exit(EXIT_FAILURE,
1390 : : "PMD recommended burst size of %d"
1391 : : " exceeds maximum value of %d\n",
1392 : : rec_nb_pkts, MAX_PKT_BURST);
1393 : 0 : printf("Using PMD-provided burst value of %d\n",
1394 : : rec_nb_pkts);
1395 : 0 : nb_pkt_per_burst = rec_nb_pkts;
1396 : 0 : } else if (n > MAX_PKT_BURST)
1397 : 0 : rte_exit(EXIT_FAILURE,
1398 : : "burst must be between1 and %d\n",
1399 : : MAX_PKT_BURST);
1400 : : else
1401 : 0 : nb_pkt_per_burst = (uint16_t) n;
1402 : : break;
1403 : 0 : case TESTPMD_OPT_FLOWGEN_CLONES_NUM:
1404 : 0 : n = atoi(optarg);
1405 : 0 : if (n >= 0)
1406 : 0 : nb_pkt_flowgen_clones = (uint16_t) n;
1407 : : else
1408 : 0 : rte_exit(EXIT_FAILURE,
1409 : : "clones must be >= 0 and <= current burst\n");
1410 : 0 : break;
1411 : 0 : case TESTPMD_OPT_FLOWGEN_FLOWS_NUM:
1412 : 0 : n = atoi(optarg);
1413 : 0 : if (n > 0)
1414 : 0 : nb_flows_flowgen = (int) n;
1415 : : else
1416 : 0 : rte_exit(EXIT_FAILURE,
1417 : : "flows must be >= 1\n");
1418 : 0 : break;
1419 : 0 : case TESTPMD_OPT_MBCACHE_NUM:
1420 : 0 : n = atoi(optarg);
1421 : 0 : if ((n >= 0) &&
1422 : : (n <= RTE_MEMPOOL_CACHE_MAX_SIZE))
1423 : 0 : mb_mempool_cache = (uint16_t) n;
1424 : : else
1425 : 0 : rte_exit(EXIT_FAILURE,
1426 : : "mbcache must be >= 0 and <= %d\n",
1427 : : RTE_MEMPOOL_CACHE_MAX_SIZE);
1428 : 0 : break;
1429 : 0 : case TESTPMD_OPT_TXFREET_NUM:
1430 : 0 : n = atoi(optarg);
1431 : 0 : if (n >= 0)
1432 : 0 : tx_free_thresh = (int16_t)n;
1433 : : else
1434 : 0 : rte_exit(EXIT_FAILURE, "txfreet must be >= 0\n");
1435 : 0 : break;
1436 : 0 : case TESTPMD_OPT_TXRST_NUM:
1437 : 0 : n = atoi(optarg);
1438 : 0 : if (n >= 0)
1439 : 0 : tx_rs_thresh = (int16_t)n;
1440 : : else
1441 : 0 : rte_exit(EXIT_FAILURE, "txrst must be >= 0\n");
1442 : 0 : break;
1443 : 0 : case TESTPMD_OPT_RXD_NUM:
1444 : 0 : n = atoi(optarg);
1445 : 0 : if (n > 0) {
1446 : 0 : if (rx_free_thresh >= n)
1447 : 0 : rte_exit(EXIT_FAILURE,
1448 : : "rxd must be > "
1449 : : "rx_free_thresh(%d)\n",
1450 : : (int)rx_free_thresh);
1451 : : else
1452 : 0 : nb_rxd = (uint16_t) n;
1453 : : } else
1454 : 0 : rte_exit(EXIT_FAILURE,
1455 : : "rxd(%d) invalid - must be > 0\n",
1456 : : n);
1457 : 0 : break;
1458 : 0 : case TESTPMD_OPT_TXD_NUM:
1459 : 0 : n = atoi(optarg);
1460 : 0 : if (n > 0)
1461 : 0 : nb_txd = (uint16_t) n;
1462 : : else
1463 : 0 : rte_exit(EXIT_FAILURE, "txd must be in > 0\n");
1464 : 0 : break;
1465 : 0 : case TESTPMD_OPT_TXPT_NUM:
1466 : 0 : n = atoi(optarg);
1467 : 0 : if (n >= 0)
1468 : 0 : tx_pthresh = (int8_t)n;
1469 : : else
1470 : 0 : rte_exit(EXIT_FAILURE, "txpt must be >= 0\n");
1471 : 0 : break;
1472 : 0 : case TESTPMD_OPT_TXHT_NUM:
1473 : 0 : n = atoi(optarg);
1474 : 0 : if (n >= 0)
1475 : 0 : tx_hthresh = (int8_t)n;
1476 : : else
1477 : 0 : rte_exit(EXIT_FAILURE, "txht must be >= 0\n");
1478 : 0 : break;
1479 : 0 : case TESTPMD_OPT_TXWT_NUM:
1480 : 0 : n = atoi(optarg);
1481 : 0 : if (n >= 0)
1482 : 0 : tx_wthresh = (int8_t)n;
1483 : : else
1484 : 0 : rte_exit(EXIT_FAILURE, "txwt must be >= 0\n");
1485 : 0 : break;
1486 : 0 : case TESTPMD_OPT_RXPT_NUM:
1487 : 0 : n = atoi(optarg);
1488 : 0 : if (n >= 0)
1489 : 0 : rx_pthresh = (int8_t)n;
1490 : : else
1491 : 0 : rte_exit(EXIT_FAILURE, "rxpt must be >= 0\n");
1492 : 0 : break;
1493 : 0 : case TESTPMD_OPT_RXHT_NUM:
1494 : 0 : n = atoi(optarg);
1495 : 0 : if (n >= 0)
1496 : 0 : rx_hthresh = (int8_t)n;
1497 : : else
1498 : 0 : rte_exit(EXIT_FAILURE, "rxht must be >= 0\n");
1499 : 0 : break;
1500 : 0 : case TESTPMD_OPT_RXWT_NUM:
1501 : 0 : n = atoi(optarg);
1502 : 0 : if (n >= 0)
1503 : 0 : rx_wthresh = (int8_t)n;
1504 : : else
1505 : 0 : rte_exit(EXIT_FAILURE, "rxwt must be >= 0\n");
1506 : 0 : break;
1507 : 0 : case TESTPMD_OPT_RXFREET_NUM:
1508 : 0 : n = atoi(optarg);
1509 : 0 : if (n >= 0)
1510 : 0 : rx_free_thresh = (int16_t)n;
1511 : : else
1512 : 0 : rte_exit(EXIT_FAILURE, "rxfreet must be >= 0\n");
1513 : 0 : break;
1514 : 0 : case TESTPMD_OPT_RXOFFS_NUM: {
1515 : : unsigned int seg_off[MAX_SEGS_BUFFER_SPLIT];
1516 : : unsigned int nb_offs;
1517 : :
1518 : 0 : nb_offs = parse_item_list
1519 : : (optarg, "rxpkt offsets",
1520 : : MAX_SEGS_BUFFER_SPLIT,
1521 : : seg_off, 0);
1522 : 0 : if (nb_offs > 0)
1523 : 0 : set_rx_pkt_offsets(seg_off, nb_offs);
1524 : : else
1525 : 0 : rte_exit(EXIT_FAILURE, "bad rxoffs\n");
1526 : : break;
1527 : : }
1528 : 0 : case TESTPMD_OPT_RXPKTS_NUM: {
1529 : : unsigned int seg_len[MAX_SEGS_BUFFER_SPLIT];
1530 : : unsigned int nb_segs;
1531 : :
1532 : 0 : nb_segs = parse_item_list
1533 : : (optarg, "rxpkt segments",
1534 : : MAX_SEGS_BUFFER_SPLIT,
1535 : : seg_len, 0);
1536 : 0 : if (nb_segs > 0)
1537 : 0 : set_rx_pkt_segments(seg_len, nb_segs);
1538 : : else
1539 : 0 : rte_exit(EXIT_FAILURE, "bad rxpkts\n");
1540 : : break;
1541 : : }
1542 : 0 : case TESTPMD_OPT_RXHDRS_NUM: {
1543 : : unsigned int seg_hdrs[MAX_SEGS_BUFFER_SPLIT];
1544 : : unsigned int nb_segs;
1545 : :
1546 : 0 : nb_segs = parse_hdrs_list
1547 : : (optarg, "rxpkt segments",
1548 : : MAX_SEGS_BUFFER_SPLIT,
1549 : : seg_hdrs);
1550 : 0 : if (nb_segs > 0)
1551 : 0 : set_rx_pkt_hdrs(seg_hdrs, nb_segs);
1552 : : else
1553 : 0 : rte_exit(EXIT_FAILURE, "bad rxpkts\n");
1554 : : break;
1555 : : }
1556 : 0 : case TESTPMD_OPT_TXPKTS_NUM: {
1557 : : unsigned int seg_lengths[RTE_MAX_SEGS_PER_PKT];
1558 : : unsigned int nb_segs;
1559 : :
1560 : 0 : nb_segs = parse_item_list(optarg, "txpkt segments",
1561 : : RTE_MAX_SEGS_PER_PKT, seg_lengths, 0);
1562 : 0 : if (nb_segs > 0)
1563 : 0 : set_tx_pkt_segments(seg_lengths, nb_segs);
1564 : : else
1565 : 0 : rte_exit(EXIT_FAILURE, "bad txpkts\n");
1566 : : break;
1567 : : }
1568 : 0 : case TESTPMD_OPT_MULTI_RX_MEMPOOL_NUM:
1569 : 0 : multi_rx_mempool = 1;
1570 : 0 : break;
1571 : 0 : case TESTPMD_OPT_TXONLY_MULTI_FLOW_NUM:
1572 : 0 : txonly_multi_flow = 1;
1573 : 0 : break;
1574 : 0 : case TESTPMD_OPT_TXONLY_FLOWS_NUM:
1575 : 0 : n = atoi(optarg);
1576 : 0 : if (n >= 1 && n <= 64)
1577 : 0 : txonly_flows = (uint16_t)n;
1578 : : else
1579 : 0 : rte_exit(EXIT_FAILURE, "txonly-flows must be >= 1 and <= 64\n");
1580 : 0 : break;
1581 : 0 : case TESTPMD_OPT_RXQ_SHARE_NUM:
1582 : 0 : rxq_share = 1;
1583 : 0 : break;
1584 : 0 : case TESTPMD_OPT_NO_FLUSH_RX_NUM:
1585 : 0 : no_flush_rx = 1;
1586 : 0 : break;
1587 : 0 : case TESTPMD_OPT_ETH_LINK_SPEED_NUM:
1588 : 0 : n = atoi(optarg);
1589 : 0 : if (n >= 0 && parse_link_speed(n) > 0)
1590 : 0 : eth_link_speed = parse_link_speed(n);
1591 : : break;
1592 : 0 : case TESTPMD_OPT_DISABLE_LINK_CHECK_NUM:
1593 : 0 : no_link_check = 1;
1594 : 0 : break;
1595 : 0 : case TESTPMD_OPT_DISABLE_DEVICE_START_NUM:
1596 : 0 : no_device_start = 1;
1597 : 0 : break;
1598 : 0 : case TESTPMD_OPT_NO_LSC_INTERRUPT_NUM:
1599 : 0 : lsc_interrupt = 0;
1600 : 0 : break;
1601 : 0 : case TESTPMD_OPT_NO_RMV_INTERRUPT_NUM:
1602 : 0 : rmv_interrupt = 0;
1603 : 0 : break;
1604 : 0 : case TESTPMD_OPT_FLOW_ISOLATE_ALL_NUM:
1605 : 0 : flow_isolate_all = 1;
1606 : 0 : break;
1607 : 0 : case TESTPMD_OPT_DISABLE_FLOW_FLUSH_NUM:
1608 : 0 : no_flow_flush = 1;
1609 : 0 : break;
1610 : 0 : case TESTPMD_OPT_TX_OFFLOADS_NUM: {
1611 : 0 : char *end = NULL;
1612 : :
1613 : 0 : n = strtoull(optarg, &end, 16);
1614 : 0 : if (n >= 0)
1615 : 0 : tx_offloads = (uint64_t)n;
1616 : : else
1617 : 0 : rte_exit(EXIT_FAILURE,
1618 : : "tx-offloads must be >= 0\n");
1619 : : break;
1620 : : }
1621 : 0 : case TESTPMD_OPT_RX_OFFLOADS_NUM: {
1622 : 0 : char *end = NULL;
1623 : :
1624 : 0 : n = strtoull(optarg, &end, 16);
1625 : 0 : if (n >= 0)
1626 : 0 : rx_offloads = (uint64_t)n;
1627 : : else
1628 : 0 : rte_exit(EXIT_FAILURE,
1629 : : "rx-offloads must be >= 0\n");
1630 : : break;
1631 : : }
1632 : 0 : case TESTPMD_OPT_VXLAN_GPE_PORT_NUM:
1633 : 0 : n = atoi(optarg);
1634 : 0 : if (n >= 0)
1635 : 0 : vxlan_gpe_udp_port = (uint16_t)n;
1636 : : else
1637 : 0 : rte_exit(EXIT_FAILURE,
1638 : : "vxlan-gpe-port must be >= 0\n");
1639 : 0 : break;
1640 : 0 : case TESTPMD_OPT_GENEVE_PARSED_PORT_NUM:
1641 : 0 : n = atoi(optarg);
1642 : 0 : if (n >= 0)
1643 : 0 : geneve_udp_port = (uint16_t)n;
1644 : : else
1645 : 0 : rte_exit(EXIT_FAILURE,
1646 : : "geneve-parsed-port must be >= 0\n");
1647 : 0 : break;
1648 : 0 : case TESTPMD_OPT_PRINT_EVENT_NUM:
1649 : 0 : if (parse_event_printing_config(optarg, 1)) {
1650 : 0 : rte_exit(EXIT_FAILURE,
1651 : : "invalid print-event argument\n");
1652 : : }
1653 : : break;
1654 : 0 : case TESTPMD_OPT_MASK_EVENT_NUM:
1655 : 0 : if (parse_event_printing_config(optarg, 0)) {
1656 : 0 : rte_exit(EXIT_FAILURE,
1657 : : "invalid mask-event argument\n");
1658 : : }
1659 : : break;
1660 : 0 : case TESTPMD_OPT_HOT_PLUG_NUM:
1661 : 0 : hot_plug = 1;
1662 : 0 : break;
1663 : 0 : case TESTPMD_OPT_MLOCKALL_NUM:
1664 : 0 : do_mlockall = 1;
1665 : 0 : break;
1666 : 0 : case TESTPMD_OPT_NO_MLOCKALL_NUM:
1667 : 0 : do_mlockall = 0;
1668 : 0 : break;
1669 : 0 : case TESTPMD_OPT_NOISY_TX_SW_BUFFER_SIZE_NUM:
1670 : 0 : n = atoi(optarg);
1671 : 0 : if (n >= 0)
1672 : 0 : noisy_tx_sw_bufsz = n;
1673 : : else
1674 : 0 : rte_exit(EXIT_FAILURE,
1675 : : "noisy-tx-sw-buffer-size must be >= 0\n");
1676 : 0 : break;
1677 : 0 : case TESTPMD_OPT_NOISY_TX_SW_BUFFER_FLUSHTIME_NUM:
1678 : 0 : n = atoi(optarg);
1679 : 0 : if (n >= 0)
1680 : 0 : noisy_tx_sw_buf_flush_time = n;
1681 : : else
1682 : 0 : rte_exit(EXIT_FAILURE,
1683 : : "noisy-tx-sw-buffer-flushtime must be >= 0\n");
1684 : 0 : break;
1685 : 0 : case TESTPMD_OPT_NOISY_LKUP_MEMORY_NUM:
1686 : 0 : n = atoi(optarg);
1687 : 0 : if (n >= 0)
1688 : 0 : noisy_lkup_mem_sz = n;
1689 : : else
1690 : 0 : rte_exit(EXIT_FAILURE,
1691 : : "noisy-lkup-memory must be >= 0\n");
1692 : 0 : break;
1693 : 0 : case TESTPMD_OPT_NOISY_LKUP_NUM_WRITES_NUM:
1694 : 0 : n = atoi(optarg);
1695 : 0 : if (n >= 0)
1696 : 0 : noisy_lkup_num_writes = n;
1697 : : else
1698 : 0 : rte_exit(EXIT_FAILURE,
1699 : : "noisy-lkup-num-writes must be >= 0\n");
1700 : 0 : break;
1701 : 0 : case TESTPMD_OPT_NOISY_LKUP_NUM_READS_NUM:
1702 : 0 : n = atoi(optarg);
1703 : 0 : if (n >= 0)
1704 : 0 : noisy_lkup_num_reads = n;
1705 : : else
1706 : 0 : rte_exit(EXIT_FAILURE,
1707 : : "noisy-lkup-num-reads must be >= 0\n");
1708 : 0 : break;
1709 : 0 : case TESTPMD_OPT_NOISY_LKUP_NUM_READS_WRITES_NUM:
1710 : 0 : n = atoi(optarg);
1711 : 0 : if (n >= 0)
1712 : 0 : noisy_lkup_num_reads_writes = n;
1713 : : else
1714 : 0 : rte_exit(EXIT_FAILURE,
1715 : : "noisy-lkup-num-reads-writes must be >= 0\n");
1716 : 0 : break;
1717 : : case TESTPMD_OPT_NOISY_FORWARD_MODE_NUM: {
1718 : : unsigned int i;
1719 : :
1720 : 0 : for (i = 0; i < NOISY_FWD_MODE_MAX; i++) {
1721 : 0 : if (!strcmp(optarg, noisy_fwd_mode_desc[i])) {
1722 : 0 : noisy_fwd_mode = i;
1723 : 0 : break;
1724 : : }
1725 : : }
1726 : 0 : if (i == NOISY_FWD_MODE_MAX)
1727 : 0 : rte_exit(EXIT_FAILURE, "noisy-forward-mode %s invalid,"
1728 : : " must be a valid noisy-forward-mode value\n",
1729 : : optarg);
1730 : : break;
1731 : : }
1732 : 0 : case TESTPMD_OPT_NO_IOVA_CONTIG_NUM:
1733 : 0 : mempool_flags = RTE_MEMPOOL_F_NO_IOVA_CONTIG;
1734 : 0 : break;
1735 : 0 : case TESTPMD_OPT_RX_MQ_MODE_NUM: {
1736 : 0 : char *end = NULL;
1737 : :
1738 : 0 : n = strtoul(optarg, &end, 16);
1739 : 0 : if (n >= 0 && n <= RTE_ETH_MQ_RX_VMDQ_DCB_RSS)
1740 : 0 : rx_mq_mode = (enum rte_eth_rx_mq_mode)n;
1741 : : else
1742 : 0 : rte_exit(EXIT_FAILURE,
1743 : : "rx-mq-mode must be >= 0 and <= %d\n",
1744 : : RTE_ETH_MQ_RX_VMDQ_DCB_RSS);
1745 : : break;
1746 : : }
1747 : 0 : case TESTPMD_OPT_RECORD_CORE_CYCLES_NUM:
1748 : 0 : record_core_cycles = 1;
1749 : 0 : break;
1750 : 0 : case TESTPMD_OPT_RECORD_BURST_STATS_NUM:
1751 : 0 : record_burst_stats = 1;
1752 : 0 : break;
1753 : 0 : case TESTPMD_OPT_NUM_PROCS_NUM:
1754 : 0 : num_procs = atoi(optarg);
1755 : 0 : break;
1756 : 0 : case TESTPMD_OPT_PROC_ID_NUM:
1757 : 0 : proc_id = atoi(optarg);
1758 : 0 : break;
1759 : 0 : default:
1760 : 0 : usage(argv[0]);
1761 : 0 : fprintf(stderr, "Invalid option: %s\n", argv[optind - 1]);
1762 : 0 : rte_exit(EXIT_FAILURE,
1763 : : "Command line is incomplete or incorrect\n");
1764 : : break;
1765 : : }
1766 : : }
1767 : :
1768 : 0 : if (optind != argc) {
1769 : 0 : usage(argv[0]);
1770 : 0 : fprintf(stderr, "Invalid parameter: %s\n", argv[optind]);
1771 : 0 : rte_exit(EXIT_FAILURE, "Command line is incorrect\n");
1772 : : }
1773 : :
1774 : 0 : if (proc_id >= (int)num_procs)
1775 : 0 : rte_exit(EXIT_FAILURE,
1776 : : "The multi-process option '%s(%d)' should be less than '%s(%u)'\n",
1777 : : TESTPMD_OPT_PROC_ID, proc_id,
1778 : : TESTPMD_OPT_NUM_PROCS, num_procs);
1779 : :
1780 : : /* check for multiple segments without scattered flag enabled */
1781 : 0 : if (mbuf_data_size_n > 1 && (rx_offloads & RTE_ETH_RX_OFFLOAD_SCATTER) == 0)
1782 : 0 : TESTPMD_LOG(WARNING, "Warning: multiple mbuf sizes specified but scattered Rx not enabled\n");
1783 : :
1784 : : /* check for max packet size greater than mbuf size, without scatter or multi-seg flags */
1785 : 0 : if (max_rx_pkt_len > mbuf_data_size[0]) {
1786 : 0 : if ((rx_offloads & RTE_ETH_RX_OFFLOAD_SCATTER) == 0)
1787 : 0 : TESTPMD_LOG(WARNING, "Warning: max-pkt-len (%u) is greater than mbuf size (%u) without scattered Rx enabled\n",
1788 : : max_rx_pkt_len, mbuf_data_size[0]);
1789 : 0 : if ((tx_offloads & RTE_ETH_TX_OFFLOAD_MULTI_SEGS) == 0)
1790 : 0 : TESTPMD_LOG(WARNING, "Warning: max-pkt-len (%u) is greater than mbuf size (%u) without multi-segment Tx enabled\n",
1791 : : max_rx_pkt_len, mbuf_data_size[0]);
1792 : : }
1793 : :
1794 : : /* check for scattered Rx enabled without also having multi-segment Tx */
1795 : 0 : if ((rx_offloads & RTE_ETH_RX_OFFLOAD_SCATTER) != 0 &&
1796 : 0 : (tx_offloads & RTE_ETH_TX_OFFLOAD_MULTI_SEGS) == 0) {
1797 : 0 : TESTPMD_LOG(WARNING, "Warning: Scattered RX offload enabled, but TX multi-segment support not enabled.\n");
1798 : 0 : TESTPMD_LOG(WARNING, " Multi-segment packets can be received but not transmitted.\n");
1799 : : }
1800 : :
1801 : : /* Set offload configuration from command line parameters. */
1802 : 0 : rx_mode.offloads = rx_offloads;
1803 : 0 : tx_mode.offloads = tx_offloads;
1804 : :
1805 : 0 : if (mempool_flags & RTE_MEMPOOL_F_NO_IOVA_CONTIG &&
1806 : 0 : mp_alloc_type != MP_ALLOC_ANON) {
1807 : 0 : TESTPMD_LOG(WARNING, "cannot use no-iova-contig without "
1808 : : "mp-alloc=anon. mempool no-iova-contig is "
1809 : : "ignored\n");
1810 : 0 : mempool_flags = 0;
1811 : : }
1812 : 0 : }
|