Code Review
/
vpp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
FIB Interpose Source
[vpp.git]
/
src
/
vnet
/
fib
/
fib_test.h
diff --git
a/src/vnet/fib/fib_test.h
b/src/vnet/fib/fib_test.h
index
b98680b
..
b2abcf5
100644
(file)
--- a/
src/vnet/fib/fib_test.h
+++ b/
src/vnet/fib/fib_test.h
@@
-17,15
+17,26
@@
#define __FIB_TEST_H__
#include <vnet/fib/fib_types.h>
#define __FIB_TEST_H__
#include <vnet/fib/fib_types.h>
+#include <vnet/mpls/mpls_types.h>
+#include <vnet/fib/fib_types.h>
+#include <vnet/mpls/packet.h>
+#include <vnet/dpo/load_balance.h>
+#include <vnet/adj/adj_types.h>
+#include <vnet/dpo/replicate_dpo.h>
typedef enum fib_test_lb_bucket_type_t_ {
FT_LB_LABEL_O_ADJ,
FT_LB_LABEL_STACK_O_ADJ,
FT_LB_LABEL_O_LB,
FT_LB_O_LB,
typedef enum fib_test_lb_bucket_type_t_ {
FT_LB_LABEL_O_ADJ,
FT_LB_LABEL_STACK_O_ADJ,
FT_LB_LABEL_O_LB,
FT_LB_O_LB,
- FT_LB_SPECIAL,
- FT_LB_ADJ,
+ FT_LB_MPLS_DISP_PIPE_O_ADJ,
FT_LB_INTF,
FT_LB_INTF,
+ FT_LB_L2,
+ FT_LB_BIER_TABLE,
+ FT_LB_BIER_FMASK,
+ FT_LB_DROP,
+ FT_LB_PUNT,
+ FT_LB_ADJ,
} fib_test_lb_bucket_type_t;
typedef struct fib_test_lb_bucket_t_ {
} fib_test_lb_bucket_type_t;
typedef struct fib_test_lb_bucket_t_ {
@@
-37,6
+48,7
@@
typedef struct fib_test_lb_bucket_t_ {
{
mpls_eos_bit_t eos;
mpls_label_t label;
{
mpls_eos_bit_t eos;
mpls_label_t label;
+ fib_mpls_lsp_mode_t mode;
u8 ttl;
adj_index_t adj;
} label_o_adj;
u8 ttl;
adj_index_t adj;
} label_o_adj;
@@
-44,6
+56,7
@@
typedef struct fib_test_lb_bucket_t_ {
{
mpls_eos_bit_t eos;
mpls_label_t label_stack[8];
{
mpls_eos_bit_t eos;
mpls_label_t label_stack[8];
+ fib_mpls_lsp_mode_t mode;
u8 label_stack_size;
u8 ttl;
adj_index_t adj;
u8 label_stack_size;
u8 ttl;
adj_index_t adj;
@@
-52,6
+65,7
@@
typedef struct fib_test_lb_bucket_t_ {
{
mpls_eos_bit_t eos;
mpls_label_t label;
{
mpls_eos_bit_t eos;
mpls_label_t label;
+ fib_mpls_lsp_mode_t mode;
u8 ttl;
index_t lb;
} label_o_lb;
u8 ttl;
index_t lb;
} label_o_lb;
@@
-67,11
+81,19
@@
typedef struct fib_test_lb_bucket_t_ {
{
index_t adj;
} special;
{
index_t adj;
} special;
+ struct
+ {
+ union {
+ index_t table;
+ index_t fmask;
+ };
+ } bier;
};
} fib_test_lb_bucket_t;
typedef enum fib_test_rep_bucket_type_t_ {
FT_REP_LABEL_O_ADJ,
};
} fib_test_lb_bucket_t;
typedef enum fib_test_rep_bucket_type_t_ {
FT_REP_LABEL_O_ADJ,
+ FT_REP_DISP_MFIB_LOOKUP,
FT_REP_INTF,
} fib_test_rep_bucket_type_t;
FT_REP_INTF,
} fib_test_rep_bucket_type_t;
@@
-97,15
+119,20
@@
typedef struct fib_test_rep_bucket_t_ {
extern int fib_test_validate_rep_v(const replicate_t *rep,
u16 n_buckets,
extern int fib_test_validate_rep_v(const replicate_t *rep,
u16 n_buckets,
- va_list ap);
+ va_list
*
ap);
extern int fib_test_validate_lb_v(const load_balance_t *lb,
extern int fib_test_validate_lb_v(const load_balance_t *lb,
- u16 n_buckets,
- va_list ap);
+ int n_buckets,
+ va_list *ap);
+
+extern int fib_test_validate_lb(const dpo_id_t *dpo,
+ int n_buckets,
+ ...);
extern int fib_test_validate_entry(fib_node_index_t fei,
fib_forward_chain_type_t fct,
extern int fib_test_validate_entry(fib_node_index_t fei,
fib_forward_chain_type_t fct,
-
u16
n_buckets,
+
int
n_buckets,
...);
...);
+
#endif
#endif