X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fip%2Fip6_neighbor.h;h=0707a2a8d217eb558cd20fcce55df4612485f2b0;hb=96453fd2417ebd1d69354a7fb692976129cea80e;hp=753de56072e9dde63986cbdee602b1a3ab13e8ff;hpb=7f358b30b04aabe9a35680997cc1eeefb080a869;p=vpp.git diff --git a/src/vnet/ip/ip6_neighbor.h b/src/vnet/ip/ip6_neighbor.h index 753de56072e..0707a2a8d21 100644 --- a/src/vnet/ip/ip6_neighbor.h +++ b/src/vnet/ip/ip6_neighbor.h @@ -20,6 +20,8 @@ #define included_ip6_neighbor_h #include +#include +#include typedef struct { @@ -28,22 +30,22 @@ typedef struct u32 pad; } ip6_neighbor_key_t; -typedef enum ip6_neighbor_flags_t_ -{ - IP6_NEIGHBOR_FLAG_STATIC = (1 << 0), - IP6_NEIGHBOR_FLAG_DYNAMIC = (1 << 1), - IP6_NEIGHBOR_FLAG_NO_FIB_ENTRY = (1 << 2), -} __attribute__ ((packed)) ip6_neighbor_flags_t; - typedef struct { ip6_neighbor_key_t key; - u8 link_layer_address[8]; - ip6_neighbor_flags_t flags; + mac_address_t mac; + ip_neighbor_flags_t flags; f64 time_last_updated; fib_node_index_t fib_entry_index; } ip6_neighbor_t; +extern ip6_address_t ip6_neighbor_get_link_local_address (u32 sw_if_index); + +extern clib_error_t *ip6_neighbor_set_link_local_address (vlib_main_t * vm, + u32 sw_if_index, + ip6_address_t * + address); + extern ip6_neighbor_t *ip6_neighbors_pool (void); extern ip6_neighbor_t *ip6_neighbors_entries (u32 sw_if_index); @@ -73,18 +75,13 @@ extern void vnet_register_ip6_neighbor_resolution_event (vnet_main_t * vnm, extern int vnet_set_ip6_ethernet_neighbor (vlib_main_t * vm, u32 sw_if_index, - ip6_address_t * a, - u8 * link_layer_address, - uword n_bytes_link_layer_address, - int is_static, - int is_no_fib_entry); + const ip6_address_t * a, + const mac_address_t * mac, + ip_neighbor_flags_t flags); extern int vnet_unset_ip6_ethernet_neighbor (vlib_main_t * vm, u32 sw_if_index, - ip6_address_t * a, - u8 * link_layer_address, - uword - n_bytes_link_layer_address); + const ip6_address_t * a); extern int ip6_neighbor_proxy_add_del (u32 sw_if_index, ip6_address_t * addr, u8 is_add); @@ -95,7 +92,7 @@ typedef struct { u32 sw_if_index; ip6_address_t ip6; - u8 mac[6]; + mac_address_t mac; } wc_nd_report_t; void wc_nd_set_publisher_node (uword node_index, uword event_type); @@ -115,8 +112,7 @@ void icmp6_send_router_solicitation (vlib_main_t * vm, u32 sw_if_index, typedef struct { - ip6_address_t dst_address; - u8 dst_address_length; + fib_prefix_t prefix; u8 flags; u32 valid_time; u32 preferred_time; @@ -125,7 +121,7 @@ typedef struct typedef struct { u32 sw_if_index; - u8 router_address[16]; + ip6_address_t router_address; u8 current_hop_limit; u8 flags; u16 router_lifetime_in_sec; @@ -138,6 +134,66 @@ typedef struct void ra_set_publisher_node (uword node_index, uword event_type); +typedef struct _vnet_ip6_neighbor_function_list_elt +{ + struct _vnet_ip6_neighbor_function_list_elt *next_ip6_neighbor_function; + clib_error_t *(*fp) (void *data); +} _vnet_ip6_neighbor_function_list_elt_t; + +typedef struct +{ + _vnet_ip6_neighbor_function_list_elt_t *ra_report_functions; +} ip6_neighbor_public_main_t; + +extern ip6_neighbor_public_main_t ip6_neighbor_public_main; + +#define _VNET_IP6_NEIGHBOR_FUNCTION_DECL(f,tag) \ + \ +static void __vnet_ip6_neighbor_function_init_##tag##_##f (void) \ + __attribute__((__constructor__)) ; \ + \ +static void __vnet_ip6_neighbor_function_init_##tag##_##f (void) \ +{ \ + ip6_neighbor_public_main_t * nm = &ip6_neighbor_public_main; \ + static _vnet_ip6_neighbor_function_list_elt_t init_function; \ + init_function.next_ip6_neighbor_function = nm->tag##_functions; \ + nm->tag##_functions = &init_function; \ + init_function.fp = (void *) &f; \ +} \ + \ +static void __vnet_ip6_neighbor_function_deinit_##tag##_##f (void) \ + __attribute__((__destructor__)) ; \ + \ +static void __vnet_ip6_neighbor_function_deinit_##tag##_##f (void) \ +{ \ + ip6_neighbor_public_main_t * nm = &ip6_neighbor_public_main; \ + _vnet_ip6_neighbor_function_list_elt_t *next; \ + if (nm->tag##_functions->fp == (void *) &f) \ + { \ + nm->tag##_functions = \ + nm->tag##_functions->next_ip6_neighbor_function; \ + return; \ + } \ + next = nm->tag##_functions; \ + while (next->next_ip6_neighbor_function) \ + { \ + if (next->next_ip6_neighbor_function->fp == (void *) &f) \ + { \ + next->next_ip6_neighbor_function = \ + next->next_ip6_neighbor_function->next_ip6_neighbor_function; \ + return; \ + } \ + next = next->next_ip6_neighbor_function; \ + } \ +} + +#define VNET_IP6_NEIGHBOR_RA_FUNCTION(f) \ + _VNET_IP6_NEIGHBOR_FUNCTION_DECL(f,ra_report) + +clib_error_t *call_ip6_neighbor_callbacks (void *data, + _vnet_ip6_neighbor_function_list_elt_t + * elt); + #endif /* included_ip6_neighbor_h */ /*