Code Review
/
vpp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
Harmonize vec/pool_get_aligned object sizes and alignment requests
[vpp.git]
/
src
/
vnet
/
dpo
/
load_balance.h
diff --git
a/src/vnet/dpo/load_balance.h
b/src/vnet/dpo/load_balance.h
index
1799653
..
dd9589f
100644
(file)
--- a/
src/vnet/dpo/load_balance.h
+++ b/
src/vnet/dpo/load_balance.h
@@
-36,6
+36,7
@@
#include <vnet/ip/lookup.h>
#include <vnet/dpo/dpo.h>
#include <vnet/fib/fib_types.h>
#include <vnet/ip/lookup.h>
#include <vnet/dpo/dpo.h>
#include <vnet/fib/fib_types.h>
+#include <vnet/fib/fib_entry.h>
/**
* Load-balance main
/**
* Load-balance main
@@
-81,6
+82,12
@@
typedef struct load_balance_path_t_ {
* - per-route counters
*/
typedef struct load_balance_t_ {
* - per-route counters
*/
typedef struct load_balance_t_ {
+ /**
+ * required for pool_get_aligned.
+ * memebers used in the switch path come first!
+ */
+ CLIB_CACHE_LINE_ALIGN_MARK(cacheline0);
+
/**
* number of buckets in the load-balance. always a power of 2.
*/
/**
* number of buckets in the load-balance. always a power of 2.
*/
@@
-98,6
+105,11
@@
typedef struct load_balance_t_ {
*/
dpo_proto_t lb_proto;
*/
dpo_proto_t lb_proto;
+ /**
+ * Flags from the load-balance's associated fib_entry_t
+ */
+ fib_entry_flag_t lb_fib_entry_flags;
+
/**
* The number of locks, which is approximately the number of users,
* of this load-balance.
/**
* The number of locks, which is approximately the number of users,
* of this load-balance.
@@
-167,6
+179,8
@@
extern void load_balance_set_bucket(index_t lbi,
const dpo_id_t *next);
extern void load_balance_set_urpf(index_t lbi,
index_t urpf);
const dpo_id_t *next);
extern void load_balance_set_urpf(index_t lbi,
index_t urpf);
+extern void load_balance_set_fib_entry_flags(index_t lbi,
+ fib_entry_flag_t flags);
extern index_t load_balance_get_urpf(index_t lbi);
extern u8* format_load_balance(u8 * s, va_list * args);
extern index_t load_balance_get_urpf(index_t lbi);
extern u8* format_load_balance(u8 * s, va_list * args);
@@
-174,6
+188,7
@@
extern u8* format_load_balance(u8 * s, va_list * args);
extern const dpo_id_t *load_balance_get_bucket(index_t lbi,
u32 bucket);
extern int load_balance_is_drop(const dpo_id_t *dpo);
extern const dpo_id_t *load_balance_get_bucket(index_t lbi,
u32 bucket);
extern int load_balance_is_drop(const dpo_id_t *dpo);
+extern u16 load_balance_n_buckets(index_t lbi);
extern f64 load_balance_get_multipath_tolerance(void);
extern f64 load_balance_get_multipath_tolerance(void);