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; \ 389 #define PRAGMA_STR1 \ 390 _Pragma ("GCC diagnostic ignored \"-Wtautological-compare\""); 391 #define PRAGMA_STR2 _Pragma ("GCC diagnostic pop"); 397 #define CHECK_MANDATORY(t, n, s, r, ...) \ 399 if (mandatory == r && !have_##n) \ 402 ret = clib_error_return (0, "Required parameter `%s' missing.", s); \ 411 #define foreach_bfd_cli_udp_session_add_cli_param(F) \ 412 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 413 unformat_vnet_sw_interface, &vnet_main) \ 414 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 415 unformat_ip46_address) \ 416 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 417 unformat_ip46_address) \ 418 F (u32, desired_min_tx, DESIRED_MIN_TX_STR, mandatory, "%u") \ 419 F (u32, required_min_rx, REQUIRED_MIN_RX_STR, mandatory, "%u") \ 420 F (u32, detect_mult, DETECT_MULT_STR, mandatory, "%u") \ 421 F (u32, conf_key_id, CONF_KEY_ID_STR, optional, "%u") \ 422 F (u32, bfd_key_id, BFD_KEY_ID_STR, optional, "%u") 428 int something_parsed = 0;
431 if (!something_parsed)
441 if (1 == have_conf_key_id + have_bfd_key_id)
444 "and `%s' must be either both specified or none",
449 if (detect_mult > 255)
456 if (have_bfd_key_id && bfd_key_id > 255)
466 detect_mult, have_conf_key_id, conf_key_id,
472 "`bfd_add_add_session' API call failed, rv=%d:%U",
483 .path =
"bfd udp session add",
484 .short_help =
"bfd udp session add" 485 " interface <interface>" 486 " local-addr <local-address>" 487 " peer-addr <peer-address>" 488 " desired-min-tx <desired min tx interval>" 489 " required-min-rx <required min rx interval>" 490 " detect-mult <detect multiplier> " 492 " conf-key-id <config key ID>" 493 " bfd-key-id <BFD key ID>" 504 #define foreach_bfd_cli_udp_session_mod_cli_param(F) \ 505 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 506 unformat_vnet_sw_interface, &vnet_main) \ 507 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 508 unformat_ip46_address) \ 509 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 510 unformat_ip46_address) \ 511 F (u32, desired_min_tx, DESIRED_MIN_TX_STR, mandatory, "%u") \ 512 F (u32, required_min_rx, REQUIRED_MIN_RX_STR, mandatory, "%u") \ 513 F (u32, detect_mult, DETECT_MULT_STR, mandatory, "%u") 519 int something_parsed = 0;
522 if (!something_parsed)
532 if (detect_mult > 255)
541 desired_min_tx, required_min_rx, detect_mult);
546 "`bfd_udp_mod_session' API call failed, rv=%d:%U",
557 .path =
"bfd udp session mod",
558 .short_help =
"bfd udp session mod interface" 559 " <interface> local-addr" 560 " <local-address> peer-addr" 561 " <peer-address> desired-min-tx" 562 " <desired min tx interval> required-min-rx" 563 " <required min rx interval> detect-mult" 564 " <detect multiplier> ",
574 #define foreach_bfd_cli_udp_session_del_cli_param(F) \ 575 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 576 unformat_vnet_sw_interface, &vnet_main) \ 577 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 578 unformat_ip46_address) \ 579 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 580 unformat_ip46_address) 586 int something_parsed = 0;
589 if (!something_parsed)
605 "`bfd_udp_del_session' API call failed, rv=%d:%U",
616 .path =
"bfd udp session del",
617 .short_help =
"bfd udp session del interface" 618 " <interface> local-addr" 619 " <local-address> peer-addr" 630 #define foreach_bfd_cli_udp_session_set_flags_cli_param(F) \ 631 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 632 unformat_vnet_sw_interface, &vnet_main) \ 633 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 634 unformat_ip46_address) \ 635 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 636 unformat_ip46_address) \ 637 F (u8 *, admin_up_down_token, ADMIN_STR, mandatory, "%v", \ 638 &admin_up_down_token) 644 int something_parsed = 0;
647 if (!something_parsed)
658 static const char up[] =
"up";
659 static const char down[] =
"down";
660 if (!memcmp (admin_up_down_token, up,
sizeof (up) - 1))
664 else if (!memcmp (admin_up_down_token, down,
sizeof (down) - 1))
676 &peer_addr, admin_up_down);
681 "`bfd_udp_session_set_flags' API call failed, rv=%d:%U",
692 .path =
"bfd udp session set-flags",
693 .short_help =
"bfd udp session set-flags" 694 " interface <interface>" 695 " local-addr <local-address>" 696 " peer-addr <peer-address>" 707 #define foreach_bfd_cli_udp_session_auth_activate_cli_param(F) \ 708 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 709 unformat_vnet_sw_interface, &vnet_main) \ 710 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 711 unformat_ip46_address) \ 712 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 713 unformat_ip46_address) \ 714 F (u8 *, delayed_token, DELAYED_STR, optional, "%v") \ 715 F (u32, conf_key_id, CONF_KEY_ID_STR, mandatory, "%u") \ 716 F (u32, bfd_key_id, BFD_KEY_ID_STR, mandatory, "%u") 722 int something_parsed = 0;
725 if (!something_parsed)
736 if (have_delayed_token)
738 static const char yes[] =
"yes";
739 static const char no[] =
"no";
740 if (!memcmp (delayed_token, yes,
sizeof (yes) - 1))
744 else if (!memcmp (delayed_token, no,
sizeof (no) - 1))
752 "Unrecognized value for `%s' parameter: `%v'",
758 if (have_bfd_key_id && bfd_key_id > 255)
767 bfd_key_id, is_delayed);
772 "`bfd_udp_auth_activate' API call failed, rv=%d:%U",
783 .path =
"bfd udp session auth activate",
784 .short_help =
"bfd udp session auth activate" 785 " interface <interface>" 786 " local-addr <local-address>" 787 " peer-addr <peer-address>" 788 " conf-key-id <config key ID>" 789 " bfd-key-id <BFD key ID>" 790 " [ delayed <yes|no> ]",
799 #define foreach_bfd_cli_udp_session_auth_deactivate_cli_param(F) \ 800 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 801 unformat_vnet_sw_interface, &vnet_main) \ 802 F (ip46_address_t, local_addr, LOCAL_ADDR_STR, mandatory, "%U", \ 803 unformat_ip46_address) \ 804 F (ip46_address_t, peer_addr, PEER_ADDR_STR, mandatory, "%U", \ 805 unformat_ip46_address) \ 806 F (u8 *, delayed_token, DELAYED_STR, optional, "%v") 812 int something_parsed = 0;
815 if (!something_parsed)
826 if (have_delayed_token)
828 static const char yes[] =
"yes";
829 static const char no[] =
"no";
830 if (!memcmp (delayed_token, yes,
sizeof (yes) - 1))
834 else if (!memcmp (delayed_token, no,
sizeof (no) - 1))
841 0,
"Unrecognized value for `%s' parameter: `%v'",
DELAYED_STR,
848 &peer_addr, is_delayed);
852 0,
"`bfd_udp_auth_deactivate' API call failed, rv=%d:%U", (
int)rv,
863 .path =
"bfd udp session auth deactivate",
864 .short_help =
"bfd udp session auth deactivate" 865 " interface <interface>" 866 " local-addr <local-address>" 867 " peer-addr <peer-address>" 868 "[ delayed <yes|no> ]",
878 #define foreach_bfd_cli_udp_set_echo_source_cli_param(F) \ 879 F (u32, sw_if_index, INTERFACE_STR, mandatory, "%U", \ 880 unformat_vnet_sw_interface, &vnet_main) 886 int something_parsed = 0;
889 if (!something_parsed)
904 "`bfd_udp_set_echo_source' API call failed, rv=%d:%U",
915 .path =
"bfd udp echo-source set",
916 .short_help =
"bfd udp echo-source set interface <interface>",
929 "`bfd_udp_del_echo_source' API call failed, rv=%d:%U",
938 .path =
"bfd udp echo-source del",
939 .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
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
struct bfd_session_s::@46 auth
authentication information
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.