X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Fapplication_namespace.c;h=21c1cbc92c62e249556e2f88d4ba8bb7c0429233;hb=dff48db0782444125f68cab14d91e7bb4109286a;hp=c8c5b7edd238500eafd2c5daeb5ba97e5bca1c67;hpb=6c36f53ff0419d27f3e5720a42e0b43d5e7157f0;p=vpp.git diff --git a/src/vnet/session/application_namespace.c b/src/vnet/session/application_namespace.c index c8c5b7edd23..21c1cbc92c6 100644 --- a/src/vnet/session/application_namespace.c +++ b/src/vnet/session/application_namespace.c @@ -248,31 +248,38 @@ u8 * format_app_namespace (u8 * s, va_list * args) { app_namespace_t *app_ns = va_arg (*args, app_namespace_t *); - s = format (s, "%-20v%-20lu%-20u", app_ns->ns_id, app_ns->ns_secret, + s = format (s, "%-20v%-10u%-20lu%-20u", app_ns->ns_id, + app_namespace_index (app_ns), app_ns->ns_secret, app_ns->sw_if_index); return s; } static clib_error_t * -show_app_ns_fn (vlib_main_t * vm, unformat_input_t * input, +show_app_ns_fn (vlib_main_t * vm, unformat_input_t * main_input, vlib_cli_command_t * cmd) { + unformat_input_t _line_input, *line_input = &_line_input; app_namespace_t *app_ns; session_table_t *st; - u8 *ns_id, do_table = 0; + u8 *ns_id, do_table = 0, had_input = 1; session_cli_return_if_not_enabled (); - if (unformat_peek_input (input) != UNFORMAT_END_OF_INPUT) + if (!unformat_user (main_input, unformat_line_input, line_input)) + { + had_input = 0; + goto do_ns_list; + } + + while (unformat_check_input (line_input) != UNFORMAT_END_OF_INPUT) { - if (unformat (input, "table %_%v%_", &ns_id)) + if (unformat (line_input, "table %_%v%_", &ns_id)) do_table = 1; else { - vlib_cli_output (vm, "unknown input [%U]", - format_unformat_error, input); - return clib_error_return (0, "unknown input `%U'", - format_unformat_error, input); + vlib_cli_output (vm, "unknown input [%U]", format_unformat_error, + line_input); + goto done; } } @@ -282,20 +289,21 @@ show_app_ns_fn (vlib_main_t * vm, unformat_input_t * input, if (!app_ns) { vlib_cli_output (vm, "ns %v not found", ns_id); - return 0; + goto done; } st = session_table_get (app_ns->local_table_index); if (!st) { vlib_cli_output (vm, "table for ns %v could not be found", ns_id); - return 0; + goto done; } session_lookup_show_table_entries (vm, st, 0, 1); vec_free (ns_id); - return 0; + goto done; } - vlib_cli_output (vm, "%-20s%-20s%-20s", "Namespace", "Secret", +do_ns_list: + vlib_cli_output (vm, "%-20s%-10s%-20s%-20s", "Namespace", "Index", "Secret", "sw_if_index"); /* *INDENT-OFF* */ @@ -304,6 +312,9 @@ show_app_ns_fn (vlib_main_t * vm, unformat_input_t * input, })); /* *INDENT-ON* */ +done: + if (had_input) + unformat_free (line_input); return 0; }