18 #ifndef included_vnet_l2_input_h 19 #define included_vnet_l2_input_h 44 u8 __force_u64_alignement[0] __attribute__ ((aligned (8)));
87 u32 feat_next_node_index[32];
125 #define L2INPUT_BVI ((u32) (~0-1)) 130 #define foreach_l2input_feat \ 131 _(DROP, "feature-bitmap-drop") \ 132 _(XCONNECT, "l2-output") \ 133 _(FLOOD, "l2-flood") \ 134 _(ARP_UFWD, "l2-uu-fwd") \ 135 _(ARP_TERM, "arp-term-l2bd") \ 136 _(UU_FLOOD, "l2-flood") \ 137 _(GBP_FWD, "gbp-fwd") \ 138 _(UU_FWD, "l2-uu-fwd") \ 141 _(LEARN, "l2-learn") \ 142 _(L2_EMULATION, "l2-emulation") \ 143 _(GBP_LEARN, "gbp-learn-l2") \ 144 _(GBP_LPM_ANON_CLASSIFY, "l2-gbp-lpm-anon-classify") \ 145 _(GBP_NULL_CLASSIFY, "gbp-null-classify") \ 146 _(GBP_SRC_CLASSIFY, "gbp-src-classify") \ 147 _(GBP_LPM_CLASSIFY, "l2-gbp-lpm-classify") \ 148 _(VTR, "l2-input-vtr") \ 149 _(L2_IP_QOS_RECORD, "l2-ip-qos-record") \ 150 _(VPATH, "vpath-input-l2") \ 151 _(ACL, "l2-input-acl") \ 152 _(POLICER_CLAS, "l2-policer-classify") \ 153 _(INPUT_FEAT_ARC, "l2-input-feat-arc") \ 154 _(INPUT_CLASSIFY, "l2-input-classify") \ 155 _(SPAN, "span-l2-input") 160 #define _(sym,str) L2INPUT_FEAT_##sym##_BIT, 172 #define _(sym,str) L2INPUT_FEAT_##sym = (1<<L2INPUT_FEAT_##sym##_BIT), 176 #define _(sym,str) L2INPUT_FEAT_##sym | 203 L2INPUT_FEAT_UU_FLOOD);
209 return ((bd_config->
feature_bitmap & L2INPUT_FEAT_FWD) == L2INPUT_FEAT_FWD);
223 L2INPUT_FEAT_ARP_TERM);
230 L2INPUT_FEAT_ARP_UFWD);
269 l2input_feat_masks_t feature_bitmap,
276 const u8 * old_address,
277 const u8 * new_address);
283 #define MODE_L2_BRIDGE 1 285 #define MODE_L2_CLASSIFY 3 287 #define MODE_ERROR_ETH 1 288 #define MODE_ERROR_BVI_DEF 2 314 ethertype = clib_net_to_host_u16 (eth->
type);
320 vlan = (
void *) (eth + 1);
321 ethertype = clib_net_to_host_u16 (vlan->
type);
322 if (ethertype == ETHERNET_TYPE_VLAN)
342 u16 ethertype = clib_net_to_host_u16 (*(
u16 *) (l3h - 2));
344 if (ethertype == ETHERNET_TYPE_IP4)
346 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)
enum walk_rc_t_ walk_rc_t
Walk return code.
#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.
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.
#define IP_FLOW_HASH_DEFAULT
Default: 5-tuple without the "reverse" bit.
vl_api_tunnel_mode_t mode
static u32 bd_is_valid(l2_bridge_domain_t *bd_config)
#define hash_v3_finalize32(a, b, c)
static_always_inline int ethernet_frame_is_tagged(u16 type)
static u32 ip6_compute_flow_hash(const ip6_header_t *ip, flow_hash_config_t flow_hash_config)
struct _vlib_node_registration vlib_node_registration_t
VLIB buffer representation.
l2_bridge_domain_t * bd_configs