40 #define vl_print(handle, ...) vlib_cli_output (handle, __VA_ARGS__) 47 #define foreach_vpe_api_msg \ 48 _(SW_INTERFACE_SET_VXLAN_BYPASS, sw_interface_set_vxlan_bypass) \ 49 _(VXLAN_ADD_DEL_TUNNEL, vxlan_add_del_tunnel) \ 50 _(VXLAN_TUNNEL_DUMP, vxlan_tunnel_dump) \ 51 _(VXLAN_OFFLOAD_RX, vxlan_offload_rx) 56 vl_api_vxlan_offload_rx_reply_t *rmp;
63 rv = VNET_API_ERROR_NO_SUCH_ENTRY;
71 rv = VNET_API_ERROR_INVALID_SW_IF_INDEX_2;
79 rv = VNET_API_ERROR_INVALID_ADDRESS_FAMILY;
91 rv = VNET_API_ERROR_NO_SUCH_FIB;
97 rv = VNET_API_ERROR_UNSPECIFIED;
110 vl_api_sw_interface_set_vxlan_bypass_reply_t *rmp;
119 REPLY_MACRO (VL_API_SW_INTERFACE_SET_VXLAN_BYPASS_REPLY);
133 rv = VNET_API_ERROR_NO_SUCH_FIB;
142 .encap_fib_index = fib_index,
144 .vni = ntohl (mp->
vni),
152 rv = VNET_API_ERROR_SAME_SRC_DST;
158 rv = VNET_API_ERROR_INVALID_SW_IF_INDEX;
162 u32 sw_if_index = ~0;
183 memset (rmp, 0,
sizeof (*rmp));
184 rmp->_vl_msg_id = ntohs (VL_API_VXLAN_TUNNEL_DETAILS);
200 rmp->
vni = htonl (t->
vni);
223 if (~0 == sw_if_index)
228 send_vxlan_tunnel_details(t, reg, mp->context);
251 #define vl_msg_name_crc_list 253 #undef vl_msg_name_crc_list 258 #define _(id,n,crc) vl_msg_api_add_msg_name_crc (am, #n "_" #crc, id); 259 foreach_vl_msg_name_crc_vxlan;
269 vl_msg_api_set_handlers(VL_API_##N, #n, \ 270 vl_api_##n##_t_handler, \ 272 vl_api_##n##_t_endian, \ 273 vl_api_##n##_t_print, \ 274 sizeof(vl_api_##n##_t), 1);
static void vl_api_sw_interface_set_vxlan_bypass_t_handler(vl_api_sw_interface_set_vxlan_bypass_t *mp)
static uword ip46_address_is_multicast(ip46_address_t *a)
vnet_main_t * vnet_get_main(void)
int size
for sanity checking
#define REPLY_MACRO2(t, body)
Interface set vxlan-bypass request.
static void vl_api_send_msg(vl_api_registration_t *rp, u8 *elem)
static vnet_hw_interface_t * vnet_get_hw_interface(vnet_main_t *vnm, u32 hw_if_index)
#define foreach_vpe_api_msg
static void setup_message_id_table(api_main_t *am)
u32 * fib_index_by_sw_if_index
Table index indexed by software interface.
void * vl_msg_api_alloc(int nbytes)
#define ip46_address_cmp(ip46_1, ip46_2)
trace_cfg_t * api_trace_cfg
Current trace configuration.
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
VLIB_API_INIT_FUNCTION(vxlan_api_hookup)
static void vl_api_vxlan_add_del_tunnel_t_handler(vl_api_vxlan_add_del_tunnel_t *mp)
u32 fib_table_find(fib_protocol_t proto, u32 table_id)
Get the index of the FIB for a Table-ID.
static clib_error_t * vxlan_api_hookup(vlib_main_t *vm)
#define pool_elt_at_index(p, i)
Returns pointer to element at given index.
API main structure, used by both vpp and binary API clients.
#define ip46_address_is_ip4(ip46)
int vnet_vxlan_add_del_rx_flow(u32 hw_if_index, u32 t_index, int is_add)
An API client registration, only in vpp/vlib.
#define BAD_SW_IF_INDEX_LABEL
int vnet_vxlan_add_del_tunnel(vnet_vxlan_add_del_tunnel_args_t *a, u32 *sw_if_indexp)
Offload vxlan rx request.
static uword vnet_sw_if_index_is_api_valid(u32 sw_if_index)
u32 ft_table_id
Table ID (hash key) for this FIB.
Create or delete a VXLAN tunnel.
static vl_api_registration_t * vl_api_client_index_to_registration(u32 index)
static uword vnet_hw_interface_is_valid(vnet_main_t *vnm, u32 hw_if_index)
static ip46_address_t to_ip46(u32 is_ipv6, u8 *buf)
u32 vnet_vxlan_get_tunnel_index(u32 sw_if_index)
#define vec_elt(v, i)
Get vector value at index i.
void vnet_int_vxlan_bypass_mode(u32 sw_if_index, u8 is_ip6, u8 is_enable)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
static fib_protocol_t fib_ip_proto(bool is_ip6)
Convert from boolean is_ip6 to FIB protocol.
u32 * tunnel_index_by_sw_if_index
static void vl_api_vxlan_tunnel_dump_t_handler(vl_api_vxlan_tunnel_dump_t *mp)
ip4_main_t ip4_main
Global ip4 main structure.
struct fib_table_t_ * fibs
Vector of FIBs.
static void send_vxlan_tunnel_details(vxlan_tunnel_t *t, vl_api_registration_t *reg, u32 context)
struct fib_table_t_ * fibs
#define VALIDATE_SW_IF_INDEX(mp)
static void vl_api_vxlan_offload_rx_t_handler(vl_api_vxlan_offload_rx_t *mp)