18 #ifndef included_vnet_l2_input_h 19 #define included_vnet_l2_input_h 58 u32 feat_next_node_index[32];
96 #define L2INPUT_BVI ((u32) (~0-1)) 101 #define foreach_l2input_feat \ 102 _(DROP, "feature-bitmap-drop") \ 103 _(XCONNECT, "l2-output") \ 104 _(FLOOD, "l2-flood") \ 105 _(ARP_UFWD, "l2-uu-fwd") \ 106 _(ARP_TERM, "arp-term-l2bd") \ 107 _(UU_FLOOD, "l2-flood") \ 108 _(GBP_FWD, "gbp-fwd") \ 109 _(UU_FWD, "l2-uu-fwd") \ 112 _(LEARN, "l2-learn") \ 113 _(L2_EMULATION, "l2-emulation") \ 114 _(GBP_LEARN, "gbp-learn-l2") \ 115 _(GBP_LPM_ANON_CLASSIFY, "l2-gbp-lpm-anon-classify") \ 116 _(GBP_NULL_CLASSIFY, "gbp-null-classify") \ 117 _(GBP_SRC_CLASSIFY, "gbp-src-classify") \ 118 _(GBP_LPM_CLASSIFY, "l2-gbp-lpm-classify") \ 119 _(VTR, "l2-input-vtr") \ 120 _(L2_IP_QOS_RECORD, "l2-ip-qos-record") \ 121 _(VPATH, "vpath-input-l2") \ 122 _(ACL, "l2-input-acl") \ 123 _(POLICER_CLAS, "l2-policer-classify") \ 124 _(INPUT_FEAT_ARC, "l2-input-feat-arc") \ 125 _(INPUT_CLASSIFY, "l2-input-classify") \ 126 _(SPAN, "span-l2-input") 131 #define _(sym,str) L2INPUT_FEAT_##sym##_BIT, 143 #define _(sym,str) L2INPUT_FEAT_##sym = (1<<L2INPUT_FEAT_##sym##_BIT), 147 #define _(sym,str) L2INPUT_FEAT_##sym | 172 L2INPUT_FEAT_UU_FLOOD);
178 return ((bd_config->
feature_bitmap & L2INPUT_FEAT_FWD) == L2INPUT_FEAT_FWD);
192 L2INPUT_FEAT_ARP_TERM);
199 L2INPUT_FEAT_ARP_UFWD);
209 l2input_feat_masks_t feature_bitmap,
216 const u8 * old_address,
217 const u8 * new_address);
220 #define MODE_L2_BRIDGE 1 222 #define MODE_L2_CLASSIFY 3 224 #define MODE_ERROR_ETH 1 225 #define MODE_ERROR_BVI_DEF 2 232 u32 shg,
u32 xc_sw_if_index);
251 ethertype = clib_net_to_host_u16 (eth->
type);
257 vlan = (
void *) (eth + 1);
258 ethertype = clib_net_to_host_u16 (vlan->
type);
259 if (ethertype == ETHERNET_TYPE_VLAN)
279 u16 ethertype = clib_net_to_host_u16 (*(
u16 *) (l3h - 2));
281 if (ethertype == ETHERNET_TYPE_IP4)
283 else if (ethertype == ETHERNET_TYPE_IP6)
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
l2_input_config_t * configs
static u32 ip4_compute_flow_hash(const ip4_header_t *ip, flow_hash_config_t flow_hash_config)
#define hash_v3_mix32(a, b, c)
#define static_always_inline
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
static void * vlib_buffer_get_current(vlib_buffer_t *b)
Get pointer to current data to process.
static u32 ip6_compute_flow_hash(const ip6_header_t *ip, flow_hash_config_t flow_hash_config)
enum l2_bd_port_type_t_ l2_bd_port_type_t
#define ethernet_buffer_set_vlan_count(b, v)
Sets the number of VLAN headers in the current Ethernet frame in the buffer.
static u32 bd_is_valid(l2_bridge_domain_t *bd_config)
vl_api_vxlan_gbp_api_tunnel_mode_t mode
#define hash_v3_finalize32(a, b, c)
static_always_inline int ethernet_frame_is_tagged(u16 type)
#define IP_FLOW_HASH_DEFAULT
Default: 5-tuple without the "reverse" bit.
struct _vlib_node_registration vlib_node_registration_t
VLIB buffer representation.
l2_bridge_domain_t * bd_configs