FD.io VPP  v19.08-27-gf4dcae4
Vector Packet Processing
lb.c File Reference
+ Include dependency graph for lb.c:

Go to the source code of this file.

Data Structures

struct  lb_pseudorand_t
 

Macros

#define LB_GARBAGE_RUN   60
 
#define LB_CONCURRENCY_TIMEOUT   10
 
#define lb_get_writer_lock()   clib_spinlock_lock (&lb_main.writer_lock)
 
#define lb_put_writer_lock()   clib_spinlock_unlock (&lb_main.writer_lock)
 

Functions

static void lb_as_stack (lb_as_t *as)
 
u32 lb_hash_time_now (vlib_main_t *vm)
 
u8format_lb_main (u8 *s, va_list *args)
 
u8format_lb_vip_type (u8 *s, va_list *args)
 
uword unformat_lb_vip_type (unformat_input_t *input, va_list *args)
 
u8format_lb_vip (u8 *s, va_list *args)
 
u8format_lb_as (u8 *s, va_list *args)
 
u8format_lb_vip_detailed (u8 *s, va_list *args)
 
static int lb_pseudorand_compare (void *a, void *b)
 
static void lb_vip_garbage_collection (lb_vip_t *vip)
 
void lb_garbage_collection ()
 
static void lb_vip_update_new_flow_table (lb_vip_t *vip)
 
int lb_conf (ip4_address_t *ip4_address, ip6_address_t *ip6_address, u32 per_cpu_sticky_buckets, u32 flow_timeout)
 Fix global load-balancer parameters. More...
 
static int lb_vip_port_find_index (ip46_address_t *prefix, u8 plen, u8 protocol, u16 port, lb_lkp_type_t lkp_type, u32 *vip_index)
 
static int lb_vip_port_find_index_with_lock (ip46_address_t *prefix, u8 plen, u8 protocol, u16 port, u32 *vip_index)
 
static int lb_vip_port_find_all_port_vip (ip46_address_t *prefix, u8 plen, u32 *vip_index)
 
static int lb_vip_port_find_diff_port (ip46_address_t *prefix, u8 plen, u8 protocol, u16 port, u32 *vip_index)
 
int lb_vip_find_index (ip46_address_t *prefix, u8 plen, u8 protocol, u16 port, u32 *vip_index)
 
static int lb_as_find_index_vip (lb_vip_t *vip, ip46_address_t *address, u32 *as_index)
 
int lb_vip_add_ass (u32 vip_index, ip46_address_t *addresses, u32 n)
 
int lb_flush_vip_as (u32 vip_index, u32 as_index)
 
int lb_vip_del_ass_withlock (u32 vip_index, ip46_address_t *addresses, u32 n, u8 flush)
 
int lb_vip_del_ass (u32 vip_index, ip46_address_t *addresses, u32 n, u8 flush)
 
static int lb_vip_prefix_index_alloc (lb_main_t *lbm)
 
static int lb_vip_prefix_index_free (lb_main_t *lbm, u32 instance)
 
static void lb_vip_add_adjacency (lb_main_t *lbm, lb_vip_t *vip, u32 *vip_prefix_index)
 Add the VIP adjacency to the ip4 or ip6 fib. More...
 
static int lb_vip_add_port_filter (lb_main_t *lbm, lb_vip_t *vip, u32 vip_prefix_index, u32 vip_idx)
 Add the VIP filter entry. More...
 
static int lb_vip_del_port_filter (lb_main_t *lbm, lb_vip_t *vip)
 Del the VIP filter entry. More...
 
static void lb_vip_del_adjacency (lb_main_t *lbm, lb_vip_t *vip)
 Deletes the adjacency associated with the VIP. More...
 
int lb_vip_add (lb_vip_add_args_t args, u32 *vip_index)
 
int lb_vip_del (u32 vip_index)
 
 VLIB_PLUGIN_REGISTER ()
 
u8format_lb_dpo (u8 *s, va_list *va)
 
static void lb_dpo_lock (dpo_id_t *dpo)
 
static void lb_dpo_unlock (dpo_id_t *dpo)
 
static fib_node_tlb_fib_node_get_node (fib_node_index_t index)
 
static void lb_fib_node_last_lock_gone (fib_node_t *node)
 
