4 * Copyright(c) 2010-2012 Intel Corporation. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
17 * * Neither the name of Intel Corporation nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40 #include <netinet/in.h>
43 #include <net/socket.h>
47 #include <sys/queue.h>
49 #include <rte_common.h>
51 #include <rte_debug.h>
52 #include <rte_memory.h>
53 #include <rte_memcpy.h>
54 #include <rte_memzone.h>
55 #include <rte_launch.h>
56 #include <rte_cycles.h>
57 #include <rte_tailq.h>
59 #include <rte_per_lcore.h>
60 #include <rte_lcore.h>
61 #include <rte_atomic.h>
62 #include <rte_branch_prediction.h>
64 #include <rte_mempool.h>
66 #include <rte_timer.h>
68 #include <cmdline_rdline.h>
69 #include <cmdline_parse.h>
70 #include <cmdline_parse_ipaddr.h>
71 #include <cmdline_parse_num.h>
72 #include <cmdline_parse_string.h>
79 struct cmd_autotest_result {
80 cmdline_fixed_string_t autotest;
83 static void cmd_autotest_parsed(void *parsed_result,
84 __attribute__((unused)) struct cmdline *cl,
85 __attribute__((unused)) void *data)
87 struct cmd_autotest_result *res = parsed_result;
91 if (!strcmp(res->autotest, "all_autotests"))
94 if (all || !strcmp(res->autotest, "version_autotest"))
95 ret |= test_version();
96 if (all || !strcmp(res->autotest, "eal_fs_autotest"))
98 if (all || !strcmp(res->autotest, "debug_autotest"))
100 if (all || !strcmp(res->autotest, "pci_autotest"))
102 if (all || !strcmp(res->autotest, "prefetch_autotest"))
103 ret |= test_prefetch();
104 if (all || !strcmp(res->autotest, "byteorder_autotest"))
105 ret |= test_byteorder();
106 if (all || !strcmp(res->autotest, "per_lcore_autotest"))
107 ret |= test_per_lcore();
108 if (all || !strcmp(res->autotest, "atomic_autotest"))
109 ret |= test_atomic();
110 if (all || !strcmp(res->autotest, "malloc_autotest"))
111 ret |= test_malloc();
112 if (all || !strcmp(res->autotest, "spinlock_autotest"))
113 ret |= test_spinlock();
114 if (all || !strcmp(res->autotest, "memory_autotest"))
115 ret |= test_memory();
116 if (all || !strcmp(res->autotest, "memzone_autotest"))
117 ret |= test_memzone();
118 if (all || !strcmp(res->autotest, "rwlock_autotest"))
119 ret |= test_rwlock();
120 if (all || !strcmp(res->autotest, "mbuf_autotest"))
122 if (all || !strcmp(res->autotest, "logs_autotest"))
124 if (all || !strcmp(res->autotest, "errno_autotest"))
126 if (all || !strcmp(res->autotest, "hash_autotest"))
128 if (all || !strcmp(res->autotest, "lpm_autotest"))
130 if (all || !strcmp(res->autotest, "cpuflags_autotest"))
131 ret |= test_cpuflags();
132 /* tailq autotest must go after all lpm and hashs tests or any other
133 * tests which need to create tailq objects (ring and mempool are implicitly
134 * created in earlier tests so can go later)
136 if (all || !strcmp(res->autotest, "tailq_autotest"))
138 if (all || !strcmp(res->autotest, "multiprocess_autotest"))
139 ret |= test_mp_secondary();
140 if (all || !strcmp(res->autotest, "memcpy_autotest"))
141 ret |= test_memcpy();
142 if (all || !strcmp(res->autotest, "string_autotest"))
143 ret |= test_string_fns();
144 if (all || !strcmp(res->autotest, "eal_flags_autotest"))
145 ret |= test_eal_flags();
146 if (all || !strcmp(res->autotest, "alarm_autotest"))
148 if (all || !strcmp(res->autotest, "interrupt_autotest"))
149 ret |= test_interrupt();
150 if (all || !strcmp(res->autotest, "cycles_autotest"))
151 ret |= test_cycles();
152 if (all || !strcmp(res->autotest, "ring_autotest"))
154 if (all || !strcmp(res->autotest, "timer_autotest"))
156 if (all || !strcmp(res->autotest, "mempool_autotest"))
157 ret |= test_mempool();
162 printf("Test Failed\n");
166 cmdline_parse_token_string_t cmd_autotest_autotest =
167 TOKEN_STRING_INITIALIZER(struct cmd_autotest_result, autotest,
168 "pci_autotest#memory_autotest#"
169 "per_lcore_autotest#spinlock_autotest#"
170 "rwlock_autotest#atomic_autotest#"
171 "byteorder_autotest#prefetch_autotest#"
172 "cycles_autotest#logs_autotest#"
173 "memzone_autotest#ring_autotest#"
174 "mempool_autotest#mbuf_autotest#"
175 "timer_autotest#malloc_autotest#"
176 "memcpy_autotest#hash_autotest#"
177 "lpm_autotest#debug_autotest#"
178 "errno_autotest#tailq_autotest#"
179 "string_autotest#multiprocess_autotest#"
180 "cpuflags_autotest#eal_flags_autotest#"
181 "alarm_autotest#interrupt_autotest#"
182 "version_autotest#eal_fs_autotest#"
185 cmdline_parse_inst_t cmd_autotest = {
186 .f = cmd_autotest_parsed, /* function to call */
187 .data = NULL, /* 2nd arg of func */
188 .help_str = "launch autotest",
189 .tokens = { /* token list, NULL terminated */
190 (void *)&cmd_autotest_autotest,
197 struct cmd_dump_result {
198 cmdline_fixed_string_t dump;
202 dump_struct_sizes(void)
204 #define DUMP_SIZE(t) printf("sizeof(" #t ") = %u\n", (unsigned)sizeof(t));
205 DUMP_SIZE(struct rte_mbuf);
206 DUMP_SIZE(struct rte_pktmbuf);
207 DUMP_SIZE(struct rte_ctrlmbuf);
208 DUMP_SIZE(struct rte_mempool);
209 DUMP_SIZE(struct rte_ring);
213 static void cmd_dump_parsed(void *parsed_result,
214 __attribute__((unused)) struct cmdline *cl,
215 __attribute__((unused)) void *data)
217 struct cmd_dump_result *res = parsed_result;
219 if (!strcmp(res->dump, "dump_physmem"))
220 rte_dump_physmem_layout();
221 else if (!strcmp(res->dump, "dump_memzone"))
223 else if (!strcmp(res->dump, "dump_log_history"))
224 rte_log_dump_history();
225 else if (!strcmp(res->dump, "dump_struct_sizes"))
227 else if (!strcmp(res->dump, "dump_ring"))
228 rte_ring_list_dump();
229 else if (!strcmp(res->dump, "dump_mempool"))
230 rte_mempool_list_dump();
233 cmdline_parse_token_string_t cmd_dump_dump =
234 TOKEN_STRING_INITIALIZER(struct cmd_dump_result, dump,
235 "dump_physmem#dump_memzone#dump_log_history#"
236 "dump_struct_sizes#dump_ring#dump_mempool");
238 cmdline_parse_inst_t cmd_dump = {
239 .f = cmd_dump_parsed, /* function to call */
240 .data = NULL, /* 2nd arg of func */
241 .help_str = "dump status",
242 .tokens = { /* token list, NULL terminated */
243 (void *)&cmd_dump_dump,
250 struct cmd_dump_one_result {
251 cmdline_fixed_string_t dump;
252 cmdline_fixed_string_t name;
255 static void cmd_dump_one_parsed(void *parsed_result, struct cmdline *cl,
256 __attribute__((unused)) void *data)
258 struct cmd_dump_one_result *res = parsed_result;
260 if (!strcmp(res->dump, "dump_ring")) {
262 r = rte_ring_lookup(res->name);
264 cmdline_printf(cl, "Cannot find ring\n");
269 else if (!strcmp(res->dump, "dump_mempool")) {
270 struct rte_mempool *mp;
271 mp = rte_mempool_lookup(res->name);
273 cmdline_printf(cl, "Cannot find mempool\n");
276 rte_mempool_dump(mp);
280 cmdline_parse_token_string_t cmd_dump_one_dump =
281 TOKEN_STRING_INITIALIZER(struct cmd_dump_one_result, dump,
282 "dump_ring#dump_mempool");
284 cmdline_parse_token_string_t cmd_dump_one_name =
285 TOKEN_STRING_INITIALIZER(struct cmd_dump_one_result, name, NULL);
287 cmdline_parse_inst_t cmd_dump_one = {
288 .f = cmd_dump_one_parsed, /* function to call */
289 .data = NULL, /* 2nd arg of func */
290 .help_str = "dump one ring/mempool: dump_ring|dump_mempool <name>",
291 .tokens = { /* token list, NULL terminated */
292 (void *)&cmd_dump_one_dump,
293 (void *)&cmd_dump_one_name,
300 struct cmd_set_ring_result {
301 cmdline_fixed_string_t set;
302 cmdline_fixed_string_t name;
306 static void cmd_set_ring_parsed(void *parsed_result, struct cmdline *cl,
307 __attribute__((unused)) void *data)
309 struct cmd_set_ring_result *res = parsed_result;
313 r = rte_ring_lookup(res->name);
315 cmdline_printf(cl, "Cannot find ring\n");
319 if (!strcmp(res->set, "set_quota")) {
320 ret = rte_ring_set_bulk_count(r, res->value);
322 cmdline_printf(cl, "Cannot set quota\n");
324 else if (!strcmp(res->set, "set_watermark")) {
325 ret = rte_ring_set_water_mark(r, res->value);
327 cmdline_printf(cl, "Cannot set water mark\n");
331 cmdline_parse_token_string_t cmd_set_ring_set =
332 TOKEN_STRING_INITIALIZER(struct cmd_set_ring_result, set,
333 "set_quota#set_watermark");
335 cmdline_parse_token_string_t cmd_set_ring_name =
336 TOKEN_STRING_INITIALIZER(struct cmd_set_ring_result, name, NULL);
338 cmdline_parse_token_num_t cmd_set_ring_value =
339 TOKEN_NUM_INITIALIZER(struct cmd_set_ring_result, value, UINT32);
341 cmdline_parse_inst_t cmd_set_ring = {
342 .f = cmd_set_ring_parsed, /* function to call */
343 .data = NULL, /* 2nd arg of func */
344 .help_str = "set quota/watermark: "
345 "set_quota|set_watermark <ring_name> <value>",
346 .tokens = { /* token list, NULL terminated */
347 (void *)&cmd_set_ring_set,
348 (void *)&cmd_set_ring_name,
349 (void *)&cmd_set_ring_value,
356 struct cmd_quit_result {
357 cmdline_fixed_string_t quit;
361 cmd_quit_parsed(__attribute__((unused)) void *parsed_result,
363 __attribute__((unused)) void *data)
368 cmdline_parse_token_string_t cmd_quit_quit =
369 TOKEN_STRING_INITIALIZER(struct cmd_quit_result, quit,
372 cmdline_parse_inst_t cmd_quit = {
373 .f = cmd_quit_parsed, /* function to call */
374 .data = NULL, /* 2nd arg of func */
375 .help_str = "exit application",
376 .tokens = { /* token list, NULL terminated */
377 (void *)&cmd_quit_quit,
384 cmdline_parse_ctx_t main_ctx[] = {
385 (cmdline_parse_inst_t *)&cmd_autotest,
386 (cmdline_parse_inst_t *)&cmd_dump,
387 (cmdline_parse_inst_t *)&cmd_dump_one,
388 (cmdline_parse_inst_t *)&cmd_set_ring,
389 (cmdline_parse_inst_t *)&cmd_quit,