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_api.c | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) (limited to 'src/vnet/policer/policer_api.c') diff --git a/src/vnet/policer/policer_api.c b/src/vnet/policer/policer_api.c index fb66667504c..17ed73790cf 100644 --- a/src/vnet/policer/policer_api.c +++ b/src/vnet/policer/policer_api.c @@ -42,9 +42,10 @@ #include -#define foreach_vpe_api_msg \ -_(POLICER_ADD_DEL, policer_add_del) \ -_(POLICER_DUMP, policer_dump) +#define foreach_vpe_api_msg \ + _ (POLICER_ADD_DEL, policer_add_del) \ + _ (POLICER_BIND, policer_bind) \ + _ (POLICER_DUMP, policer_dump) static void vl_api_policer_add_del_t_handler (vl_api_policer_add_del_t * mp) @@ -95,6 +96,26 @@ vl_api_policer_add_del_t_handler (vl_api_policer_add_del_t * mp) /* *INDENT-ON* */ } +static void +vl_api_policer_bind_t_handler (vl_api_policer_bind_t *mp) +{ + vl_api_policer_bind_reply_t *rmp; + u8 *name; + u32 worker_index; + u8 bind_enable; + int rv; + + name = format (0, "%s", mp->name); + vec_terminate_c_string (name); + + worker_index = ntohl (mp->worker_index); + bind_enable = mp->bind_enable; + + rv = policer_bind_worker (name, worker_index, bind_enable); + vec_free (name); + REPLY_MACRO (VL_API_POLICER_BIND_REPLY); +} + static void send_policer_details (u8 *name, qos_pol_cfg_params_st *config, policer_read_response_type_st *templ, -- cgit 1.2.3-korg