#ifndef __included_policer_h__
#define __included_policer_h__
+#include <stdbool.h>
+
#include <vlib/vlib.h>
#include <vnet/vnet.h>
typedef struct
{
/* policer pool, aligned */
- policer_read_response_type_st *policers;
+ policer_t *policers;
/* config + template h/w policer instance parallel pools */
- sse2_qos_pol_cfg_params_st *configs;
- policer_read_response_type_st *policer_templates;
+ qos_pol_cfg_params_st *configs;
+ policer_t *policer_templates;
/* Config by name hash */
uword *policer_config_by_name;
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;
+
+ /* 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[];
-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
{
- VNET_POLICER_NEXT_TRANSMIT,
VNET_POLICER_NEXT_DROP,
+ VNET_POLICER_NEXT_HANDOFF,
VNET_POLICER_N_NEXT,
} vnet_policer_next_t;
u8 *format_policer_instance (u8 * s, va_list * va);
-clib_error_t *policer_add_del (vlib_main_t * vm,
- u8 * name,
- sse2_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__ */