|
FD.io VPP
v21.06-3-gbb25fbf28
Vector Packet Processing
|
Go to the documentation of this file.
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);
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)
344 u16 ethertype = clib_net_to_host_u16 (*(
u16 *) (l3h - 2));
346 if (ethertype == ETHERNET_TYPE_IP4)
348 else if (ethertype == ETHERNET_TYPE_IP6)
static_always_inline int ethernet_frame_is_tagged(u16 type)
vl_api_tunnel_mode_t mode
vlib_main_t * vm
X-connect all packets from the HOST to the PHY.
static u32 ip6_compute_flow_hash(const ip6_header_t *ip, flow_hash_config_t flow_hash_config)
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
#define static_always_inline
#define IP_FLOW_HASH_DEFAULT
Default: 5-tuple + flowlabel without the "reverse" bit.
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment)
#define hash_v3_finalize32(a, b, c)
struct _vlib_node_registration vlib_node_registration_t
static u32 bd_is_valid(l2_bridge_domain_t *bd_config)
#define ethernet_buffer_set_vlan_count(b, v)
Sets the number of VLAN headers in the current Ethernet frame in the buffer.
static u32 ip4_compute_flow_hash(const ip4_header_t *ip, flow_hash_config_t flow_hash_config)
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
l2_input_config_t * configs
vl_api_interface_index_t sw_if_index
enum walk_rc_t_ walk_rc_t
Walk return code.
#define hash_v3_mix32(a, b, c)
l2_bridge_domain_t * bd_configs
VLIB buffer representation.