2 * Copyright (c) 2015-2016 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
7 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
16 option version = "2.1.0";
18 import "vnet/interface_types.api";
19 import "vnet/ip/ip_types.api";
21 define vxlan_gpe_add_del_tunnel
25 vl_api_address_t local;
26 vl_api_address_t remote;
27 vl_api_interface_index_t mcast_sw_if_index;
30 vl_api_ip_proto_t protocol;
32 bool is_add [default=true];
35 /** \brief Create or delete a VXLAN-GPE tunnel
36 @param client_index - opaque cookie to identify the sender
37 @param context - sender context, to match reply w/ request
38 @param local - Source IP address
39 @param remote - Destination IP address, can be multicast
40 @param local_port - Source UDP port. It is not included in sent packets. Used only for port registration
41 @param remote_port - Destination UDP port
42 @param mcast_sw_if_index - Interface for multicast destination
43 @param encap_vrf_id - Encap route table FIB index
44 @param decap_vrf_id - Decap route table FIB index
45 @param protocol - Encapsulated protocol
46 @param vni - The VXLAN Network Identifier, uint24
47 @param is_add - Use 1 to create the tunnel, 0 to remove it
49 define vxlan_gpe_add_del_tunnel_v2
53 vl_api_address_t local;
54 vl_api_address_t remote;
57 vl_api_interface_index_t mcast_sw_if_index;
60 vl_api_ip_proto_t protocol;
62 bool is_add [default=true];
65 define vxlan_gpe_add_del_tunnel_reply
69 vl_api_interface_index_t sw_if_index;
71 define vxlan_gpe_add_del_tunnel_v2_reply
75 vl_api_interface_index_t sw_if_index;
78 define vxlan_gpe_tunnel_dump
82 vl_api_interface_index_t sw_if_index;
84 define vxlan_gpe_tunnel_v2_dump
88 vl_api_interface_index_t sw_if_index;
91 define vxlan_gpe_tunnel_details
94 vl_api_interface_index_t sw_if_index;
95 vl_api_address_t local;
96 vl_api_address_t remote;
98 vl_api_ip_proto_t protocol;
99 vl_api_interface_index_t mcast_sw_if_index;
104 define vxlan_gpe_tunnel_v2_details
107 vl_api_interface_index_t sw_if_index;
108 vl_api_address_t local;
109 vl_api_address_t remote;
113 vl_api_ip_proto_t protocol;
114 vl_api_interface_index_t mcast_sw_if_index;
120 /** \brief Interface set vxlan-gpe-bypass request
121 @param client_index - opaque cookie to identify the sender
122 @param context - sender context, to match reply w/ request
123 @param sw_if_index - interface used to reach neighbor
124 @param is_ipv6 - if non-zero, enable ipv6-vxlan-bypass, else ipv4-vxlan-bypass
125 @param enable - if non-zero enable, else disable
127 autoreply define sw_interface_set_vxlan_gpe_bypass
131 vl_api_interface_index_t sw_if_index;
133 bool enable [default=true];
138 * eval: (c-set-style "gnu")