36 case BFD_TRANSPORT_UDP4:
37 s =
format (s,
"%=10u %-32s %20U %20U\n", bs->
bs_idx,
"IPv4 address",
41 case BFD_TRANSPORT_UDP6:
42 s =
format (s,
"%=10u %-32s %20U %20U\n", bs->
bs_idx,
"IPv6 address",
47 s =
format (s,
"%10s %-32s %20s %20s\n",
"",
"Session state",
50 s =
format (s,
"%10s %-32s %20s %20s\n",
"",
"Diagnostic code",
53 s =
format (s,
"%10s %-32s %20u %20u\n",
"",
"Detect multiplier",
55 s =
format (s,
"%10s %-32s %20u %20llu\n",
"",
56 "Required Min Rx Interval (usec)",
58 s =
format (s,
"%10s %-32s %20u %20u\n",
"",
59 "Desired Min Tx Interval (usec)",
63 format (s,
"%10s %-32s %20u\n",
"",
"Transmit interval",
71 s =
format (s,
"%10s %-32s %20v\n",
"",
"Last control frame tx", tmp);
78 s =
format (s,
"%10s %-32s %20v\n",
"",
"Last control frame rx", tmp);
82 format (s,
"%10s %-32s %20u %20llu\n",
"",
"Min Echo Rx Interval (usec)",
86 s =
format (s,
"%10s %-32s %20u\n",
"",
"Echo transmit interval",
90 s =
format (s,
"%10s %-32s %20v\n",
"",
"Last echo frame tx", tmp);
92 tmp =
format (tmp,
"%.6fs",
96 format (s,
"%10s %-32s %20v\n",
"",
"Last echo frame roundtrip time",
101 s =
format (s,
"%10s %-32s %20s %20s\n",
"",
"Demand mode",
"no",
103 s =
format (s,
"%10s %-32s %20s\n",
"",
"Poll state",
107 s =
format (s,
"%10s %-32s %20u\n",
"",
"Authentication config key ID",
109 s =
format (s,
"%10s %-32s %20u\n",
"",
"Authentication BFD key ID",
111 s =
format (s,
"%10s %-32s %20u %20u\n",
"",
"Sequence number",
127 u8 *s =
format (
NULL,
"%=10s %=25s %=10s\n",
"Configuration Key ID",
128 "Type",
"Use Count");
131 s = format (s,
"%10u %-25s %10u\n", key->conf_key_id,
132 bfd_auth_type_str (key->auth_type), key->use_count);
140 else if (
unformat (input,
"sessions"))
142 u8 *s =
format (
NULL,
"%=10s %=32s %=20s %=20s\n",
"Index",
"Property",
143 "Local value",
"Remote value");
146 s = format (s,
"%U", format_bfd_session_cli, vm, bm, bs);
154 else if (
unformat (input,
"echo-source"))
163 &have_usable_ip6, &ip6);
171 s =
format (s,
"IPv4 address usable as echo source: ");
180 s =
format (s,
"IPv6 address usable as echo source: ");
210 .short_help =
"show bfd [keys|sessions|echo-source]",
221 s = format (s, "%s", c); \ 241 static const u8 keyed_sha1[] =
"keyed-sha1";
242 static const u8 meticulous_keyed_sha1[] =
"meticulous-keyed-sha1";
246 if (
unformat (input,
"conf-key-id %u", &key_id))
253 if (
vec_len (vec_auth_type) ==
sizeof (keyed_sha1) - 1 &&
254 0 == memcmp (vec_auth_type, keyed_sha1,
255 sizeof (keyed_sha1) - 1))
257 auth_type = BFD_AUTH_TYPE_keyed_sha1;
259 else if (
vec_len (vec_auth_type) ==
260 sizeof (meticulous_keyed_sha1) - 1 &&
261 0 == memcmp (vec_auth_type, meticulous_keyed_sha1,
262 sizeof (meticulous_keyed_sha1) - 1))
264 auth_type = BFD_AUTH_TYPE_meticulous_keyed_sha1;
317 .path =
"bfd key set",
318 .short_help =
"bfd key set" 320 " type <keyed-sha1|meticulous-keyed-sha1> " 335 if (!
unformat (input,
"conf-key-id %u", &key_id))
357 .path =
"bfd key del",
358 .short_help =
"bfd key del conf-key-id <id>",
363 #define INTERFACE_STR "interface" 364 #define LOCAL_ADDR_STR "local-addr" 365 #define PEER_ADDR_STR "peer-addr" 366 #define CONF_KEY_ID_STR "conf-key-id" 367 #define BFD_KEY_ID_STR "bfd-key-id" 368 #define DESIRED_MIN_TX_STR "desired-min-tx" 369 #define REQUIRED_MIN_RX_STR "required-min-rx" 370 #define DETECT_MULT_STR "detect-mult" 371 #define ADMIN_STR "admin" 372 #define DELAYED_STR "delayed" 374 static const unsigned mandatory = 1;
375 static const unsigned optional = 0;
377 #define DECLARE(t, n, s, r, ...) \ 381 #define UNFORMAT(t, n, s, r, ...) \ 382 if (unformat (input, s " " __VA_ARGS__, &n)) \ 384 something_parsed = 1; \ 388 #define CHECK_MANDATORY(t, n, s, r, ...) \ 389 if (mandatory == r && !have_##n) \ 391 ret = clib_error_return (0, "Required parameter `%s' missing.", s); \ 400 #define foreach_bfd_cli_udp_session_add_cli_param(F) \ 401 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 402 unformat_vnet_sw_interface, &vnet_main) \ 403 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 404 unformat_ip46_address) \ 405 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 406 unformat_ip46_address) \ 407 F (u32, desired_min_tx, DESIRED_MIN_TX_STR, mandatory, "%u") \ 408 F (u32, required_min_rx, REQUIRED_MIN_RX_STR, mandatory, "%u") \ 409 F (u32, detect_mult, DETECT_MULT_STR, mandatory, "%u") \ 410 F (u32, conf_key_id, CONF_KEY_ID_STR, optional, "%u") \ 411 F (u32, bfd_key_id, BFD_KEY_ID_STR, optional, "%u") 417 int something_parsed = 0;
420 if (!something_parsed)
430 if (1 == have_conf_key_id + have_bfd_key_id)
433 "and `%s' must be either both specified or none",
438 if (detect_mult > 255)
445 if (have_bfd_key_id && bfd_key_id > 255)
455 detect_mult, have_conf_key_id, conf_key_id,
461 "`bfd_add_add_session' API call failed, rv=%d:%U",
472 .path =
"bfd udp session add",
473 .short_help =
"bfd udp session add" 474 " interface <interface>" 475 " local-addr <local-address>" 476 " peer-addr <peer-address>" 477 " desired-min-tx <desired min tx interval>" 478 " required-min-rx <required min rx interval>" 479 " detect-mult <detect multiplier> " 481 " conf-key-id <config key ID>" 482 " bfd-key-id <BFD key ID>" 493 #define foreach_bfd_cli_udp_session_mod_cli_param(F) \ 494 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 495 unformat_vnet_sw_interface, &vnet_main) \ 496 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 497 unformat_ip46_address) \ 498 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 499 unformat_ip46_address) \ 500 F (u32, desired_min_tx, DESIRED_MIN_TX_STR, mandatory, "%u") \ 501 F (u32, required_min_rx, REQUIRED_MIN_RX_STR, mandatory, "%u") \ 502 F (u32, detect_mult, DETECT_MULT_STR, mandatory, "%u") 508 int something_parsed = 0;
511 if (!something_parsed)
521 if (detect_mult > 255)
530 desired_min_tx, required_min_rx, detect_mult);
535 "`bfd_udp_mod_session' API call failed, rv=%d:%U",
546 .path =
"bfd udp session mod",
547 .short_help =
"bfd udp session mod interface" 548 " <interface> local-addr" 549 " <local-address> peer-addr" 550 " <peer-address> desired-min-tx" 551 " <desired min tx interval> required-min-rx" 552 " <required min rx interval> detect-mult" 553 " <detect multiplier> ",
563 #define foreach_bfd_cli_udp_session_del_cli_param(F) \ 564 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 565 unformat_vnet_sw_interface, &vnet_main) \ 566 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 567 unformat_ip46_address) \ 568 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 569 unformat_ip46_address) 575 int something_parsed = 0;
578 if (!something_parsed)
594 "`bfd_udp_del_session' API call failed, rv=%d:%U",
605 .path =
"bfd udp session del",
606 .short_help =
"bfd udp session del interface" 607 " <interface> local-addr" 608 " <local-address> peer-addr" 619 #define foreach_bfd_cli_udp_session_set_flags_cli_param(F) \ 620 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 621 unformat_vnet_sw_interface, &vnet_main) \ 622 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 623 unformat_ip46_address) \ 624 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 625 unformat_ip46_address) \ 626 F (u8 *, admin_up_down_token, ADMIN_STR, mandatory, "%v", \ 627 &admin_up_down_token) 633 int something_parsed = 0;
636 if (!something_parsed)
647 static const char up[] =
"up";
648 static const char down[] =
"down";
649 if (!memcmp (admin_up_down_token, up,
sizeof (up) - 1))
653 else if (!memcmp (admin_up_down_token, down,
sizeof (down) - 1))
665 &peer_addr, admin_up_down);
670 "`bfd_udp_session_set_flags' API call failed, rv=%d:%U",
681 .path =
"bfd udp session set-flags",
682 .short_help =
"bfd udp session set-flags" 683 " interface <interface>" 684 " local-addr <local-address>" 685 " peer-addr <peer-address>" 696 #define foreach_bfd_cli_udp_session_auth_activate_cli_param(F) \ 697 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 698 unformat_vnet_sw_interface, &vnet_main) \ 699 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 700 unformat_ip46_address) \ 701 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 702 unformat_ip46_address) \ 703 F (u8 *, delayed_token, DELAYED_STR, optional, "%v") \ 704 F (u32, conf_key_id, CONF_KEY_ID_STR, mandatory, "%u") \ 705 F (u32, bfd_key_id, BFD_KEY_ID_STR, mandatory, "%u") 711 int something_parsed = 0;
714 if (!something_parsed)
725 if (have_delayed_token)
727 static const char yes[] =
"yes";
728 static const char no[] =
"no";
729 if (!memcmp (delayed_token, yes,
sizeof (yes) - 1))
733 else if (!memcmp (delayed_token, no,
sizeof (no) - 1))
741 "Unrecognized value for `%s' parameter: `%v'",
747 if (have_bfd_key_id && bfd_key_id > 255)
756 bfd_key_id, is_delayed);
761 "`bfd_udp_auth_activate' API call failed, rv=%d:%U",
772 .path =
"bfd udp session auth activate",
773 .short_help =
"bfd udp session auth activate" 774 " interface <interface>" 775 " local-addr <local-address>" 776 " peer-addr <peer-address>" 777 " conf-key-id <config key ID>" 778 " bfd-key-id <BFD key ID>" 779 " [ delayed <yes|no> ]",
788 #define foreach_bfd_cli_udp_session_auth_deactivate_cli_param(F) \ 789 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 790 unformat_vnet_sw_interface, &vnet_main) \ 791 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 792 unformat_ip46_address) \ 793 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 794 unformat_ip46_address) \ 795 F (u8 *, delayed_token, DELAYED_STR, optional, "%v") 801 int something_parsed = 0;
804 if (!something_parsed)
815 if (have_delayed_token)
817 static const char yes[] =
"yes";
818 static const char no[] =
"no";
819 if (!memcmp (delayed_token, yes,
sizeof (yes) - 1))
823 else if (!memcmp (delayed_token, no,
sizeof (no) - 1))
830 0,
"Unrecognized value for `%s' parameter: `%v'",
DELAYED_STR,
837 &peer_addr, is_delayed);
841 0,
"`bfd_udp_auth_deactivate' API call failed, rv=%d:%U", (
int)rv,
852 .path =
"bfd udp session auth deactivate",
853 .short_help =
"bfd udp session auth deactivate" 854 " interface <interface>" 855 " local-addr <local-address>" 856 " peer-addr <peer-address>" 857 "[ delayed <yes|no> ]",
867 #define foreach_bfd_cli_udp_set_echo_source_cli_param(F) \ 868 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 869 unformat_vnet_sw_interface, &vnet_main) 875 int something_parsed = 0;
878 if (!something_parsed)
893 "`bfd_udp_set_echo_source' API call failed, rv=%d:%U",
904 .path =
"bfd udp echo-source set",
905 .short_help =
"bfd udp echo-source set interface <interface>",
918 "`bfd_udp_del_echo_source' API call failed, rv=%d:%U",
927 .path =
"bfd udp echo-source del",
928 .short_help =
"bfd udp echo-source del",
static u8 * format_vnet_api_errno(u8 *s, va_list *args)
u8 curr_bfd_key_id
current key ID sent out in bfd packet
static clib_error_t * bfd_cli_udp_session_mod(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
vnet_api_error_t bfd_udp_mod_session(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr, u32 desired_min_tx_usec, u32 required_min_rx_usec, u8 detect_mult)
modify existing session
static clib_error_t * bfd_cli_key_del(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
u64 echo_last_rx_clocks
timestamp of last echo packet received
static vnet_hw_interface_t * vnet_get_hw_interface(vnet_main_t *vnm, u32 hw_if_index)
bfd_diag_code_e local_diag
local diagnostics
static u64 clib_cpu_time_now(void)
vnet_api_error_t bfd_udp_add_session(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr, u32 desired_min_tx_usec, u32 required_min_rx_usec, u8 detect_mult, u8 is_authenticated, u32 conf_key_id, u8 bfd_key_id)
create a new bfd session
vnet_api_error_t bfd_auth_del_key(u32 conf_key_id)
delete existing authentication key
u64 last_tx_clocks
timestamp of last packet transmitted
static clib_error_t * bfd_cli_udp_session_set_flags(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
u32 remote_seq_number
remote sequence number
vnet_api_error_t bfd_udp_del_echo_source()
unset echo-source interface
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
void bfd_udp_get_echo_source(int *is_set, u32 *sw_if_index, int *have_usable_ip4, ip4_address_t *ip4, int *have_usable_ip6, ip6_address_t *ip6)
get echo source information - used by CLI
#define foreach_bfd_cli_udp_session_auth_activate_cli_param(F)
u32 bfd_clocks_to_usec(const bfd_main_t *bm, u64 clocks)
vnet_api_error_t bfd_udp_del_session(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr)
delete existing session
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
const char * bfd_poll_state_string(bfd_poll_state_e state)
static clib_error_t * bfd_cli_udp_set_echo_source(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
u64 remote_min_rx_usec
remote min rx interval (microseconds)
#define clib_error_return(e, args...)
#define foreach_bfd_cli_udp_set_echo_source_cli_param(F)
vnet_api_error_t bfd_auth_set_key(u32 conf_key_id, u8 auth_type, u8 key_len, const u8 *key)
create or modify bfd authentication key
#define foreach_bfd_cli_udp_session_auth_deactivate_cli_param(F)
#define CHECK_MANDATORY(t, n, s, r,...)
u8 remote_demand
1 if remote system sets demand mode, 0 otherwise
bfd_session_t * sessions
pool of bfd sessions context data
bfd_auth_key_t * auth_keys
pool of authentication keys
bfd_udp_key_t key
key identifying this session
bfd_transport_e transport
transport type for this session
#define foreach_bfd_cli_udp_session_mod_cli_param(F)
u64 echo_last_tx_clocks
timestamp of last echo packet transmitted
bfd_poll_state_e poll_state
state info regarding poll sequence
struct bfd_session_s::@35 auth
authentication information
static clib_error_t * show_bfd(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
static clib_error_t * bfd_cli_udp_session_auth_deactivate(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
#define foreach_bfd_cli_udp_session_set_flags_cli_param(F)
u8 local_detect_mult
configured detect multiplier
#define DECLARE(t, n, s, r,...)
u64 last_rx_clocks
timestamp of last packet received
vnet_api_error_t bfd_udp_session_set_flags(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr, u8 admin_up_down)
set session admin down/up
bfd_diag_code_e remote_diag
remote diagnostics
u64 transmit_interval_clocks
transmit interval
#define foreach_bfd_cli_udp_session_del_cli_param(F)
#define vec_free(V)
Free vector's memory (no header).
u32 config_desired_min_tx_usec
configured desired min tx interval (microseconds)
#define UNFORMAT(t, n, s, r,...)
static vnet_sw_interface_t * vnet_get_sw_interface_safe(vnet_main_t *vnm, u32 sw_if_index)
const char * bfd_diag_code_string(bfd_diag_code_e diag)
static clib_error_t * bfd_cli_udp_session_auth_activate(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
static clib_error_t * bfd_cli_udp_del_echo_source(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
#define foreach_vnet_api_error
#define VLIB_CLI_COMMAND(x,...)
u8 echo
1 is echo function is active, 0 otherwise
u64 remote_desired_min_tx_clocks
remote desired min tx interval (clocks)
vnet_api_error_t bfd_udp_auth_activate(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr, u32 conf_key_id, u8 bfd_key_id, u8 is_delayed)
activate authentication for existing session
u32 conf_key_id
global configuration key ID
bfd_state_e local_state
session state
u64 echo_transmit_interval_clocks
transmit interval for echo packets
u32 local_seq_number
sequence number incremented occasionally or always (if meticulous)
vnet_api_error_t bfd_udp_set_echo_source(u32 loopback_sw_if_index)
set echo-source interface
u32 config_required_min_rx_usec
configured required min rx interval (microseconds)
static clib_error_t * bfd_cli_udp_session_del(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
u32 bs_idx
index in bfd_main.sessions pool
static u8 * format_bfd_session_cli(u8 *s, va_list *args)
u64 remote_min_echo_rx_usec
remote min echo rx interval (microseconds)
bfd_state_e remote_state
remote session state
const char * bfd_state_string(bfd_state_e state)
static clib_error_t * bfd_cli_udp_session_add(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
vnet_api_error_t bfd_udp_auth_deactivate(u32 sw_if_index, const ip46_address_t *local_addr, const ip46_address_t *peer_addr, u8 is_delayed)
deactivate authentication for existing session
bfd_auth_key_t * curr_key
current key in use
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
#define foreach_bfd_cli_udp_session_add_cli_param(F)
static clib_error_t * bfd_cli_key_add(vlib_main_t *vm, unformat_input_t *input, CLIB_UNUSED(vlib_cli_command_t *lmd))
u8 remote_detect_mult
remote detect multiplier
static uword pool_elts(void *v)
Number of active elements in a pool.