Code Review
/
vpp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
policer: output interface policer
[vpp.git]
/
src
/
vnet
/
policer
/
policer.h
diff --git
a/src/vnet/policer/policer.h
b/src/vnet/policer/policer.h
index
4d253f7
..
f5b6c0d
100644
(file)
--- a/
src/vnet/policer/policer.h
+++ b/
src/vnet/policer/policer.h
@@
-15,6
+15,8
@@
#ifndef __included_policer_h__
#define __included_policer_h__
#ifndef __included_policer_h__
#define __included_policer_h__
+#include <stdbool.h>
+
#include <vlib/vlib.h>
#include <vnet/vnet.h>
#include <vlib/vlib.h>
#include <vnet/vnet.h>
@@
-24,11
+26,11
@@
typedef struct
{
/* policer pool, aligned */
typedef struct
{
/* policer pool, aligned */
- policer_
read_response_type_s
t *policers;
+ policer_t *policers;
/* config + template h/w policer instance parallel pools */
qos_pol_cfg_params_st *configs;
/* config + template h/w policer instance parallel pools */
qos_pol_cfg_params_st *configs;
- policer_
read_response_type_s
t *policer_templates;
+ policer_t *policer_templates;
/* Config by name hash */
uword *policer_config_by_name;
/* Config by name hash */
uword *policer_config_by_name;
@@
-37,30
+39,31
@@
typedef struct
uword *policer_index_by_name;
/* Policer by sw_if_index vector */
uword *policer_index_by_name;
/* Policer by sw_if_index vector */
- u32 *policer_index_by_sw_if_index;
+ u32 *policer_index_by_sw_if_index
[VLIB_N_RX_TX]
;
/* convenience */
vlib_main_t *vlib_main;
vnet_main_t *vnet_main;
vlib_log_class_t log_class;
/* convenience */
vlib_main_t *vlib_main;
vnet_main_t *vnet_main;
vlib_log_class_t log_class;
+
+ /* frame queue for thread handoff */
+ u32 fq_index[VLIB_N_RX_TX];
+
+ u16 msg_id_base;
} vnet_policer_main_t;
extern vnet_policer_main_t vnet_policer_main;
extern vlib_combined_counter_main_t policer_counters[];
} vnet_policer_main_t;
extern vnet_policer_main_t vnet_policer_main;
extern vlib_combined_counter_main_t policer_counters[];
-typedef enum
-{
- VNET_POLICER_INDEX_BY_SW_IF_INDEX,
- VNET_POLICER_INDEX_BY_OPAQUE,
- VNET_POLICER_INDEX_BY_EITHER,
-} vnet_policer_index_t;
+extern vlib_node_registration_t policer_input_node;
+extern vlib_node_registration_t policer_output_node;
typedef enum
{
typedef enum
{
- VNET_POLICER_NEXT_TRANSMIT,
VNET_POLICER_NEXT_DROP,
VNET_POLICER_NEXT_DROP,
+ VNET_POLICER_NEXT_HANDOFF,
VNET_POLICER_N_NEXT,
} vnet_policer_next_t;
VNET_POLICER_N_NEXT,
} vnet_policer_next_t;
@@
-68,6
+71,8
@@
u8 *format_policer_instance (u8 * s, va_list * va);
clib_error_t *policer_add_del (vlib_main_t *vm, u8 *name,
qos_pol_cfg_params_st *cfg, u32 *policer_index,
u8 is_add);
clib_error_t *policer_add_del (vlib_main_t *vm, u8 *name,
qos_pol_cfg_params_st *cfg, u32 *policer_index,
u8 is_add);
+int policer_bind_worker (u8 *name, u32 worker, bool bind);
+int policer_input (u8 *name, u32 sw_if_index, vlib_dir_t dir, bool apply);
#endif /* __included_policer_h__ */
#endif /* __included_policer_h__ */