X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fplugins%2Farping%2Farping_api.c;h=1b3431f2f39e923c098037ecc9ae62517febfff7;hb=8af78b8e360f12ffb9e347868a6e820bee618b81;hp=50fbb04115bcd8cafdc4ead405edf6eb33ddda5d;hpb=34850e01876005422ba9523df5ae0400964e1c91;p=vpp.git diff --git a/src/plugins/arping/arping_api.c b/src/plugins/arping/arping_api.c index 50fbb04115b..1b3431f2f39 100644 --- a/src/plugins/arping/arping_api.c +++ b/src/plugins/arping/arping_api.c @@ -26,6 +26,7 @@ #include #include +#include /* define message IDs */ #include @@ -62,6 +63,36 @@ vl_api_arping_t_handler (vl_api_arping_t *mp) ({ rmp->reply_count = ntohl (args.reply_count); })); } +static void +vl_api_arping_acd_t_handler (vl_api_arping_acd_t *mp) +{ + vlib_main_t *vm = vlib_get_main (); + arping_main_t *am = &arping_main; + vl_api_arping_acd_reply_t *rmp; + arping_args_t args = { 0 }; + int rv; + + if (mp->sw_if_index != ~0) + VALIDATE_SW_IF_INDEX (mp); + + ip_address_decode2 (&mp->address, &args.address); + args.interval = clib_net_to_host_f64 (mp->interval); + args.repeat = ntohl (mp->repeat); + args.is_garp = mp->is_garp; + args.sw_if_index = ntohl (mp->sw_if_index); + args.silence = 1; + + arping_run_command (vm, &args); + rv = args.rv; + + BAD_SW_IF_INDEX_LABEL; + + REPLY_MACRO2 (VL_API_ARPING_ACD_REPLY, ({ + rmp->reply_count = ntohl (args.reply_count); + mac_address_encode (&args.recv.from4.mac, rmp->mac_address); + })); +} + /* set tup the API message handling tables */ #include clib_error_t * @@ -75,6 +106,7 @@ arping_plugin_api_hookup (vlib_main_t *vm) /* Mark API as mp safe */ vl_api_set_msg_thread_safe (vam, am->msg_id_base + VL_API_ARPING, 1); + vl_api_set_msg_thread_safe (vam, am->msg_id_base + VL_API_ARPING_ACD, 1); return 0; }