2 * Copyright (c) 2015 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
7 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
15 #include <vlib/vlib.h>
16 #include <vlib/unix/unix.h>
20 main (int argc, char *argv[])
22 return vlib_unix_main (argc, argv);
26 main_stub_init (vlib_main_t * vm)
31 unix_physmem_init (vm, /* fail_if_physical_memory_not_present */ 0)))
34 if ((error = vlib_call_init_function (vm, unix_cli_init)))
40 VLIB_INIT_FUNCTION (main_stub_init);
51 format_my_node_frame (u8 * s, va_list * va)
53 vlib_frame_t *f = va_arg (*va, vlib_frame_t *);
54 my_frame_t *g = vlib_frame_args (f);
57 s = format (s, "scalar %d, vector { ", g->scalar);
58 for (i = 0; i < f->n_vectors; i++)
59 s = format (s, "%d, ", g->vector[i]);
66 my_func (vlib_main_t * vm, vlib_node_runtime_t * rt, vlib_frame_t * f)
74 node = vlib_get_node (vm, rt->node_index);
79 vlib_cli_output (vm, "%v: call frame %p %U", node->name,
80 f, format_my_node_frame, f);
82 if (rt->n_next_nodes > 0)
84 vlib_frame_t *next = vlib_get_next_frame (vm, rt, /* next index */ 0);
85 n_left = VLIB_FRAME_SIZE - next->n_vectors;
86 y = vlib_frame_args (next);
92 for (i = 0; i < 5; i++)
98 y->vector[i] = y->scalar + i;
102 vlib_put_next_frame (vm, rt, /* next index */ 0, n_left);
105 vlib_cli_output (vm, "%v: return frame %p", node->name, f);
111 VLIB_REGISTER_NODE (my_node1,static) = {
113 .type = VLIB_NODE_TYPE_INPUT,
115 .scalar_size = sizeof (my_frame_t),
116 .vector_size = STRUCT_SIZE_OF (my_frame_t, vector[0]),
125 VLIB_REGISTER_NODE (my_node2,static) = {
128 .scalar_size = sizeof (my_frame_t),
129 .vector_size = STRUCT_SIZE_OF (my_frame_t, vector[0]),
141 } my_process_completion_type_t;
147 } my_process_event_data_t;
150 format_my_process_event_data (u8 * s, va_list * va)
152 my_process_event_data_t *d = va_arg (*va, my_process_event_data_t *);
153 return format (s, "{ a %d b %.6f}", d->a, d->b);
157 my_proc (vlib_main_t * vm, vlib_node_runtime_t * rt, vlib_frame_t * f)
162 node = vlib_get_node (vm, rt->node_index);
164 vlib_cli_output (vm, "%v: call frame %p", node->name, f);
166 for (i = 0; i < 5; i++)
168 vlib_cli_output (vm, "%v: %d", node->name, i);
169 vlib_process_suspend (vm, 1e0 /* secs */ );
172 vlib_cli_output (vm, "%v: return frame %p", node->name, f);
176 uword n_events_seen, type, *data = 0;
178 for (n_events_seen = 0; n_events_seen < 2;)
180 vlib_process_wait_for_event (vm);
181 type = vlib_process_get_events (vm, &data);
182 n_events_seen += vec_len (data);
183 vlib_cli_output (vm, "%U %v: completion #%d type %d data 0x%wx",
184 format_time_interval, "h:m:s:u",
185 vlib_time_now (vm), node->name, i, type, data[0]);
193 uword n_events_seen, i, type;
194 my_process_event_data_t *data;
195 for (n_events_seen = 0; n_events_seen < 2;)
197 vlib_process_wait_for_event (vm);
198 data = vlib_process_get_event_data (vm, &type);
199 vec_foreach_index (i, data)
201 vlib_cli_output (vm, "%U event type %d data %U",
202 format_time_interval, "h:m:s:u",
203 vlib_time_now (vm), type,
204 format_my_process_event_data, data);
206 n_events_seen += vec_len (data);
207 vlib_process_put_event_data (vm, data);
215 VLIB_REGISTER_NODE (my_proc_node,static) = {
217 .type = VLIB_NODE_TYPE_PROCESS,
223 my_proc_input (vlib_main_t * vm, vlib_node_runtime_t * rt, vlib_frame_t * f)
230 vlib_process_signal_event (vm, my_proc_node.index,
231 i == 1 ? MY_EVENT_TYPE1 : MY_EVENT_TYPE2,
235 my_process_event_data_t *d;
237 d = vlib_process_signal_event_at_time (vm,
246 d->b = vlib_time_now (vm);
250 vlib_node_set_state (vm, rt->node_index, VLIB_NODE_STATE_DISABLED);
256 VLIB_REGISTER_NODE (my_proc_input_node,static) = {
257 .function = my_proc_input,
258 .type = VLIB_NODE_TYPE_INPUT,
259 .name = "my-proc-input",
264 _unformat_farith (unformat_input_t * i, va_list * args)
266 u32 prec = va_arg (*args, u32);
267 f64 *result = va_arg (*args, f64 *);
270 /* Binary operations in from lowest to highest precedence. */
272 "+%U", "-%U", "/%U", "*%U", "^%U",
275 if (prec <= ARRAY_LEN (binops) - 1
276 && unformat_user (i, _unformat_farith, prec + 1, &tmp[0]))
279 for (p = prec; p < ARRAY_LEN (binops); p++)
281 if (unformat (i, binops[p], _unformat_farith, prec + 0, &tmp[1]))
283 switch (binops[p][0])
286 result[0] = tmp[0] + tmp[1];
289 result[0] = tmp[0] - tmp[1];
292 result[0] = tmp[0] / tmp[1];
295 result[0] = tmp[0] * tmp[1];
298 result[0] = pow (tmp[0], tmp[1]);
310 else if (unformat (i, "-%U", _unformat_farith, prec + 0, &tmp[0]))
316 else if (unformat (i, "(%U)", _unformat_farith, 0, &tmp[0]))
322 else if (unformat (i, "%f", result))
330 unformat_farith (unformat_input_t * i, va_list * args)
332 CLIB_UNUSED (vlib_main_t * vm) = va_arg (*args, vlib_main_t *);
333 f64 *result = va_arg (*args, f64 *);
334 return unformat_user (i, _unformat_farith, 0, result);
338 unformat_integer (unformat_input_t * i, va_list * args)
340 CLIB_UNUSED (vlib_main_t * vm) = va_arg (*args, vlib_main_t *);
341 u32 *data = va_arg (*args, u32 *);
342 return unformat (i, "%d", data);
345 static VLIB_CLI_PARSE_RULE (my_parse_rule1) =
347 .name = "decimal_integer",.short_help =
348 "a decimal integer",.unformat_function = unformat_integer,.data_size =
351 static VLIB_CLI_PARSE_RULE (my_parse_rule2) =
353 .name = "float_expression",.short_help =
354 "floating point expression",.unformat_function =
355 unformat_farith,.data_size = sizeof (f64),};
357 static clib_error_t *
358 bar_command (vlib_main_t * vm,
359 unformat_input_t * input, vlib_cli_command_t * cmd)
361 switch (cmd->function_arg)
366 d = vlib_cli_get_parse_rule_result (vm, 0);
367 e = vlib_cli_get_parse_rule_result (vm, 1);
368 vlib_cli_output (vm, "bar2 %d %d", d[0], e[0]);
374 u32 *d = vlib_cli_get_parse_rule_result (vm, 0);
375 vlib_cli_output (vm, "bar1 %d", d[0]);
381 f64 *d = vlib_cli_get_parse_rule_result (vm, 0);
382 vlib_cli_output (vm, "expr %.6f", d[0]);
390 VLIB_CLI_COMMAND (bar_command2, static) = {
391 .path = "bar %decimal_integer",
392 .short_help = "bar1 command",
393 .function = bar_command,
396 VLIB_CLI_COMMAND (bar_command1, static) = {
397 .path = "bar %decimal_integer %decimal_integer",
398 .short_help = "bar2 command",
399 .function = bar_command,
402 VLIB_CLI_COMMAND (bar_command3, static) = {
403 .path = "zap %float_expression",
404 .short_help = "bar3 command",
405 .function = bar_command,
413 * fd.io coding-style-patch-verification: ON
416 * eval: (c-set-style "gnu")