static lb_as_tlb_as_from_fib_node (fib_node_t *node)
 
static fib_node_back_walk_rc_t lb_fib_node_back_walk_notify (fib_node_t *node, fib_node_back_walk_ctx_t *ctx)
 
int lb_nat4_interface_add_del (u32 sw_if_index, int is_del)
 
int lb_nat6_interface_add_del (u32 sw_if_index, int is_del)
 
clib_error_tlb_init (vlib_main_t *vm)
 

Variables

lb_main_t lb_main
 
static const char *const lb_dpo_gre4_ip4 [] = { "lb4-gre4" , NULL }
 
static const char *const lb_dpo_gre4_ip6 [] = { "lb6-gre4" , NULL }
 
static const char *const *const lb_dpo_gre4_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_gre6_ip4 [] = { "lb4-gre6" , NULL }
 
static const char *const lb_dpo_gre6_ip6 [] = { "lb6-gre6" , NULL }
 
static const char *const *const lb_dpo_gre6_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_gre4_ip4_port [] = { "lb4-gre4-port" , NULL }
 
static const char *const lb_dpo_gre4_ip6_port [] = { "lb6-gre4-port" , NULL }
 
static const char *const *const lb_dpo_gre4_port_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_gre6_ip4_port [] = { "lb4-gre6-port" , NULL }
 
static const char *const lb_dpo_gre6_ip6_port [] = { "lb6-gre6-port" , NULL }
 
static const char *const *const lb_dpo_gre6_port_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_l3dsr_ip4 [] = {"lb4-l3dsr" , NULL}
 
static const char *const *const lb_dpo_l3dsr_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_l3dsr_ip4_port [] = {"lb4-l3dsr-port" , NULL}
 
static const char *const *const lb_dpo_l3dsr_port_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_nat4_ip4_port [] = { "lb4-nat4-port" , NULL }
 
static const char *const *const lb_dpo_nat4_port_nodes [DPO_PROTO_NUM]
 
static const char *const lb_dpo_nat6_ip6_port [] = { "lb6-nat6-port" , NULL }
 
static const char *const *const lb_dpo_nat6_port_nodes [DPO_PROTO_NUM]
 
static char * lb_vip_type_strings []
 

Macro Definition Documentation

#define LB_CONCURRENCY_TIMEOUT   10

Definition at line 27 of file lb.c.

#define LB_GARBAGE_RUN   60

Definition at line 24 of file lb.c.

#define lb_get_writer_lock ( )    clib_spinlock_lock (&lb_main.writer_lock)

Definition at line 31 of file lb.c.

#define lb_put_writer_lock ( )    clib_spinlock_unlock (&lb_main.writer_lock)

Definition at line 32 of file lb.c.

Function Documentation

u8* format_lb_as ( u8 s,
va_list *  args 
)

Definition at line 184 of file lb.c.

+ Here is the call graph for this function:

u8* format_lb_dpo ( u8 s,
va_list *  va 
)

Definition at line 1254 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

u8* format_lb_main ( u8 s,
va_list *  args 
)

Definition at line 98 of file lb.c.

+ Here is the call graph for this function:

u8* format_lb_vip ( u8 s,
va_list *  args 
)

Definition at line 153 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

u8* format_lb_vip_detailed ( u8 s,
va_list *  args 
)

Definition at line 192 of file lb.c.

+ Here is the call graph for this function:

u8* format_lb_vip_type ( u8 s,
va_list *  args 
)

Definition at line 131 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_as_find_index_vip ( lb_vip_t vip,
ip46_address_t *  address,
u32 as_index 
)
static

Definition at line 562 of file lb.c.

+ Here is the caller graph for this function:

static lb_as_t* lb_as_from_fib_node ( fib_node_t node)
static

Definition at line 1280 of file lb.c.

+ Here is the caller graph for this function:

static void lb_as_stack ( lb_as_t as)
static

Definition at line 1287 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

int lb_conf ( ip4_address_t ip4_address,
ip6_address_t ip6_address,
u32  sticky_buckets,
u32  flow_timeout 
)

Fix global load-balancer parameters.

