52833eb6f862fd4d93e6bef883681df17f821e1c
[vpp.git] / src / vpp / api / test_client.c
1 /*
2  *------------------------------------------------------------------
3  * api.c - message handler registration
4  *
5  * Copyright (c) 2010 Cisco and/or its affiliates.
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at:
9  *
10  *     http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *------------------------------------------------------------------
18  */
19
20 #include <stdio.h>
21 #include <stdlib.h>
22 #include <sys/types.h>
23 #include <sys/mman.h>
24 #include <sys/stat.h>
25 #include <netinet/in.h>
26 #include <signal.h>
27 #include <pthread.h>
28 #include <unistd.h>
29 #include <time.h>
30 #include <fcntl.h>
31 #include <string.h>
32 #include <vppinfra/clib.h>
33 #include <vppinfra/vec.h>
34 #include <vppinfra/hash.h>
35 #include <vppinfra/bitmap.h>
36 #include <vppinfra/fifo.h>
37 #include <vppinfra/time.h>
38 #include <vppinfra/mheap.h>
39 #include <vppinfra/heap.h>
40 #include <vppinfra/pool.h>
41 #include <vppinfra/format.h>
42 #include <vppinfra/error.h>
43
44 #include <vnet/vnet.h>
45 #include <vlib/vlib.h>
46 #include <vlib/unix/unix.h>
47 #include <vlibapi/api.h>
48 #include <vlibmemory/api.h>
49
50 #include <vpp/api/vpe_msg_enum.h>
51
52 #include <vnet/ip/ip.h>
53 #include <vnet/interface.h>
54
55 #define f64_endian(a)
56 #define f64_print(a,b)
57
58 #define vl_typedefs             /* define message structures */
59 #include <vpp/api/vpe_all_api_h.h>
60 #undef vl_typedefs
61
62 #define vl_endianfun            /* define message structures */
63 #include <vpp/api/vpe_all_api_h.h>
64 #undef vl_endianfun
65
66 /* instantiate all the print functions we know about */
67 #define vl_print(handle, ...)
68 #define vl_printfun
69 #include <vpp/api/vpe_all_api_h.h>
70 #undef vl_printfun
71
72 vl_shmem_hdr_t *shmem_hdr;
73
74 typedef struct
75 {
76   int link_events_on;
77   int stats_on;
78   int oam_events_on;
79
80   /* convenience */
81   unix_shared_memory_queue_t *vl_input_queue;
82   u32 my_client_index;
83 } test_main_t;
84
85 test_main_t test_main;
86
87 /*
88  * Satisfy external references when -lvlib is not available.
89  */
90 vlib_main_t vlib_global_main;
91 vlib_main_t **vlib_mains;
92
93 void
94 vlib_cli_output (struct vlib_main_t *vm, char *fmt, ...)
95 {
96   clib_warning ("vlib_cli_output callled...");
97 }
98
99 u8 *
100 format_ethernet_address (u8 * s, va_list * args)
101 {
102   u8 *a = va_arg (*args, u8 *);
103
104   return format (s, "%02x:%02x:%02x:%02x:%02x:%02x",
105                  a[0], a[1], a[2], a[3], a[4], a[5]);
106 }
107
108 static void
109 vl_api_sw_interface_details_t_handler (vl_api_sw_interface_details_t * mp)
110 {
111   char *duplex, *speed;
112
113   switch (mp->link_duplex << VNET_HW_INTERFACE_FLAG_DUPLEX_SHIFT)
114     {
115     case VNET_HW_INTERFACE_FLAG_HALF_DUPLEX:
116       duplex = "half";
117       break;
118     case VNET_HW_INTERFACE_FLAG_FULL_DUPLEX:
119       duplex = "full";
120       break;
121     default:
122       duplex = "bogus";
123       break;
124     }
125   switch (mp->link_speed << VNET_HW_INTERFACE_FLAG_SPEED_SHIFT)
126     {
127     case VNET_HW_INTERFACE_FLAG_SPEED_10M:
128       speed = "10Mbps";
129       break;
130     case VNET_HW_INTERFACE_FLAG_SPEED_100M:
131       speed = "100Mbps";
132       break;
133     case VNET_HW_INTERFACE_FLAG_SPEED_1G:
134       speed = "1Gbps";
135       break;
136     case VNET_HW_INTERFACE_FLAG_SPEED_10G:
137       speed = "10Gbps";
138       break;
139     case VNET_HW_INTERFACE_FLAG_SPEED_40G:
140       speed = "40Gbps";
141       break;
142     case VNET_HW_INTERFACE_FLAG_SPEED_100G:
143       speed = "100Gbps";
144       break;
145     default:
146       speed = "bogus";
147       break;
148     }
149   fformat (stdout, "details: %s sw_if_index %d sup_sw_if_index %d "
150            "link_duplex %s link_speed %s",
151            mp->interface_name, ntohl (mp->sw_if_index),
152            ntohl (mp->sup_sw_if_index), duplex, speed);
153
154   if (mp->l2_address_length)
155     fformat (stdout, "  l2 address: %U\n",
156              format_ethernet_address, mp->l2_address);
157   else
158     fformat (stdout, "\n");
159 }
160
161 static void
162 vl_api_sw_interface_set_flags_t_handler (vl_api_sw_interface_set_flags_t * mp)
163 {
164   fformat (stdout, "set flags: sw_if_index %d, admin %s\n",
165            ntohl (mp->sw_if_index), mp->admin_up_down ? "up" : "down");
166 }
167
168 static void
169   vl_api_sw_interface_set_flags_reply_t_handler
170   (vl_api_sw_interface_set_flags_reply_t * mp)
171 {
172   fformat (stdout, "set flags reply: reply %d\n", ntohl (mp->retval));
173 }
174
175 static void
176   vl_api_want_interface_events_reply_t_handler
177   (vl_api_want_interface_events_reply_t * mp)
178 {
179 }
180
181 static void
182 vl_api_want_stats_reply_t_handler (vl_api_want_stats_reply_t * mp)
183 {
184   fformat (stdout, "want stats reply %d\n", ntohl (mp->retval));
185 }
186
187 static void
188 vl_api_want_oam_events_reply_t_handler (vl_api_want_oam_events_reply_t * mp)
189 {
190   fformat (stdout, "want oam reply %d\n", ntohl (mp->retval));
191 }
192
193 static void
194 vl_api_ip_add_del_route_reply_t_handler (vl_api_ip_add_del_route_reply_t * mp)
195 {
196   fformat (stdout, "add_route reply %d\n", ntohl (mp->retval));
197 }
198
199 static void
200   vl_api_sw_interface_add_del_address_reply_t_handler
201   (vl_api_sw_interface_add_del_address_reply_t * mp)
202 {
203   fformat (stdout, "add_del_address reply %d\n", ntohl (mp->retval));
204 }
205
206 static void
207   vl_api_sw_interface_set_table_reply_t_handler
208   (vl_api_sw_interface_set_table_reply_t * mp)
209 {
210   fformat (stdout, "set_table reply %d\n", ntohl (mp->retval));
211 }
212
213 static void
214 vl_api_tap_connect_reply_t_handler (vl_api_tap_connect_reply_t * mp)
215 {
216   fformat (stdout, "tap connect reply %d, sw_if_index %d\n",
217            ntohl (mp->retval), ntohl (mp->sw_if_index));
218 }
219
220 static void
221 vl_api_create_vlan_subif_reply_t_handler (vl_api_create_vlan_subif_reply_t *
222                                           mp)
223 {
224   fformat (stdout, "create vlan subif reply %d, sw_if_index %d\n",
225            ntohl (mp->retval), ntohl (mp->sw_if_index));
226 }
227
228 static void vl_api_proxy_arp_add_del_reply_t_handler
229   (vl_api_proxy_arp_add_del_reply_t * mp)
230 {
231   fformat (stdout, "add del proxy arp reply %d\n", ntohl (mp->retval));
232 }
233
234 static void vl_api_proxy_arp_intfc_enable_disable_reply_t_handler
235   (vl_api_proxy_arp_intfc_enable_disable_reply_t * mp)
236 {
237   fformat (stdout, "proxy arp intfc ena/dis reply %d\n", ntohl (mp->retval));
238 }
239
240 static void vl_api_ip_neighbor_add_del_reply_t_handler
241   (vl_api_ip_neighbor_add_del_reply_t * mp)
242 {
243   fformat (stdout, "ip neighbor add del reply %d\n", ntohl (mp->retval));
244 }
245
246 #if 0
247 static void
248 vl_api_vnet_interface_counters_t_handler (vl_api_vnet_interface_counters_t *
249                                           mp)
250 {
251   char *counter_name;
252   u32 count, sw_if_index;
253   int i;
254
255   count = ntohl (mp->count);
256   sw_if_index = ntohl (mp->first_sw_if_index);
257   if (mp->is_combined == 0)
258     {
259       u64 *vp, v;
260       vp = (u64 *) mp->data;
261
262       switch (mp->vnet_counter_type)
263         {
264         case VNET_INTERFACE_COUNTER_DROP:
265           counter_name = "drop";
266           break;
267         case VNET_INTERFACE_COUNTER_PUNT:
268           counter_name = "punt";
269           break;
270         case VNET_INTERFACE_COUNTER_IP4:
271           counter_name = "ip4";
272           break;
273         case VNET_INTERFACE_COUNTER_IP6:
274           counter_name = "ip6";
275           break;
276         case VNET_INTERFACE_COUNTER_RX_NO_BUF:
277           counter_name = "rx-no-buf";
278           break;
279         case VNET_INTERFACE_COUNTER_RX_MISS:
280           counter_name = "rx-miss";
281           break;
282         case VNET_INTERFACE_COUNTER_RX_ERROR:
283           counter_name = "rx-error";
284           break;
285         case VNET_INTERFACE_COUNTER_TX_ERROR:
286           counter_name = "tx-error (fifo-full)";
287           break;
288         default:
289           counter_name = "bogus";
290           break;
291         }
292       for (i = 0; i < count; i++)
293         {
294           v = clib_mem_unaligned (vp, u64);
295           v = clib_net_to_host_u64 (v);
296           vp++;
297           fformat (stdout, "%d.%s %lld\n", sw_if_index, counter_name, v);
298           sw_if_index++;
299         }
300     }
301   else
302     {
303       vlib_counter_t *vp;
304       u64 packets, bytes;
305       vp = (vlib_counter_t *) mp->data;
306
307       switch (mp->vnet_counter_type)
308         {
309         case VNET_INTERFACE_COUNTER_RX:
310           counter_name = "rx";
311           break;
312         case VNET_INTERFACE_COUNTER_TX:
313           counter_name = "tx";
314           break;
315         default:
316           counter_name = "bogus";
317           break;
318         }
319       for (i = 0; i < count; i++)
320         {
321           packets = clib_mem_unaligned (&vp->packets, u64);
322           packets = clib_net_to_host_u64 (packets);
323           bytes = clib_mem_unaligned (&vp->bytes, u64);
324           bytes = clib_net_to_host_u64 (bytes);
325           vp++;
326           fformat (stdout, "%d.%s.packets %lld\n",
327                    sw_if_index, counter_name, packets);
328           fformat (stdout, "%d.%s.bytes %lld\n",
329                    sw_if_index, counter_name, bytes);
330           sw_if_index++;
331         }
332     }
333 }
334 #endif
335
336 /* Format an IP4 address. */
337 u8 *
338 format_ip4_address (u8 * s, va_list * args)
339 {
340   u8 *a = va_arg (*args, u8 *);
341   return format (s, "%d.%d.%d.%d", a[0], a[1], a[2], a[3]);
342 }
343
344 /* Format an IP4 route destination and length. */
345 u8 *
346 format_ip4_address_and_length (u8 * s, va_list * args)
347 {
348   u8 *a = va_arg (*args, u8 *);
349   u8 l = va_arg (*args, u32);
350   return format (s, "%U/%d", format_ip4_address, a, l);
351 }
352
353 static void
354 vl_api_vnet_ip4_fib_counters_t_handler (vl_api_vnet_ip4_fib_counters_t * mp)
355 {
356   int i;
357   vl_api_ip4_fib_counter_t *ctrp;
358   u32 count;
359
360   count = ntohl (mp->count);
361
362   fformat (stdout, "fib id %d, count this msg %d\n",
363            ntohl (mp->vrf_id), count);
364
365   ctrp = mp->c;
366   for (i = 0; i < count; i++)
367     {
368       fformat (stdout, "%U: %lld packets, %lld bytes\n",
369                format_ip4_address_and_length, &ctrp->address,
370                (u32) ctrp->address_length,
371                clib_net_to_host_u64 (ctrp->packets),
372                clib_net_to_host_u64 (ctrp->bytes));
373       ctrp++;
374     }
375 }
376
377 /* Format an IP6 address. */
378 u8 *
379 format_ip6_address (u8 * s, va_list * args)
380 {
381   ip6_address_t *a = va_arg (*args, ip6_address_t *);
382   u32 i, i_max_n_zero, max_n_zeros, i_first_zero, n_zeros, last_double_colon;
383
384   i_max_n_zero = ARRAY_LEN (a->as_u16);
385   max_n_zeros = 0;
386   i_first_zero = i_max_n_zero;
387   n_zeros = 0;
388   for (i = 0; i < ARRAY_LEN (a->as_u16); i++)
389     {
390       u32 is_zero = a->as_u16[i] == 0;
391       if (is_zero && i_first_zero >= ARRAY_LEN (a->as_u16))
392         {
393           i_first_zero = i;
394           n_zeros = 0;
395         }
396       n_zeros += is_zero;
397       if ((!is_zero && n_zeros > max_n_zeros)
398           || (i + 1 >= ARRAY_LEN (a->as_u16) && n_zeros > max_n_zeros))
399         {
400           i_max_n_zero = i_first_zero;
401           max_n_zeros = n_zeros;
402           i_first_zero = ARRAY_LEN (a->as_u16);
403           n_zeros = 0;
404         }
405     }
406
407   last_double_colon = 0;
408   for (i = 0; i < ARRAY_LEN (a->as_u16); i++)
409     {
410       if (i == i_max_n_zero && max_n_zeros > 1)
411         {
412           s = format (s, "::");
413           i += max_n_zeros - 1;
414           last_double_colon = 1;
415         }
416       else
417         {
418           s = format (s, "%s%x",
419                       (last_double_colon || i == 0) ? "" : ":",
420                       clib_net_to_host_u16 (a->as_u16[i]));
421           last_double_colon = 0;
422         }
423     }
424
425   return s;
426 }
427
428 /* Format an IP6 route destination and length. */
429 u8 *
430 format_ip6_address_and_length (u8 * s, va_list * args)
431 {
432   ip6_address_t *a = va_arg (*args, ip6_address_t *);
433   u8 l = va_arg (*args, u32);
434   return format (s, "%U/%d", format_ip6_address, a, l);
435 }
436
437 static void
438 vl_api_vnet_ip6_fib_counters_t_handler (vl_api_vnet_ip6_fib_counters_t * mp)
439 {
440   int i;
441   vl_api_ip6_fib_counter_t *ctrp;
442   u32 count;
443
444   count = ntohl (mp->count);
445
446   fformat (stdout, "fib id %d, count this msg %d\n",
447            ntohl (mp->vrf_id), count);
448
449   ctrp = mp->c;
450   for (i = 0; i < count; i++)
451     {
452       fformat (stdout, "%U: %lld packets, %lld bytes\n",
453                format_ip6_address_and_length, &ctrp->address,
454                (u32) ctrp->address_length,
455                clib_net_to_host_u64 (ctrp->packets),
456                clib_net_to_host_u64 (ctrp->bytes));
457       ctrp++;
458     }
459 }
460
461 static void
462 vl_api_oam_event_t_handler (vl_api_oam_event_t * mp)
463 {
464   fformat (stdout, "OAM: %U now %s\n",
465            format_ip4_address, &mp->dst_address,
466            mp->state == 1 ? "alive" : "dead");
467 }
468
469 static void
470 vl_api_oam_add_del_reply_t_handler (vl_api_oam_add_del_reply_t * mp)
471 {
472   fformat (stdout, "oam add del reply %d\n", ntohl (mp->retval));
473 }
474
475 static void
476 vl_api_reset_fib_reply_t_handler (vl_api_reset_fib_reply_t * mp)
477 {
478   fformat (stdout, "fib reset reply %d\n", ntohl (mp->retval));
479 }
480
481 static void
482 vl_api_dhcp_proxy_set_vss_reply_t_handler (vl_api_dhcp_proxy_set_vss_reply_t *
483                                            mp)
484 {
485   fformat (stdout, "dhcp proxy set vss reply %d\n", ntohl (mp->retval));
486 }
487
488 static void
489 vl_api_dhcp_proxy_config_reply_t_handler (vl_api_dhcp_proxy_config_reply_t *
490                                           mp)
491 {
492   fformat (stdout, "dhcp proxy config reply %d\n", ntohl (mp->retval));
493 }
494
495 static void
496 vl_api_set_ip_flow_hash_reply_t_handler (vl_api_set_ip_flow_hash_reply_t * mp)
497 {
498   fformat (stdout, "set ip flow hash reply %d\n", ntohl (mp->retval));
499 }
500
501 static void
502   vl_api_sw_interface_ip6nd_ra_config_reply_t_handler
503   (vl_api_sw_interface_ip6nd_ra_config_reply_t * mp)
504 {
505   fformat (stdout, "ip6 nd ra-config  reply %d\n", ntohl (mp->retval));
506 }
507
508 static void
509   vl_api_sw_interface_ip6nd_ra_prefix_reply_t_handler
510   (vl_api_sw_interface_ip6nd_ra_prefix_reply_t * mp)
511 {
512   fformat (stdout, "ip6 nd ra-prefix  reply %d\n", ntohl (mp->retval));
513 }
514
515 static void
516   vl_api_sw_interface_ip6_enable_disable_reply_t_handler
517   (vl_api_sw_interface_ip6_enable_disable_reply_t * mp)
518 {
519   fformat (stdout, "ip6 enable/disable reply %d\n", ntohl (mp->retval));
520 }
521
522 static void
523   vl_api_sw_interface_ip6_set_link_local_address_reply_t_handler
524   (vl_api_sw_interface_ip6_set_link_local_address_reply_t * mp)
525 {
526   fformat (stdout, "ip6 set link-local address reply %d\n",
527            ntohl (mp->retval));
528 }
529
530 static void vl_api_create_loopback_reply_t_handler
531   (vl_api_create_loopback_reply_t * mp)
532 {
533   fformat (stdout, "create loopback status %d, sw_if_index %d\n",
534            ntohl (mp->retval), ntohl (mp->sw_if_index));
535 }
536
537 static void vl_api_create_loopback_instance_reply_t_handler
538   (vl_api_create_loopback_instance_reply_t * mp)
539 {
540   fformat (stdout, "create loopback status %d, sw_if_index %d\n",
541            ntohl (mp->retval), ntohl (mp->sw_if_index));
542 }
543
544 static void vl_api_l2_patch_add_del_reply_t_handler
545   (vl_api_l2_patch_add_del_reply_t * mp)
546 {
547   fformat (stdout, "l2 patch reply %d\n", ntohl (mp->retval));
548 }
549
550 static void vl_api_sw_interface_set_l2_xconnect_reply_t_handler
551   (vl_api_sw_interface_set_l2_xconnect_reply_t * mp)
552 {
553   fformat (stdout, "l2_xconnect reply %d\n", ntohl (mp->retval));
554 }
555
556 static void vl_api_sw_interface_set_l2_bridge_reply_t_handler
557   (vl_api_sw_interface_set_l2_bridge_reply_t * mp)
558 {
559   fformat (stdout, "l2_bridge reply %d\n", ntohl (mp->retval));
560 }
561
562 static void
563 noop_handler (void *notused)
564 {
565 }
566
567 #define vl_api_vnet_ip4_fib_counters_t_endian noop_handler
568 #define vl_api_vnet_ip4_fib_counters_t_print noop_handler
569 #define vl_api_vnet_ip6_fib_counters_t_endian noop_handler
570 #define vl_api_vnet_ip6_fib_counters_t_print noop_handler
571
572 #define foreach_api_msg                                                 \
573 _(SW_INTERFACE_DETAILS, sw_interface_details)                           \
574 _(SW_INTERFACE_SET_FLAGS, sw_interface_set_flags)                       \
575 _(SW_INTERFACE_SET_FLAGS_REPLY, sw_interface_set_flags_reply)           \
576 _(WANT_INTERFACE_EVENTS_REPLY, want_interface_events_reply)             \
577 _(WANT_STATS_REPLY, want_stats_reply)                                   \
578 _(WANT_OAM_EVENTS_REPLY, want_oam_events_reply)                         \
579 _(OAM_EVENT, oam_event)                                                 \
580 _(OAM_ADD_DEL_REPLY, oam_add_del_reply)                                 \
581 _(VNET_IP4_FIB_COUNTERS, vnet_ip4_fib_counters)                         \
582 _(VNET_IP6_FIB_COUNTERS, vnet_ip6_fib_counters)                         \
583 _(IP_ADD_DEL_ROUTE_REPLY, ip_add_del_route_reply)                       \
584 _(SW_INTERFACE_ADD_DEL_ADDRESS_REPLY, sw_interface_add_del_address_reply) \
585 _(SW_INTERFACE_SET_TABLE_REPLY, sw_interface_set_table_reply)           \
586 _(TAP_CONNECT_REPLY, tap_connect_reply)                                 \
587 _(CREATE_VLAN_SUBIF_REPLY, create_vlan_subif_reply)                     \
588 _(PROXY_ARP_ADD_DEL_REPLY, proxy_arp_add_del_reply)                     \
589 _(PROXY_ARP_INTFC_ENABLE_DISABLE_REPLY, proxy_arp_intfc_enable_disable_reply) \
590 _(IP_NEIGHBOR_ADD_DEL_REPLY, ip_neighbor_add_del_reply)                 \
591 _(RESET_FIB_REPLY, reset_fib_reply)                                     \
592 _(DHCP_PROXY_CONFIG_REPLY, dhcp_proxy_config_reply)                     \
593 _(DHCP_PROXY_SET_VSS_REPLY, dhcp_proxy_set_vss_reply)                   \
594 _(SET_IP_FLOW_HASH_REPLY, set_ip_flow_hash_reply)                       \
595 _(SW_INTERFACE_IP6ND_RA_CONFIG_REPLY, sw_interface_ip6nd_ra_config_reply) \
596 _(SW_INTERFACE_IP6ND_RA_PREFIX_REPLY, sw_interface_ip6nd_ra_prefix_reply) \
597 _(SW_INTERFACE_IP6_ENABLE_DISABLE_REPLY, sw_interface_ip6_enable_disable_reply) \
598 _(SW_INTERFACE_IP6_SET_LINK_LOCAL_ADDRESS_REPLY, sw_interface_ip6_set_link_local_address_reply) \
599  _(CREATE_LOOPBACK_REPLY, create_loopback_reply)                        \
600  _(CREATE_LOOPBACK_INSTANCE_REPLY, create_loopback_instance_reply)      \
601 _(L2_PATCH_ADD_DEL_REPLY, l2_patch_add_del_reply)                       \
602 _(SW_INTERFACE_SET_L2_XCONNECT_REPLY, sw_interface_set_l2_xconnect_reply) \
603 _(SW_INTERFACE_SET_L2_BRIDGE_REPLY, sw_interface_set_l2_bridge_reply)
604
605 int
606 connect_to_vpe (char *name)
607 {
608   int rv = 0;
609
610   rv = vl_client_connect_to_vlib ("/vpe-api", name, 32);
611
612 #define _(N,n)                                                  \
613     vl_msg_api_set_handlers(VL_API_##N, #n,                     \
614                            vl_api_##n##_t_handler,              \
615                            noop_handler,                        \
616                            vl_api_##n##_t_endian,               \
617                            vl_api_##n##_t_print,                \
618                            sizeof(vl_api_##n##_t), 1);
619   foreach_api_msg;
620 #undef _
621
622   shmem_hdr = api_main.shmem_hdr;
623
624   return rv;
625 }
626
627 int
628 disconnect_from_vpe (void)
629 {
630   vl_client_disconnect_from_vlib ();
631   return 0;
632 }
633
634 void
635 link_up_down_enable_disable (test_main_t * tm, int enable)
636 {
637   vl_api_want_interface_events_t *mp;
638
639   /* Request admin / link up down messages */
640   mp = vl_msg_api_alloc (sizeof (*mp));
641   memset (mp, 0, sizeof (*mp));
642   mp->_vl_msg_id = ntohs (VL_API_WANT_INTERFACE_EVENTS);
643   mp->client_index = tm->my_client_index;
644   mp->context = 0xdeadbeef;
645   mp->enable_disable = enable;
646   mp->pid = getpid ();
647   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
648   tm->link_events_on = enable;
649 }
650
651 void
652 stats_enable_disable (test_main_t * tm, int enable)
653 {
654   vl_api_want_stats_t *mp;
655
656   mp = vl_msg_api_alloc (sizeof (*mp));
657   memset (mp, 0, sizeof (*mp));
658   mp->_vl_msg_id = ntohs (VL_API_WANT_STATS);
659   mp->client_index = tm->my_client_index;
660   mp->context = 0xdeadbeef;
661   mp->enable_disable = enable;
662   mp->pid = getpid ();
663   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
664   tm->stats_on = enable;
665 }
666
667 void
668 oam_events_enable_disable (test_main_t * tm, int enable)
669 {
670   vl_api_want_oam_events_t *mp;
671
672   mp = vl_msg_api_alloc (sizeof (*mp));
673   memset (mp, 0, sizeof (*mp));
674   mp->_vl_msg_id = ntohs (VL_API_WANT_OAM_EVENTS);
675   mp->client_index = tm->my_client_index;
676   mp->context = 0xdeadbeef;
677   mp->enable_disable = enable;
678   mp->pid = getpid ();
679   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
680   tm->oam_events_on = enable;
681 }
682
683 void
684 oam_add_del (test_main_t * tm, int is_add)
685 {
686   vl_api_oam_add_del_t *mp;
687   ip4_address_t tmp;
688
689   mp = vl_msg_api_alloc (sizeof (*mp));
690   memset (mp, 0, sizeof (*mp));
691   mp->_vl_msg_id = ntohs (VL_API_OAM_ADD_DEL);
692   mp->client_index = tm->my_client_index;
693   mp->context = 0xdeadbeef;
694   mp->is_add = is_add;
695
696   tmp.as_u32 = ntohl (0xc0a80101);      /* 192.168.1.1 */
697   clib_memcpy (mp->src_address, tmp.as_u8, 4);
698
699   tmp.as_u32 = ntohl (0xc0a80103);      /* 192.168.1.3 */
700   clib_memcpy (mp->dst_address, tmp.as_u8, 4);
701
702   mp->vrf_id = 0;
703   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
704 }
705
706 void
707 dump (test_main_t * tm)
708 {
709   vl_api_sw_interface_dump_t *mp;
710
711   mp = vl_msg_api_alloc (sizeof (*mp));
712   memset (mp, 0, sizeof (*mp));
713   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_DUMP);
714   mp->client_index = tm->my_client_index;
715   mp->name_filter_valid = 1;
716   strncpy ((char *) mp->name_filter, "eth", sizeof (mp->name_filter) - 1);
717
718   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
719 }
720
721 void
722 add_del_ip4_route (test_main_t * tm, int enable_disable)
723 {
724   vl_api_ip_add_del_route_t *mp;
725   u32 tmp;
726
727   mp = vl_msg_api_alloc (sizeof (*mp));
728   memset (mp, 0, sizeof (*mp));
729   mp->_vl_msg_id = ntohs (VL_API_IP_ADD_DEL_ROUTE);
730   mp->client_index = tm->my_client_index;
731   mp->context = 0xdeadbeef;
732   mp->table_id = ntohl (0);
733   mp->create_vrf_if_needed = 1;
734
735   mp->next_hop_sw_if_index = ntohl (5);
736   mp->is_add = enable_disable;
737   mp->next_hop_weight = 1;
738
739   /* Next hop: 6.0.0.1 */
740   tmp = ntohl (0x06000001);
741   clib_memcpy (mp->next_hop_address, &tmp, sizeof (tmp));
742
743   /* Destination: 10.0.0.1/32 */
744   tmp = ntohl (0x0);
745   clib_memcpy (mp->dst_address, &tmp, sizeof (tmp));
746   mp->dst_address_length = 0;
747
748   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
749 }
750
751 void
752 add_del_ip6_route (test_main_t * tm, int enable_disable)
753 {
754   vl_api_ip_add_del_route_t *mp;
755   u64 tmp[2];
756
757   mp = vl_msg_api_alloc (sizeof (*mp));
758   memset (mp, 0, sizeof (*mp));
759   mp->_vl_msg_id = ntohs (VL_API_IP_ADD_DEL_ROUTE);
760   mp->client_index = tm->my_client_index;
761   mp->context = 0xdeadbeef;
762   mp->next_hop_sw_if_index = ntohl (5);
763   mp->is_add = enable_disable;
764   mp->is_ipv6 = 1;
765   mp->next_hop_weight = 1;
766   mp->dst_address_length = 64;
767
768   /* add/del dabe::/64 via db01::11 */
769
770   tmp[0] = clib_host_to_net_u64 (0xdabe000000000000ULL);
771   tmp[1] = clib_host_to_net_u64 (0x0ULL);
772   clib_memcpy (mp->dst_address, &tmp[0], 8);
773   clib_memcpy (&mp->dst_address[8], &tmp[1], 8);
774
775   tmp[0] = clib_host_to_net_u64 (0xdb01000000000000ULL);
776   tmp[1] = clib_host_to_net_u64 (0x11ULL);
777   clib_memcpy (mp->next_hop_address, &tmp[0], 8);
778   clib_memcpy (&mp->next_hop_address[8], &tmp[1], 8);
779
780   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
781 }
782
783 void
784 add_del_interface_address (test_main_t * tm, int enable_disable)
785 {
786   vl_api_sw_interface_add_del_address_t *mp;
787   u32 tmp;
788
789   mp = vl_msg_api_alloc (sizeof (*mp));
790   memset (mp, 0, sizeof (*mp));
791   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_ADD_DEL_ADDRESS);
792   mp->client_index = tm->my_client_index;
793   mp->context = 0xdeadbeef;
794   mp->sw_if_index = ntohl (5);
795   mp->is_add = enable_disable;
796   mp->address_length = 8;
797
798   tmp = ntohl (0x01020304);
799   clib_memcpy (mp->address, &tmp, 4);
800
801   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
802 }
803
804 void
805 add_del_v6_interface_address (test_main_t * tm, int enable_disable)
806 {
807   vl_api_sw_interface_add_del_address_t *mp;
808   u64 tmp[2];
809
810   mp = vl_msg_api_alloc (sizeof (*mp));
811   memset (mp, 0, sizeof (*mp));
812   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_ADD_DEL_ADDRESS);
813   mp->client_index = tm->my_client_index;
814   mp->context = 0xdeadbeef;
815   mp->is_ipv6 = 1;
816   mp->sw_if_index = ntohl (5);
817   mp->is_add = enable_disable;
818   mp->address_length = 64;
819
820   tmp[0] = clib_host_to_net_u64 (0xdb01000000000000ULL);
821   tmp[1] = clib_host_to_net_u64 (0x11ULL);
822
823   clib_memcpy (mp->address, &tmp[0], 8);
824   clib_memcpy (&mp->address[8], &tmp[1], 8);
825
826   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
827 }
828
829 void
830 del_all_interface_addresses (test_main_t * tm)
831 {
832   vl_api_sw_interface_add_del_address_t *mp;
833
834   mp = vl_msg_api_alloc (sizeof (*mp));
835   memset (mp, 0, sizeof (*mp));
836   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_ADD_DEL_ADDRESS);
837   mp->client_index = tm->my_client_index;
838   mp->context = 0xdeadbeef;
839   mp->sw_if_index = ntohl (5);
840   mp->del_all = 1;
841
842   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
843 }
844
845 void
846 set_interface_table (test_main_t * tm, int is_ipv6, u32 vrf_id)
847 {
848   vl_api_sw_interface_set_table_t *mp;
849
850   mp = vl_msg_api_alloc (sizeof (*mp));
851   memset (mp, 0, sizeof (*mp));
852   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_SET_TABLE);
853   mp->client_index = tm->my_client_index;
854   mp->context = 0xdeadbeef;
855   mp->sw_if_index = ntohl (5);
856   mp->is_ipv6 = is_ipv6;
857   mp->vrf_id = ntohl (vrf_id);
858
859   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
860 }
861
862 void
863 connect_unix_tap (test_main_t * tm, char *name)
864 {
865   vl_api_tap_connect_t *mp;
866
867   mp = vl_msg_api_alloc (sizeof (*mp));
868   memset (mp, 0, sizeof (*mp));
869   mp->_vl_msg_id = ntohs (VL_API_TAP_CONNECT);
870   mp->client_index = tm->my_client_index;
871   mp->context = 0xdeadbeef;
872   strncpy ((char *) mp->tap_name, name, sizeof (mp->tap_name) - 1);
873   mp->use_random_mac = 1;
874   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
875 }
876
877 void
878 create_vlan_subif (test_main_t * tm, u32 vlan_id)
879 {
880   vl_api_create_vlan_subif_t *mp;
881
882   mp = vl_msg_api_alloc (sizeof (*mp));
883   memset (mp, 0, sizeof (*mp));
884   mp->_vl_msg_id = ntohs (VL_API_CREATE_VLAN_SUBIF);
885   mp->client_index = tm->my_client_index;
886   mp->context = 0xdeadbeef;
887   mp->sw_if_index = ntohl (5);
888   mp->vlan_id = ntohl (vlan_id);
889
890   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
891 }
892
893 void
894 add_del_proxy_arp (test_main_t * tm, int is_add)
895 {
896   vl_api_proxy_arp_add_del_t *mp;
897   u32 tmp;
898
899   mp = vl_msg_api_alloc (sizeof (*mp));
900   memset (mp, 0, sizeof (*mp));
901   mp->_vl_msg_id = ntohs (VL_API_PROXY_ARP_ADD_DEL);
902   mp->client_index = tm->my_client_index;
903   mp->context = 0xdeadbeef;
904   mp->vrf_id = ntohl (11);
905   mp->is_add = is_add;
906
907   /* proxy fib 11, 1.1.1.1 -> 1.1.1.10 */
908   tmp = ntohl (0x01010101);
909   clib_memcpy (mp->low_address, &tmp, 4);
910
911   tmp = ntohl (0x0101010a);
912   clib_memcpy (mp->hi_address, &tmp, 4);
913
914   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
915 }
916
917 void
918 proxy_arp_intfc_enable_disable (test_main_t * tm, int enable_disable)
919 {
920   vl_api_proxy_arp_intfc_enable_disable_t *mp;
921
922   mp = vl_msg_api_alloc (sizeof (*mp));
923   memset (mp, 0, sizeof (*mp));
924   mp->_vl_msg_id = ntohs (VL_API_PROXY_ARP_INTFC_ENABLE_DISABLE);
925   mp->client_index = tm->my_client_index;
926   mp->context = 0xdeadbeef;
927   mp->sw_if_index = ntohl (6);
928   mp->enable_disable = enable_disable;
929
930   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
931 }
932
933 void
934 add_ip4_neighbor (test_main_t * tm, int add_del)
935 {
936   vl_api_ip_neighbor_add_del_t *mp;
937   u32 tmp;
938
939   mp = vl_msg_api_alloc (sizeof (*mp));
940   memset (mp, 0, sizeof (*mp));
941   mp->_vl_msg_id = ntohs (VL_API_IP_NEIGHBOR_ADD_DEL);
942   mp->client_index = tm->my_client_index;
943   mp->context = 0xdeadbeef;
944   mp->sw_if_index = ntohl (6);
945   mp->is_add = add_del;
946
947   memset (mp->mac_address, 0xbe, sizeof (mp->mac_address));
948
949   tmp = ntohl (0x0101010a);
950   clib_memcpy (mp->dst_address, &tmp, 4);
951
952   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
953 }
954
955 void
956 add_ip6_neighbor (test_main_t * tm, int add_del)
957 {
958   vl_api_ip_neighbor_add_del_t *mp;
959   u64 tmp[2];
960
961   mp = vl_msg_api_alloc (sizeof (*mp));
962   memset (mp, 0, sizeof (*mp));
963   mp->_vl_msg_id = ntohs (VL_API_IP_NEIGHBOR_ADD_DEL);
964   mp->client_index = tm->my_client_index;
965   mp->context = 0xdeadbeef;
966   mp->sw_if_index = ntohl (6);
967   mp->is_add = add_del;
968   mp->is_ipv6 = 1;
969
970   memset (mp->mac_address, 0xbe, sizeof (mp->mac_address));
971
972   tmp[0] = clib_host_to_net_u64 (0xdb01000000000000ULL);
973   tmp[1] = clib_host_to_net_u64 (0x11ULL);
974
975   clib_memcpy (mp->dst_address, &tmp[0], 8);
976   clib_memcpy (&mp->dst_address[8], &tmp[1], 8);
977
978   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
979 }
980
981 void
982 reset_fib (test_main_t * tm, u8 is_ip6)
983 {
984   vl_api_reset_fib_t *mp;
985
986   mp = vl_msg_api_alloc (sizeof (*mp));
987   memset (mp, 0, sizeof (*mp));
988   mp->_vl_msg_id = ntohs (VL_API_RESET_FIB);
989   mp->client_index = tm->my_client_index;
990   mp->context = 0xdeadbeef;
991   mp->vrf_id = ntohl (11);
992   mp->is_ipv6 = is_ip6;
993
994   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
995 }
996
997 void
998 dhcpv6_set_vss (test_main_t * tm)
999 {
1000   vl_api_dhcp_proxy_set_vss_t *mp;
1001
1002   mp = vl_msg_api_alloc (sizeof (*mp));
1003   memset (mp, 0, sizeof (*mp));
1004   mp->_vl_msg_id = ntohs (VL_API_DHCP_PROXY_SET_VSS);
1005   mp->client_index = tm->my_client_index;
1006   mp->context = 0xdeadbeef;
1007   mp->oui = ntohl (6);
1008   mp->tbl_id = ntohl (60);
1009   mp->is_add = 1;
1010   mp->is_ipv6 = 1;
1011   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1012 }
1013
1014 void
1015 dhcpv4_set_vss (test_main_t * tm)
1016 {
1017   vl_api_dhcp_proxy_set_vss_t *mp;
1018
1019   mp = vl_msg_api_alloc (sizeof (*mp));
1020   memset (mp, 0, sizeof (*mp));
1021   mp->_vl_msg_id = ntohs (VL_API_DHCP_PROXY_SET_VSS);
1022   mp->client_index = tm->my_client_index;
1023   mp->context = 0xdeadbeef;
1024   mp->oui = ntohl (4);
1025   mp->tbl_id = ntohl (40);
1026   mp->is_add = 1;
1027   mp->is_ipv6 = 0;
1028   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1029 }
1030
1031 void
1032 dhcp_set_vss (test_main_t * tm)
1033 {
1034   dhcpv4_set_vss (tm);
1035   dhcpv6_set_vss (tm);
1036 }
1037
1038 void
1039 dhcp_set_proxy (test_main_t * tm, int ipv6)
1040 {
1041   vl_api_dhcp_proxy_config_t *mp;
1042
1043   mp = vl_msg_api_alloc (sizeof (*mp));
1044   memset (mp, 0, sizeof (*mp));
1045   mp->_vl_msg_id = ntohs (VL_API_DHCP_PROXY_CONFIG);
1046   mp->client_index = tm->my_client_index;
1047   mp->context = 0xdeadbeef;
1048   mp->is_ipv6 = ipv6;
1049   mp->is_add = 1;
1050   mp->dhcp_server[0] = 0x20;
1051   mp->dhcp_server[1] = 0x01;
1052   mp->dhcp_server[2] = 0xab;
1053   mp->dhcp_server[3] = 0xcd;
1054   mp->dhcp_server[4] = 0x12;
1055   mp->dhcp_server[5] = 0x34;
1056   mp->dhcp_server[6] = 0xfe;
1057   mp->dhcp_server[7] = 0xdc;
1058   mp->dhcp_server[14] = 0;
1059   mp->dhcp_server[15] = 0x2;
1060
1061   mp->dhcp_src_address[0] = 0x20;
1062   mp->dhcp_src_address[1] = 0x01;
1063   mp->dhcp_src_address[2] = 0xab;
1064   mp->dhcp_src_address[3] = 0xcd;
1065   mp->dhcp_src_address[4] = 0x12;
1066   mp->dhcp_src_address[5] = 0x34;
1067   mp->dhcp_src_address[6] = 0x56;
1068   mp->dhcp_src_address[7] = 0x78;
1069   mp->dhcp_src_address[14] = 0;
1070   mp->dhcp_src_address[15] = 0x2;
1071
1072   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1073 }
1074
1075 void
1076 set_ip_flow_hash (test_main_t * tm, u8 is_ip6)
1077 {
1078   vl_api_set_ip_flow_hash_t *mp;
1079
1080   mp = vl_msg_api_alloc (sizeof (*mp));
1081   memset (mp, 0, sizeof (*mp));
1082   mp->_vl_msg_id = ntohs (VL_API_SET_IP_FLOW_HASH);
1083   mp->client_index = tm->my_client_index;
1084   mp->context = 0xdeadbeef;
1085   mp->vrf_id = 0;
1086   mp->is_ipv6 = is_ip6;
1087   mp->dst = 1;
1088   mp->reverse = 1;
1089
1090   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1091 }
1092
1093 void
1094 ip6nd_ra_config (test_main_t * tm, int is_no)
1095 {
1096   vl_api_sw_interface_ip6nd_ra_config_t *mp;
1097
1098   mp = vl_msg_api_alloc (sizeof (*mp));
1099   memset (mp, 0, sizeof (*mp));
1100
1101   mp->client_index = tm->my_client_index;
1102   mp->context = 0xdeadbeef;
1103   mp->sw_if_index = ntohl (5);
1104   mp->is_no = is_no;
1105
1106   mp->suppress = 1;
1107
1108
1109   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_IP6ND_RA_CONFIG);
1110   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1111 }
1112
1113 void
1114 ip6nd_ra_prefix (test_main_t * tm, int is_no)
1115 {
1116   vl_api_sw_interface_ip6nd_ra_prefix_t *mp;
1117   u64 tmp[2];
1118
1119   mp = vl_msg_api_alloc (sizeof (*mp));
1120   memset (mp, 0, sizeof (*mp));
1121
1122   mp->client_index = tm->my_client_index;
1123   mp->context = 0xdeadbeef;
1124   mp->sw_if_index = ntohl (5);
1125   mp->is_no = is_no;
1126
1127   mp->use_default = 1;
1128
1129
1130   tmp[0] = clib_host_to_net_u64 (0xdb01000000000000ULL);
1131   tmp[1] = clib_host_to_net_u64 (0x11ULL);
1132
1133
1134   clib_memcpy (mp->address, &tmp[0], 8);
1135   clib_memcpy (&mp->address[8], &tmp[1], 8);
1136
1137   mp->address_length = 64;
1138
1139
1140   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_IP6ND_RA_PREFIX);
1141   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1142 }
1143
1144 void
1145 ip6_enable_disable (test_main_t * tm, int enable)
1146 {
1147   vl_api_sw_interface_ip6_enable_disable_t *mp;
1148
1149   mp = vl_msg_api_alloc (sizeof (*mp));
1150   memset (mp, 0, sizeof (*mp));
1151
1152   mp->client_index = tm->my_client_index;
1153   mp->context = 0xdeadbeef;
1154   mp->sw_if_index = ntohl (5);
1155   mp->enable = (enable == 1);;
1156
1157   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_IP6_ENABLE_DISABLE);
1158   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1159 }
1160
1161 void
1162 loop_create (test_main_t * tm)
1163 {
1164   vl_api_create_loopback_t *mp;
1165
1166   mp = vl_msg_api_alloc (sizeof (*mp));
1167   memset (mp, 0, sizeof (*mp));
1168
1169   mp->_vl_msg_id = ntohs (VL_API_CREATE_LOOPBACK);
1170   mp->client_index = tm->my_client_index;
1171   mp->context = 0xdeadbeef;
1172   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1173 }
1174
1175 void
1176 ip6_set_link_local_address (test_main_t * tm)
1177 {
1178   vl_api_sw_interface_ip6_set_link_local_address_t *mp;
1179   u64 tmp[2];
1180
1181   mp = vl_msg_api_alloc (sizeof (*mp));
1182   memset (mp, 0, sizeof (*mp));
1183
1184   mp->client_index = tm->my_client_index;
1185   mp->context = 0xdeadbeef;
1186   mp->sw_if_index = ntohl (5);
1187
1188   tmp[0] = clib_host_to_net_u64 (0xfe80000000000000ULL);
1189   tmp[1] = clib_host_to_net_u64 (0x11ULL);
1190
1191   clib_memcpy (mp->address, &tmp[0], 8);
1192   clib_memcpy (&mp->address[8], &tmp[1], 8);
1193
1194   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_IP6_SET_LINK_LOCAL_ADDRESS);
1195
1196   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1197 }
1198
1199
1200 void
1201 set_flags (test_main_t * tm, int up_down)
1202 {
1203   vl_api_sw_interface_set_flags_t *mp;
1204
1205   mp = vl_msg_api_alloc (sizeof (*mp));
1206   memset (mp, 0, sizeof (*mp));
1207
1208   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_SET_FLAGS);
1209   mp->client_index = tm->my_client_index;
1210   mp->context = 0xdeadbeef;
1211   mp->sw_if_index = ntohl (5);
1212   mp->admin_up_down = up_down;
1213   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1214
1215 }
1216
1217 void
1218 l2_patch_add_del (test_main_t * tm, int is_add)
1219 {
1220   vl_api_l2_patch_add_del_t *mp;
1221
1222   mp = vl_msg_api_alloc (sizeof (*mp));
1223   memset (mp, 0, sizeof (*mp));
1224   mp->_vl_msg_id = ntohs (VL_API_L2_PATCH_ADD_DEL);
1225   mp->client_index = tm->my_client_index;
1226   mp->context = 0xdeadbeef;
1227   mp->is_add = is_add;
1228   mp->rx_sw_if_index = ntohl (1);
1229   mp->tx_sw_if_index = ntohl (2);
1230
1231   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1232 }
1233
1234 void
1235 l2_xconnect (test_main_t * tm)
1236 {
1237   vl_api_sw_interface_set_l2_xconnect_t *mp;
1238
1239   mp = vl_msg_api_alloc (sizeof (*mp));
1240   memset (mp, 0, sizeof (*mp));
1241   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_SET_L2_XCONNECT);
1242   mp->client_index = tm->my_client_index;
1243   mp->context = 0xdeadbeef;
1244   mp->rx_sw_if_index = ntohl (5);
1245   mp->tx_sw_if_index = ntohl (6);
1246   mp->enable = 1;
1247
1248   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1249 }
1250
1251 void
1252 l2_bridge (test_main_t * tm)
1253 {
1254   vl_api_sw_interface_set_l2_bridge_t *mp;
1255
1256   mp = vl_msg_api_alloc (sizeof (*mp));
1257   memset (mp, 0, sizeof (*mp));
1258   mp->_vl_msg_id = ntohs (VL_API_SW_INTERFACE_SET_L2_BRIDGE);
1259   mp->client_index = tm->my_client_index;
1260   mp->context = 0xdeadbeef;
1261   mp->rx_sw_if_index = ntohl (5);
1262   mp->bd_id = ntohl (6);
1263   mp->bvi = ntohl (1);
1264   mp->shg = ntohl (0);
1265   mp->enable = 1;
1266
1267   vl_msg_api_send_shmem (tm->vl_input_queue, (u8 *) & mp);
1268 }
1269
1270 int
1271 main (int argc, char **argv)
1272 {
1273   api_main_t *am = &api_main;
1274   test_main_t *tm = &test_main;
1275   int ch;
1276
1277   connect_to_vpe ("test_client");
1278
1279   tm->vl_input_queue = shmem_hdr->vl_input_queue;
1280   tm->my_client_index = am->my_client_index;
1281
1282   fformat (stdout, "Type 'h' for help, 'q' to quit...\n");
1283
1284   while (1)
1285     {
1286       ch = getchar ();
1287       switch (ch)
1288         {
1289         case 'q':
1290           goto done;
1291         case 'd':
1292           dump (tm);
1293           break;
1294         case 'L':
1295           link_up_down_enable_disable (tm, 1 /* enable_disable */ );
1296           break;
1297         case 'l':
1298           link_up_down_enable_disable (tm, 0 /* enable_disable */ );
1299           break;
1300         case 'S':
1301           stats_enable_disable (tm, 1 /* enable_disable */ );
1302           break;
1303         case 's':
1304           stats_enable_disable (tm, 0 /* enable_disable */ );
1305           break;
1306         case '3':
1307           add_del_ip4_route (tm, 0 /* add */ );
1308           break;
1309         case '4':
1310           add_del_ip4_route (tm, 1 /* add */ );
1311           break;
1312         case '5':
1313           add_del_ip6_route (tm, 0 /* add */ );
1314           break;
1315         case '6':
1316           add_del_ip6_route (tm, 1 /* add */ );
1317           break;
1318         case 'A':
1319           add_del_interface_address (tm, 1 /* add */ );
1320           break;
1321         case 'a':
1322           add_del_interface_address (tm, 0 /* add */ );
1323           break;
1324         case 'B':
1325           add_del_v6_interface_address (tm, 1 /* add */ );
1326           break;
1327         case 'b':
1328           add_del_v6_interface_address (tm, 0 /* add */ );
1329           break;
1330         case 'E':
1331           l2_patch_add_del (tm, 1 /* is_add */ );
1332           break;
1333         case 'e':
1334           l2_patch_add_del (tm, 0 /* is_add */ );
1335           break;
1336         case 'z':
1337           del_all_interface_addresses (tm);
1338           break;
1339         case 't':
1340           set_interface_table (tm, 0 /* is_ipv6 */ ,
1341                                11 /* my amp goes to 11 */ );
1342           break;
1343         case 'T':
1344           set_interface_table (tm, 1 /* is_ipv6 */ ,
1345                                12 /* my amp goes to 12 */ );
1346           break;
1347
1348         case 'u':
1349           create_vlan_subif (tm, 123);
1350           break;
1351
1352         case 'c':
1353           connect_unix_tap (tm, "foo");
1354           break;
1355
1356         case 'n':
1357           add_ip4_neighbor (tm, 1 /* is_add */ );
1358           add_ip6_neighbor (tm, 1 /* is_add */ );
1359           break;
1360
1361         case 'N':
1362           add_ip4_neighbor (tm, 0 /* is_add */ );
1363           add_ip6_neighbor (tm, 0 /* is_add */ );
1364           break;
1365
1366         case 'p':
1367           add_del_proxy_arp (tm, 1 /* add */ );
1368           break;
1369
1370         case 'i':
1371           proxy_arp_intfc_enable_disable (tm, 1 /* enable */ );
1372           break;
1373
1374         case 'O':
1375           oam_events_enable_disable (tm, 0 /* enable */ );
1376           break;
1377
1378         case 'o':
1379           oam_events_enable_disable (tm, 1 /* enable */ );
1380           break;
1381
1382         case '0':
1383           oam_add_del (tm, 0 /* is_add */ );
1384           break;
1385
1386         case '1':
1387           oam_add_del (tm, 1 /* is_add */ );
1388           break;
1389
1390         case 'r':
1391           reset_fib (tm, 0 /* is_ip6 */ );
1392           break;
1393
1394         case 'R':
1395           reset_fib (tm, 1 /* is_ip6 */ );
1396           break;
1397
1398         case 'j':
1399           dhcp_set_vss (tm);
1400           break;
1401
1402         case 'k':
1403           dhcp_set_proxy (tm, 0);
1404           break;
1405
1406         case 'K':
1407           dhcp_set_proxy (tm, 1 /*ipv6 */ );
1408           break;
1409
1410         case 'v':
1411           set_ip_flow_hash (tm, 0 /* is_ip6 */ );
1412           break;
1413
1414         case 'V':
1415           ip6_set_link_local_address (tm);
1416           break;
1417
1418         case 'w':
1419           ip6_enable_disable (tm, 1 /* enable */ );
1420           break;
1421
1422         case 'W':
1423           ip6_enable_disable (tm, 0 /* disable */ );
1424           break;
1425
1426         case 'x':
1427           ip6nd_ra_config (tm, 0 /* is_no */ );
1428           break;
1429         case 'X':
1430           ip6nd_ra_config (tm, 1 /* is_no */ );
1431           break;
1432         case 'y':
1433           ip6nd_ra_prefix (tm, 0 /* is_no */ );
1434           break;
1435         case 'Y':
1436           ip6nd_ra_prefix (tm, 1 /* is_no */ );
1437           break;
1438
1439         case '7':
1440           loop_create (tm);
1441           break;
1442
1443         case 'F':
1444           set_flags (tm, 1 /* up_down */ );
1445           break;
1446
1447         case 'f':
1448           set_flags (tm, 0 /* up_down */ );
1449           break;
1450
1451         case '@':
1452           l2_xconnect (tm);
1453           break;
1454
1455         case '#':
1456           l2_bridge (tm);
1457           break;
1458
1459         case 'h':
1460           fformat (stdout, "q=quit,d=dump,L=link evts on,l=link evts off\n");
1461           fformat (stdout, "S=stats on,s=stats off\n");
1462           fformat (stdout, "4=add v4 route, 3=del v4 route\n");
1463           fformat (stdout, "6=add v6 route, 5=del v6 route\n");
1464           fformat (stdout, "A=add v4 intfc route, a=del v4 intfc route\n");
1465           fformat (stdout, "B=add v6 intfc route, b=del v6 intfc route\n");
1466           fformat (stdout, "z=del all intfc routes\n");
1467           fformat (stdout, "t=set v4 intfc table, T=set v6 intfc table\n");
1468           fformat (stdout, "c=connect unix tap\n");
1469           fformat (stdout,
1470                    "j=set dhcpv4 and v6 link-address/option-82 params\n");
1471           fformat (stdout, "k=set dhcpv4 relay agent params\n");
1472           fformat (stdout, "K=set dhcpv6 relay agent params\n");
1473           fformat (stdout, "E=add l2 patch, e=del l2 patch\n");
1474           fformat (stdout, "V=ip6 set link-local address \n");
1475           fformat (stdout, "w=ip6 enable \n");
1476           fformat (stdout, "W=ip6 disable \n");
1477           fformat (stdout, "x=ip6 nd config \n");
1478           fformat (stdout, "X=no ip6 nd config\n");
1479           fformat (stdout, "y=ip6 nd prefix \n");
1480           fformat (stdout, "Y=no ip6 nd prefix\n");
1481           fformat (stdout, "@=l2 xconnect\n");
1482           fformat (stdout, "#=l2 bridge\n");
1483
1484         default:
1485           break;
1486         }
1487
1488     }
1489
1490 done:
1491
1492   if (tm->link_events_on)
1493     link_up_down_enable_disable (tm, 0 /* enable */ );
1494   if (tm->stats_on)
1495     stats_enable_disable (tm, 0 /* enable */ );
1496   if (tm->oam_events_on)
1497     oam_events_enable_disable (tm, 0 /* enable */ );
1498
1499   disconnect_from_vpe ();
1500   exit (0);
1501 }
1502
1503 #undef vl_api_version
1504 #define vl_api_version(n,v) static u32 vpe_api_version = v;
1505 #include <vpp/api/vpe.api.h>
1506 #undef vl_api_version
1507
1508 void
1509 vl_client_add_api_signatures (vl_api_memclnt_create_t * mp)
1510 {
1511   /*
1512    * Send the main API signature in slot 0. This bit of code must
1513    * match the checks in ../vpe/api/api.c: vl_msg_api_version_check().
1514    */
1515   mp->api_versions[0] = clib_host_to_net_u32 (vpe_api_version);
1516 }
1517
1518 /*
1519  * fd.io coding-style-patch-verification: ON
1520  *
1521  * Local Variables:
1522  * eval: (c-set-style "gnu")
1523  * End:
1524  */