Add simple counter statistics to VRRP, based on a subset of those defined in RFC8347. Add an update API that allows in-place modification of an existing instance. The method returns a vrrp_index which can be used both for retrieving statistics and to modify non-key parameters. Also add a delete method which will take that vrrp_index as parameter. Type: improvement Signed-off-by: Emanuele Di Pascale <lele84@gmail.com> Change-Id: I2cd11467b4dbd9dfdb5aa748783144b4883dba57
329 lines
9.1 KiB
Plaintext
329 lines
9.1 KiB
Plaintext
/*
|
|
* Copyright 2019-2020 Rubicon Communications, LLC (Netgate)
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
*/
|
|
|
|
option version = "1.1.1";
|
|
|
|
import "vnet/interface_types.api";
|
|
import "vnet/ip/ip_types.api";
|
|
import "vnet/ethernet/ethernet_types.api";
|
|
|
|
typedef vrrp_vr_key
|
|
{
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 is_ipv6;
|
|
};
|
|
|
|
enum vrrp_vr_flags
|
|
{
|
|
VRRP_API_VR_PREEMPT = 0x1,
|
|
VRRP_API_VR_ACCEPT = 0x2,
|
|
VRRP_API_VR_UNICAST = 0x4,
|
|
VRRP_API_VR_IPV6 = 0x8,
|
|
};
|
|
|
|
typedef vrrp_vr_conf
|
|
{
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 priority;
|
|
u16 interval;
|
|
vl_api_vrrp_vr_flags_t flags;
|
|
};
|
|
|
|
/** \brief VRRP: Add or delete a VRRP virtual router
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param is_add - 0 if deleting, != 0 if adding
|
|
@param sw_if_index - interface backed up by this vr
|
|
@param vr_id - the VR ID advertised by this vr
|
|
@param priority - the priority advertised for this vr
|
|
@param interval - interval between advertisements in centiseconds
|
|
@param flags - bit flags for booleans - preempt, accept, unicast, ipv6
|
|
@param n_addrs - number of addresses being backed up by this vr
|
|
@param addrs - the addresses backed up by this vr
|
|
*/
|
|
autoreply define vrrp_vr_add_del {
|
|
u32 client_index;
|
|
u32 context;
|
|
u8 is_add;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 priority;
|
|
u16 interval;
|
|
vl_api_vrrp_vr_flags_t flags;
|
|
u8 n_addrs;
|
|
vl_api_address_t addrs[n_addrs];
|
|
};
|
|
|
|
/** @brief Replace an existing VRRP virtual router in-place or create a new one
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param vrrp_index - an existing VRRP entry to replace, or 0xffffffff to crate a new one
|
|
@param sw_if_index - interface backed up by this vr
|
|
@param vr_id - the VR ID advertised by this vr
|
|
@param priority - the priority advertised for this vr
|
|
@param interval - interval between advertisements in centiseconds
|
|
@param flags - bit flags for booleans - preempt, accept, unicast, ipv6
|
|
@param n_addrs - number of addresses being backed up by this vr
|
|
@param addrs - the addresses backed up by this vr
|
|
*/
|
|
define vrrp_vr_update {
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 vrrp_index;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 priority;
|
|
u16 interval;
|
|
vl_api_vrrp_vr_flags_t flags;
|
|
u8 n_addrs;
|
|
vl_api_address_t addrs[n_addrs];
|
|
};
|
|
|
|
/**
|
|
* @brief Reply to a VRRP add/replace
|
|
* @param context - returned sender context, to match reply w/ request
|
|
* @param vrrp_index - index of the updated or newly created VRRP instance
|
|
* @param retval 0 - no error
|
|
*/
|
|
define vrrp_vr_update_reply {
|
|
u32 context;
|
|
i32 retval;
|
|
u32 vrrp_index;
|
|
};
|
|
|
|
/**
|
|
* @brief Delete an existing VRRP instance
|
|
* @param client_index - opaque cookie to identify the sender
|
|
* @param context - returned sender context, to match reply w/ request
|
|
* @param vrrp_index - index of the VRRP instance to delete
|
|
*/
|
|
autoreply define vrrp_vr_del {
|
|
u32 client_index;
|
|
u32 context;
|
|
u32 vrrp_index;
|
|
};
|
|
|
|
/** \brief VRRP: dump virtual router data
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index - interface to use as filter (0,~0 == "all")
|
|
*/
|
|
define vrrp_vr_dump {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
};
|
|
|
|
enum vrrp_vr_state
|
|
{
|
|
VRRP_API_VR_STATE_INIT = 0,
|
|
VRRP_API_VR_STATE_BACKUP,
|
|
VRRP_API_VR_STATE_MASTER,
|
|
VRRP_API_VR_STATE_INTF_DOWN,
|
|
};
|
|
|
|
typedef vrrp_vr_tracking
|
|
{
|
|
u32 interfaces_dec;
|
|
u8 priority;
|
|
};
|
|
|
|
typedef vrrp_vr_runtime
|
|
{
|
|
vl_api_vrrp_vr_state_t state;
|
|
u16 master_adv_int;
|
|
u16 skew;
|
|
u16 master_down_int;
|
|
vl_api_mac_address_t mac;
|
|
vl_api_vrrp_vr_tracking_t tracking;
|
|
};
|
|
|
|
/** \brief VRRP: VR dump response
|
|
@param context - sender context which was passed in the request
|
|
@param conf - configuration parameters for the VR
|
|
@param runtime - runtime state for the VR
|
|
*/
|
|
define vrrp_vr_details {
|
|
u32 context;
|
|
vl_api_vrrp_vr_conf_t config;
|
|
vl_api_vrrp_vr_runtime_t runtime;
|
|
u8 n_addrs;
|
|
vl_api_address_t addrs[n_addrs];
|
|
};
|
|
|
|
/** \brief VRRP: start or shutdown the VRRP protocol for a virtual router
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index - interface ID that VR is backing up
|
|
@param vr_id - VR ID
|
|
@param is_ipv6 - 1 for IPv6, 0 for IPv4
|
|
@param is_start - 1 to start VRRP proto on this VR, 0 to shutdown
|
|
*/
|
|
autoreply define vrrp_vr_start_stop {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 is_ipv6;
|
|
u8 is_start;
|
|
};
|
|
|
|
/** \brief VRRP: set unicast peers for a VR
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index - interface ID that VR is backing up
|
|
@param vr_id - VR ID
|
|
@param is_ipv6 - 1 for IPv6, 0 for IPv4
|
|
@param n_addrs - number of peer addresses
|
|
@param addrs - peer addresses
|
|
*/
|
|
autoreply define vrrp_vr_set_peers {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 is_ipv6;
|
|
u8 n_addrs;
|
|
vl_api_address_t addrs[n_addrs];
|
|
};
|
|
|
|
/** \brief VRRP: dump virtual router peer address data
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index - interface (0,~0 == "all" -> ignore is_ipv6 & vr_id))
|
|
@param is_ipv6 - 0 -> IPv4, 1 -> IPv6
|
|
@param vr_id - ID of VR to dump
|
|
*/
|
|
define vrrp_vr_peer_dump {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 is_ipv6;
|
|
u8 vr_id;
|
|
};
|
|
|
|
/** \brief VRRP: VR peer dump response
|
|
@param context - sender context which was passed in the request
|
|
@param sw_if_index - interface index
|
|
@param is_ipv6 - 0 -> IPv4, 1 -> IPv6
|
|
@param vr_id - ID of VR
|
|
@param n_peer_addrs - number of peer addresses
|
|
@param peer_addrs - peer addresses
|
|
*/
|
|
define vrrp_vr_peer_details {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 is_ipv6;
|
|
u8 n_peer_addrs;
|
|
vl_api_address_t peer_addrs[n_peer_addrs];
|
|
};
|
|
|
|
/** \brief VR interface tracking
|
|
@param sw_if_index - the interface index to track (not the VR sw_if_index)
|
|
@param priority - the adjustment to VR priority if intf is down
|
|
*/
|
|
typedef vrrp_vr_track_if
|
|
{
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 priority;
|
|
};
|
|
|
|
/** \brief VRRP: Add/delete VR priority tracking of interface status
|
|
@param context - sender context which was passed in the request
|
|
@param sw_if_index - interface index
|
|
@param is_ipv6 - 0 -> IPv4, 1 -> IPv6
|
|
@param vr_id - ID of VR
|
|
@param is_add - 0 -> delete, 1 -> add
|
|
@param n_ifs - number of interface tracking records
|
|
@param ifs - array of interface tracking records
|
|
*/
|
|
autoreply define vrrp_vr_track_if_add_del
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 is_ipv6;
|
|
u8 vr_id;
|
|
u8 is_add;
|
|
u8 n_ifs;
|
|
vl_api_vrrp_vr_track_if_t ifs[n_ifs];
|
|
};
|
|
|
|
/** \brief VRRP: dump virtual router interface tracking data
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param sw_if_index - interface
|
|
@param is_ipv6 - 0 -> IPv4, 1 -> IPv6
|
|
@param vr_id - ID of VR to dump
|
|
@param dump_all - dump all VR interface tracking, ignore other fields
|
|
*/
|
|
define vrrp_vr_track_if_dump {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 is_ipv6;
|
|
u8 vr_id;
|
|
u8 dump_all;
|
|
};
|
|
|
|
/** \brief VRRP: VR interface tracking dump response
|
|
@param context - sender context which was passed in the request
|
|
@param sw_if_index - interface index
|
|
@param is_ipv6 - 0 -> IPv4, 1 -> IPv6
|
|
@param vr_id - ID of VR
|
|
@param n_ifs - number of tracked interfaces
|
|
@param ifs - array of tracked interface data
|
|
*/
|
|
define vrrp_vr_track_if_details {
|
|
u32 client_index;
|
|
u32 context;
|
|
vl_api_interface_index_t sw_if_index;
|
|
u8 vr_id;
|
|
u8 is_ipv6;
|
|
u8 n_ifs;
|
|
vl_api_vrrp_vr_track_if_t ifs[n_ifs];
|
|
};
|
|
|
|
/** \brief Notification about VRRP VR state change event
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param pid - client pid registered to receive notification
|
|
@param vr - configuration parameters identifying the VR
|
|
@param old_state - old state of VR
|
|
@param new_state - new state of VR
|
|
*/
|
|
define vrrp_vr_event
|
|
{
|
|
u32 client_index;
|
|
u32 pid;
|
|
vl_api_vrrp_vr_key_t vr;
|
|
vl_api_vrrp_vr_state_t old_state;
|
|
vl_api_vrrp_vr_state_t new_state;
|
|
};
|
|
|
|
service {
|
|
rpc want_vrrp_vr_events returns want_vrrp_vr_events_reply
|
|
events vrrp_vr_event;
|
|
};
|
|
|
|
/** \brief Register for VRRP VR state change events
|
|
@param client_index - opaque cookie to identify the sender
|
|
@param context - sender context, to match reply w/ request
|
|
@param enable_disable - 1 to register, 0 to cancel registration
|
|
@param pid - sender's pid
|
|
*/
|
|
autoreply define want_vrrp_vr_events
|
|
{
|
|
u32 client_index;
|
|
u32 context;
|
|
bool enable_disable;
|
|
u32 pid;
|
|
};
|