Parameters
ip4_addressIPv4 source address used for encapsulated traffic
ip6_addressIPv6 source address used for encapsulated traffic
Returns
0 on success. VNET_LB_ERR_XXX on error

Definition at line 473 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static void lb_dpo_lock ( dpo_id_t dpo)
static

Definition at line 1263 of file lb.c.

+ Here is the caller graph for this function:

static void lb_dpo_unlock ( dpo_id_t dpo)
static

Definition at line 1264 of file lb.c.

+ Here is the caller graph for this function:

static fib_node_back_walk_rc_t lb_fib_node_back_walk_notify ( fib_node_t node,
fib_node_back_walk_ctx_t ctx 
)
static

Definition at line 1318 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static fib_node_t* lb_fib_node_get_node ( fib_node_index_t  index)
static

Definition at line 1267 of file lb.c.

+ Here is the caller graph for this function:

static void lb_fib_node_last_lock_gone ( fib_node_t node)
static

Definition at line 1275 of file lb.c.

+ Here is the caller graph for this function:

int lb_flush_vip_as ( u32  vip_index,
u32  as_index 
)

Definition at line 759 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void lb_garbage_collection ( )

Definition at line 354 of file lb.c.

+ Here is the caller graph for this function:

u32 lb_hash_time_now ( vlib_main_t vm)

Definition at line 93 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

clib_error_t* lb_init ( vlib_main_t vm)

Definition at line 1358 of file lb.c.

+ Here is the call graph for this function:

int lb_nat4_interface_add_del ( u32  sw_if_index,
int  is_del 
)

Definition at line 1325 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

int lb_nat6_interface_add_del ( u32  sw_if_index,
int  is_del 
)

Definition at line 1341 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_pseudorand_compare ( void *  a,
void *  b 
)
static

Definition at line 276 of file lb.c.

int lb_vip_add ( lb_vip_add_args_t  args,
u32 vip_index 
)

Definition at line 1043 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static void lb_vip_add_adjacency ( lb_main_t lbm,
lb_vip_t vip,
u32 vip_prefix_index 
)
static

Add the VIP adjacency to the ip4 or ip6 fib.

Definition at line 892 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

int lb_vip_add_ass ( u32  vip_index,
ip46_address_t *  addresses,
u32  n 
)

Definition at line 582 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_add_port_filter ( lb_main_t lbm,
lb_vip_t vip,
u32  vip_prefix_index,
u32  vip_idx 
)
static

Add the VIP filter entry.

Definition at line 960 of file lb.c.

+ Here is the caller graph for this function:

int lb_vip_del ( u32  vip_index)

Definition at line 1197 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static void lb_vip_del_adjacency ( lb_main_t lbm,
lb_vip_t vip 
)
static

Deletes the adjacency associated with the VIP.

Definition at line 1010 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

int lb_vip_del_ass ( u32  vip_index,
ip46_address_t *  addresses,
u32  n,
u8  flush 
)

Definition at line 850 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

int lb_vip_del_ass_withlock ( u32  vip_index,
ip46_address_t *  addresses,
u32  n,
u8  flush 
)

Definition at line 793 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_del_port_filter ( lb_main_t lbm,
lb_vip_t vip 
)
static

Del the VIP filter entry.

Definition at line 981 of file lb.c.

+ Here is the caller graph for this function:

int lb_vip_find_index ( ip46_address_t *  prefix,
u8  plen,
u8  protocol,
u16  port,
u32 vip_index 
)

Definition at line 551 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static void lb_vip_garbage_collection ( lb_vip_t vip)
static

Definition at line 285 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_port_find_all_port_vip ( ip46_address_t *  prefix,
u8  plen,
u32 vip_index 
)
static

Definition at line 535 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_port_find_diff_port ( ip46_address_t *  prefix,
u8  plen,
u8  protocol,
u16  port,
u32 vip_index 
)
static

Definition at line 544 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_port_find_index ( ip46_address_t *  prefix,
u8  plen,
u8  protocol,
u16  port,
lb_lkp_type_t  lkp_type,
u32 vip_index 
)
static

Definition at line 493 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_port_find_index_with_lock ( ip46_address_t *  prefix,
u8  plen,
u8  protocol,
u16  port,
u32 vip_index 
)
static

