X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fip%2Fpunt_api.c;h=3ca9621a410b69b2f6bebb0a44a86592b5066b8a;hb=7c03ed4;hp=33fc3f931a75560c14e776f66c9598924067a7ea;hpb=e86a8edd3c14fb41ace2a12efd17bc7772bf623f;p=vpp.git diff --git a/src/vnet/ip/punt_api.c b/src/vnet/ip/punt_api.c index 33fc3f931a7..3ca9621a410 100644 --- a/src/vnet/ip/punt_api.c +++ b/src/vnet/ip/punt_api.c @@ -40,27 +40,35 @@ #include #define foreach_punt_api_msg \ -_(PUNT, punt) \ +_(SET_PUNT, set_punt) \ _(PUNT_SOCKET_REGISTER, punt_socket_register) \ -_(PUNT_SOCKET_DEREGISTER, punt_socket_deregister) +_(PUNT_SOCKET_DEREGISTER, punt_socket_deregister) \ +_(PUNT_DUMP, punt_dump) \ +_(PUNT_SOCKET_DUMP, punt_socket_dump) static void -vl_api_punt_t_handler (vl_api_punt_t * mp) +vl_api_set_punt_t_handler (vl_api_set_punt_t * mp) { - vl_api_punt_reply_t *rmp; + vl_api_set_punt_reply_t *rmp; vlib_main_t *vm = vlib_get_main (); int rv = 0; clib_error_t *error; - error = vnet_punt_add_del (vm, mp->ipv, mp->l4_protocol, - ntohs (mp->l4_port), mp->is_add); + error = vnet_punt_add_del (vm, mp->punt.ipv, mp->punt.l4_protocol, + ntohs (mp->punt.l4_port), mp->is_add); if (error) { rv = -1; clib_error_report (error); } - REPLY_MACRO (VL_API_PUNT_REPLY); + REPLY_MACRO (VL_API_SET_PUNT_REPLY); +} + +static void +vl_api_punt_dump_t_handler (vl_api_punt_dump_t * mp) +{ + } static void @@ -70,19 +78,20 @@ vl_api_punt_socket_register_t_handler (vl_api_punt_socket_register_t * mp) vlib_main_t *vm = vlib_get_main (); int rv = 0; clib_error_t *error; - svm_queue_t *q; + vl_api_registration_t *reg; - error = vnet_punt_socket_add (vm, ntohl (mp->header_version), - mp->is_ip4, mp->l4_protocol, - ntohs (mp->l4_port), (char *) mp->pathname); + error = 0; + vnet_punt_socket_add (vm, ntohl (mp->header_version), + mp->punt.ipv, mp->punt.l4_protocol, + ntohs (mp->punt.l4_port), (char *) mp->pathname); if (error) { rv = -1; clib_error_report (error); } - q = vl_api_client_index_to_input_queue (mp->client_index); - if (!q) + reg = vl_api_client_index_to_registration (mp->client_index); + if (!reg) return; rmp = vl_msg_api_alloc (sizeof (*rmp)); @@ -92,7 +101,49 @@ vl_api_punt_socket_register_t_handler (vl_api_punt_socket_register_t * mp) char *p = vnet_punt_get_server_pathname (); /* Abstract pathnames start with \0 */ memcpy ((char *) rmp->pathname, p, sizeof (rmp->pathname)); - vl_msg_api_send_shmem (q, (u8 *) & rmp); + vl_api_send_msg (reg, (u8 *) rmp); +} + +void +send_punt_socket_details (vl_api_registration_t * reg, + u32 context, punt_socket_detail_t * p) +{ + vl_api_punt_socket_details_t *mp; + + mp = vl_msg_api_alloc (sizeof (*mp)); + if (!mp) + return; + + clib_memset (mp, 0, sizeof (*mp)); + mp->_vl_msg_id = ntohs (VL_API_PUNT_SOCKET_DETAILS); + mp->context = context; + mp->punt.ipv = p->ipv; + mp->punt.l4_protocol = p->l4_protocol; + mp->punt.l4_port = htons (p->l4_port); + memcpy (mp->pathname, p->pathname, sizeof (p->pathname)); + + vl_api_send_msg (reg, (u8 *) mp); +} + +static void +vl_api_punt_socket_dump_t_handler (vl_api_punt_socket_dump_t * mp) +{ + vl_api_registration_t *reg; + punt_socket_detail_t *p, *ps; + int rv __attribute__ ((unused)) = 0; + + reg = vl_api_client_index_to_registration (mp->client_index); + if (!reg) + return; + + ps = punt_socket_entries (mp->is_ipv6); + /* *INDENT-OFF* */ + vec_foreach (p, ps) + { + send_punt_socket_details (reg, mp->context, p); + } + /* *INDENT-ON* */ + vec_free (ps); } static void @@ -102,25 +153,25 @@ vl_api_punt_socket_deregister_t_handler (vl_api_punt_socket_deregister_t * mp) vlib_main_t *vm = vlib_get_main (); int rv = 0; clib_error_t *error; - svm_queue_t *q; + vl_api_registration_t *reg; - error = vnet_punt_socket_del (vm, mp->is_ip4, mp->l4_protocol, - ntohs (mp->l4_port)); + error = vnet_punt_socket_del (vm, mp->punt.ipv, mp->punt.l4_protocol, + ntohs (mp->punt.l4_port)); if (error) { rv = -1; clib_error_report (error); } - q = vl_api_client_index_to_input_queue (mp->client_index); - if (!q) + reg = vl_api_client_index_to_registration (mp->client_index); + if (!reg) return; rmp = vl_msg_api_alloc (sizeof (*rmp)); rmp->_vl_msg_id = htons (VL_API_PUNT_SOCKET_DEREGISTER_REPLY); rmp->context = mp->context; rmp->retval = htonl (rv); - vl_msg_api_send_shmem (q, (u8 *) & rmp); + vl_api_send_msg (reg, (u8 *) rmp); } #define vl_msg_name_crc_list