18 #ifndef included_gre_h 19 #define included_gre_h 32 #define gre_error(n,s) GRE_ERROR_##n, 62 #define GRE_TUNNEL_TYPE_NAMES { \ 63 [GRE_TUNNEL_TYPE_L3] = "L3", \ 64 [GRE_TUNNEL_TYPE_TEB] = "TEB", \ 65 [GRE_TUNNEL_TYPE_ERSPAN] = "ERSPAN", \ 137 #define GTK_FIB_INDEX_SHIFT 12 138 #define GTK_FIB_INDEX_MASK 0xfffff000 139 #define GTK_TYPE_SHIFT 0 140 #define GTK_TYPE_MASK 0x3 141 #define GTK_SESSION_ID_SHIFT 2 142 #define GTK_SESSION_ID_MASK 0xffc 143 #define GTK_SESSION_ID_MAX (GTK_SESSION_ID_MASK >> GTK_SESSION_ID_SHIFT) 311 }) ip4_and_gre_header_t;
321 }) ip6_and_gre_header_t;
334 u32 hw_if_index,
u32 flags);
360 u32 node_index, gre_tunnel_type_t tunnel_type);
363 #define GRE_OUTPUT_NEXT_LOOKUP 1
uword * seq_num_by_key
Hash mapping tunnel src/dst addr and fib-idx to sequence number.
vlib_node_registration_t gre_encap_node
(constructor) VLIB_REGISTER_NODE (gre_encap_node)
vlib_node_registration_t gre4_input_node
(constructor) VLIB_REGISTER_NODE (gre4_input_node)
uword * tunnel_by_key6
Hash mapping to tunnels with ipv6 src/dst addr.
#define CLIB_CACHE_LINE_ALIGN_MARK(mark)
format_function_t format_gre_header_with_length
fib_node_index_t fib_entry_index
The FIB entry sourced by the tunnel for its destination prefix.
Key for a IPv6 GRE Tunnel We use a different type so that the V4 key hash is as small as possible...
Transparent Ethernet Bridging - the tunnel is in L2 mode.
uword * protocol_info_by_protocol
#define GTK_SESSION_ID_SHIFT
gre_protocol_t protocol
GRE protocol type in host byte order.
char * name
Name (a c string).
A GRE payload protocol registration.
u32 outer_fib_index
The FIB in which the src.dst address are present.
typedef CLIB_PACKED(struct { ip4_header_t ip4;gre_header_t gre;}) ip4_and_gre_header_t
IPv4 and GRE header.
gre_tunnel_type_t_
The GRE tunnel type.
u32 gtk_fidx_ssid_type
FIB table index, ERSPAN session ID and tunnel type in u32 bit fields:
struct _vnet_device_class vnet_device_class_t
u32 * tunnel_index_by_sw_if_index
Mapping from sw_if_index to tunnel index.
u32 sibling_index
The tunnel is a child of the FIB entry for its desintion.
Hash key for GRE header seq number generation for ERSPAN encap.
enum gre_tunnel_type_t_ gre_tunnel_type_t
The GRE tunnel type.
u32 gtk_fidx_ssid_type
FIB table index, ERSPAN session ID and tunnel type in u32 bit fields:
void gre_tunnel_stack(adj_index_t ai)
gre_tunnel_stack
gre_tunnel_type_t tunnel_type
GRE tunnel type.
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
Aggregrate type for a prefix.
adj_index_t l2_adj_index
an L2 tunnel always rquires an L2 midchain.
unformat_function_t unformat_gre_header
ip46_address_t tunnel_src
The tunnel's source/local address.
uword * tunnel_by_key4
Hash mapping to tunnels with ipv4 src/dst addr.
A representation of a GRE tunnel.
ip46_address_t fp_addr
The address type is not deriveable from the fp_addr member.
struct gre_tunnel_key6_t_ gre_tunnel_key6_t
Key for a IPv6 GRE Tunnel We use a different type so that the V4 key hash is as small as possible...
ip6_address_t gtk_src
Source and destination IP addresses.
unformat_function_t unformat_gre_protocol_net_byte_order
static int gre_match_key4(const gre_tunnel_key4_t *key1, const gre_tunnel_key4_t *key2)
u32 node_index
Node which handles this type.
void gre_register_input_protocol(vlib_main_t *vm, gre_protocol_t protocol, u32 node_index, gre_tunnel_type_t tunnel_type)
static int gre_match_key6(const gre_tunnel_key6_t *key1, const gre_tunnel_key6_t *key2)
An node in the FIB graph.
Key for a IPv4 GRE Tunnel.
union gre_tunnel_key_t_ gre_tunnel_key_t
Union of the two possible key types.
gre_sn_t * gre_sn
GRE header sequence number (SN) used for ERSPAN type 2 header, must be bumped automically to be threa...
format_function_t format_gre_protocol
#define GTK_FIB_INDEX_SHIFT
static void gre_mk_key4(ip4_address_t src, ip4_address_t dst, u32 fib_index, u8 ttype, u16 session_id, gre_tunnel_key4_t *key)
Used for GRE header seq number generation for ERSPAN encap.
u32 fib_node_index_t
A typedef of a node index.
u32 adj_index_t
An index for adjacencies.
u32 next_index
Next index for this type.
void gre_update_adj(vnet_main_t *vnm, u32 sw_if_index, adj_index_t ai)
gre_tunnel_t * tunnels
pool of tunnel instances
next_info_t * next_by_protocol
Union of the two possible key types.
vnet_hw_interface_class_t gre_hw_interface_class
static void gre_mk_key6(const ip6_address_t *src, const ip6_address_t *dst, u32 fib_index, u8 ttype, u16 session_id, gre_tunnel_key6_t *key)
fib_node_t node
Linkage into the FIB object graph.
struct _vlib_node_registration vlib_node_registration_t
vnet_device_class_t gre_device_class
clib_error_t * gre_interface_admin_up_down(vnet_main_t *vnm, u32 hw_if_index, u32 flags)
int vnet_gre_add_del_tunnel(vnet_gre_add_del_tunnel_args_t *a, u32 *sw_if_indexp)
ERSPAN type 2 - the tunnel is for port mirror SPAN output.
struct _vnet_hw_interface_class vnet_hw_interface_class_t
unformat_function_t unformat_pg_gre_header
gre_tunnel_key_t * key
The hash table's key stored in separate memory since the tunnel_t memory can realloc.
vlib_node_registration_t gre6_input_node
(constructor) VLIB_REGISTER_NODE (gre6_input_node)
unformat_function_t unformat_gre_protocol_host_byte_order
fib_prefix_t tunnel_dst
The tunnel's destination/remote address.
static gre_protocol_info_t * gre_get_protocol_info(gre_main_t *em, gre_protocol_t protocol)
gre_protocol_info_t * protocol_infos
GRE payload protocol registrations.
format_function_t format_gre_header
u16 session_id
ERSPAN type 2 session ID, least significant 10 bits of u16.
static void gre_mk_sn_key(const gre_tunnel_t *gt, gre_sn_key_t *key)
struct gre_tunnel_key4_t_ gre_tunnel_key4_t
Key for a IPv4 GRE Tunnel.