Definition at line 527 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_prefix_index_alloc ( lb_main_t lbm)
static

Definition at line 860 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static int lb_vip_prefix_index_free ( lb_main_t lbm,
u32  instance 
)
static

Definition at line 875 of file lb.c.

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static void lb_vip_update_new_flow_table ( lb_vip_t vip)
static

Definition at line 379 of file lb.c.

+ Here is the caller graph for this function:

uword unformat_lb_vip_type ( unformat_input_t input,
va_list *  args 
)

Definition at line 141 of file lb.c.

+ Here is the call graph for this function:

VLIB_PLUGIN_REGISTER ( )

+ Here is the caller graph for this function:

Variable Documentation

const char* const lb_dpo_gre4_ip4[] = { "lb4-gre4" , NULL }
static

Definition at line 37 of file lb.c.

const char* const lb_dpo_gre4_ip4_port[] = { "lb4-gre4-port" , NULL }
static

Definition at line 53 of file lb.c.

const char* const lb_dpo_gre4_ip6[] = { "lb6-gre4" , NULL }
static

Definition at line 38 of file lb.c.

const char* const lb_dpo_gre4_ip6_port[] = { "lb6-gre4-port" , NULL }
static

Definition at line 54 of file lb.c.

const char* const* const lb_dpo_gre4_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_gre4_ip4[]
Definition: lb.c:37
static const char *const lb_dpo_gre4_ip6[]
Definition: lb.c:38

Definition at line 39 of file lb.c.

const char* const* const lb_dpo_gre4_port_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_gre4_ip6_port[]
Definition: lb.c:54
static const char *const lb_dpo_gre4_ip4_port[]
Definition: lb.c:53

Definition at line 55 of file lb.c.

const char* const lb_dpo_gre6_ip4[] = { "lb4-gre6" , NULL }
static

Definition at line 45 of file lb.c.

const char* const lb_dpo_gre6_ip4_port[] = { "lb4-gre6-port" , NULL }
static

Definition at line 61 of file lb.c.

const char* const lb_dpo_gre6_ip6[] = { "lb6-gre6" , NULL }
static

Definition at line 46 of file lb.c.

const char* const lb_dpo_gre6_ip6_port[] = { "lb6-gre6-port" , NULL }
static

Definition at line 62 of file lb.c.

const char* const* const lb_dpo_gre6_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_gre6_ip4[]
Definition: lb.c:45
static const char *const lb_dpo_gre6_ip6[]
Definition: lb.c:46

Definition at line 47 of file lb.c.

const char* const* const lb_dpo_gre6_port_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_gre6_ip4_port[]
Definition: lb.c:61
static const char *const lb_dpo_gre6_ip6_port[]
Definition: lb.c:62

Definition at line 63 of file lb.c.

const char* const lb_dpo_l3dsr_ip4[] = {"lb4-l3dsr" , NULL}
static

Definition at line 69 of file lb.c.

const char* const lb_dpo_l3dsr_ip4_port[] = {"lb4-l3dsr-port" , NULL}
static

Definition at line 75 of file lb.c.

const char* const* const lb_dpo_l3dsr_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_l3dsr_ip4[]
Definition: lb.c:69

Definition at line 70 of file lb.c.

const char* const* const lb_dpo_l3dsr_port_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_l3dsr_ip4_port[]
Definition: lb.c:75

Definition at line 76 of file lb.c.

const char* const lb_dpo_nat4_ip4_port[] = { "lb4-nat4-port" , NULL }
static

Definition at line 81 of file lb.c.

const char* const* const lb_dpo_nat4_port_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_nat4_ip4_port[]
Definition: lb.c:81

Definition at line 82 of file lb.c.

const char* const lb_dpo_nat6_ip6_port[] = { "lb6-nat6-port" , NULL }
static

Definition at line 87 of file lb.c.

const char* const* const lb_dpo_nat6_port_nodes[DPO_PROTO_NUM]
static
Initial value:
=
{
}
static const char *const lb_dpo_nat6_ip6_port[]
Definition: lb.c:87

Definition at line 88 of file lb.c.

lb_main_t lb_main

Definition at line 29 of file lb.c.

char* lb_vip_type_strings[]
static
Initial value:

Definition at line 121 of file lb.c.