blob: f4e025394b33b3012bce47fa38eee6fa47146f94 [file] [log] [blame]
Neale Ranns5a8844b2019-04-16 07:15:35 +00001/* Hey Emacs use -*- mode: C -*- */
Pavel Kotucek1099b0d2016-12-20 08:13:14 +01002/*
Vratko Polak8ab4e502020-01-31 19:21:25 +01003 * Copyright (c) 2015-2020 Cisco and/or its affiliates.
Pavel Kotucek1099b0d2016-12-20 08:13:14 +01004 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Vratko Polak8ab4e502020-01-31 19:21:25 +010017option version = "2.1.0";
Dave Barach0d056e52017-09-28 15:11:16 -040018
Ole Troan814f1592019-06-07 11:02:58 +020019import "vnet/interface_types.api";
Neale Ranns59ff9182019-12-29 23:55:18 +000020import "vnet/tunnel/tunnel_types.api";
Neale Ranns5a8844b2019-04-16 07:15:35 +000021import "vnet/ip/ip_types.api";
22
23/** \brief A GRE tunnel type
24*/
Neale Ranns5f8f6172019-04-18 10:23:56 +000025enum gre_tunnel_type : u8
Neale Ranns5a8844b2019-04-16 07:15:35 +000026{
Alexander Chernavind0aed2e2019-04-22 09:30:16 -040027 GRE_API_TUNNEL_TYPE_L3 = 0,
Vratko Polak48ac1c22020-01-31 20:43:33 +010028 /* L2 Transparent Ethernet Bridge */
Neale Ranns5a8844b2019-04-16 07:15:35 +000029 GRE_API_TUNNEL_TYPE_TEB,
Vratko Polak48ac1c22020-01-31 20:43:33 +010030 /* Encapsulated Remote Switched Port ANalyzer */
Neale Ranns5a8844b2019-04-16 07:15:35 +000031 GRE_API_TUNNEL_TYPE_ERSPAN,
32};
33
Vratko Polak48ac1c22020-01-31 20:43:33 +010034/** \brief A composite type uniquely defining a GRE tunnel.
35 @param type - tunnel type (see enum definition), 0: L3, 1: TEB, 2: ERSPAN
Neale Rannse5b94dd2019-12-31 05:13:14 +000036 @param mode - P2P or P2MP
37 @param flags - to control encap/decap behaviour
Vratko Polak48ac1c22020-01-31 20:43:33 +010038 @param session_id - session for ERSPAN tunnel, range 0-1023
39 @param instance - optional unique custom device instance, else ~0.
40 @param outer_table_id - Encap FIB table ID
41 @param sw_if_index - ignored on create/delete, present in details.
Neale Ranns5a8844b2019-04-16 07:15:35 +000042 @param src - Source IP address
43 @param dst - Destination IP address, can be multicast
John Loa43ccae2018-02-13 17:15:23 -050044*/
Neale Ranns5a8844b2019-04-16 07:15:35 +000045typedef gre_tunnel
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010046{
Neale Ranns5a8844b2019-04-16 07:15:35 +000047 vl_api_gre_tunnel_type_t type;
Neale Ranns59ff9182019-12-29 23:55:18 +000048 vl_api_tunnel_mode_t mode;
Neale Rannse5b94dd2019-12-31 05:13:14 +000049 vl_api_tunnel_encap_decap_flags_t flags;
Neale Ranns5f8f6172019-04-18 10:23:56 +000050 u16 session_id;
Neale Ranns5a8844b2019-04-16 07:15:35 +000051 u32 instance;
Neale Ranns5f8f6172019-04-18 10:23:56 +000052 u32 outer_table_id;
Ole Troan814f1592019-06-07 11:02:58 +020053 vl_api_interface_index_t sw_if_index;
Neale Ranns5a8844b2019-04-16 07:15:35 +000054 vl_api_address_t src;
55 vl_api_address_t dst;
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010056};
57
Vratko Polak48ac1c22020-01-31 20:43:33 +010058/** \brief Add or delete a single GRE tunnel.
59 @param client_index - opaque cookie to identify the sender.
60 @param context - sender context, to match reply w/ request.
61 @param is_add - add if true, delete if false.
62 @param tunnel - tunnel definition to add or delete.
63*/
Neale Ranns5a8844b2019-04-16 07:15:35 +000064define gre_tunnel_add_del
65{
66 u32 client_index;
67 u32 context;
Ole Troan814f1592019-06-07 11:02:58 +020068 bool is_add;
Neale Ranns5a8844b2019-04-16 07:15:35 +000069 vl_api_gre_tunnel_t tunnel;
70};
71
Vratko Polak48ac1c22020-01-31 20:43:33 +010072/** \brief Add or delete a single GRE tunnel.
73 @param context - sender context, to match reply w/ request.
74 @param retval - return code for the request.
75 @param sw_if_index - the interface corresponding to the affected tunnel.
76*/
Neale Ranns5a8844b2019-04-16 07:15:35 +000077define gre_tunnel_add_del_reply
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010078{
79 u32 context;
80 i32 retval;
Ole Troan814f1592019-06-07 11:02:58 +020081 vl_api_interface_index_t sw_if_index;
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010082};
83
Vratko Polak48ac1c22020-01-31 20:43:33 +010084/** \brief Dump details of all or just a single GRE tunnel.
85 @param client_index - opaque cookie to identify the sender.
86 @param context - sender context, to match reply w/ request.
87 @param sw_if_index - filter for tunnel of this interface index, ~0 for all.
88*/
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010089define gre_tunnel_dump
90{
91 u32 client_index;
92 u32 context;
Ole Troan814f1592019-06-07 11:02:58 +020093 vl_api_interface_index_t sw_if_index;
Pavel Kotucek1099b0d2016-12-20 08:13:14 +010094};
95
Vratko Polak48ac1c22020-01-31 20:43:33 +010096/** \brief Details response for one of the requested GRE tunnels.
97 @param context - sender context, to match reply w/ request.
98 @param tunnel - definition of the dumped tunnel.
99*/
Pavel Kotucek1099b0d2016-12-20 08:13:14 +0100100define gre_tunnel_details
101{
102 u32 context;
Neale Ranns5a8844b2019-04-16 07:15:35 +0000103 vl_api_gre_tunnel_t tunnel;
Pavel Kotucek1099b0d2016-12-20 08:13:14 +0100104};
105
106/*
107 * Local Variables:
108 * eval: (c-set-style "gnu")
109 * End:
110 */