From 48e26367cfe731d31472e18c1e0f6fe94bc4e9c3 Mon Sep 17 00:00:00 2001 From: Brian Russell Date: Wed, 10 Feb 2021 13:53:42 +0000 Subject: policer: add api to bind policer to worker Add a new api to allow a policer to be bound to a specific worker thread for thread handoff. Type: improvement Signed-off-by: Brian Russell Change-Id: I2623a6827843c3d93c0d7b4ad7c2e13611ec1696 --- src/vnet/policer/policer.c | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) (limited to 'src/vnet/policer/policer.c') diff --git a/src/vnet/policer/policer.c b/src/vnet/policer/policer.c index 2c05ae21515..8146d4bb0c3 100644 --- a/src/vnet/policer/policer.c +++ b/src/vnet/policer/policer.c @@ -13,6 +13,7 @@ * limitations under the License. */ #include +#include #include #include #include @@ -133,6 +134,37 @@ policer_add_del (vlib_main_t *vm, u8 *name, qos_pol_cfg_params_st *cfg, return 0; } +int +policer_bind_worker (u8 *name, u32 worker, bool bind) +{ + vnet_policer_main_t *pm = &vnet_policer_main; + policer_read_response_type_st *policer; + uword *p; + + p = hash_get_mem (pm->policer_index_by_name, name); + if (p == 0) + { + return VNET_API_ERROR_NO_SUCH_ENTRY; + } + + policer = &pm->policers[p[0]]; + + if (bind) + { + if (worker >= vlib_num_workers ()) + { + return VNET_API_ERROR_INVALID_WORKER; + } + + policer->thread_index = vlib_get_worker_thread_index (worker); + } + else + { + policer->thread_index = ~0; + } + return 0; +} + u8 * format_policer_instance (u8 * s, va_list * va) { -- cgit 1.2.3-korg