blob: 2cd2bd50272b684ec2535c1b351287d4faa5a28c [file] [log] [blame]
Neale Rannsd0df49f2018-08-08 01:06:40 -07001/* Hey Emacs use -*- mode: C -*- */
Neale Ranns810086d2017-11-05 16:26:46 -08002/*
Florin Coras10dc2ea2019-04-10 07:08:01 -07003 * Copyright (c) 2018-2019 Cisco and/or its affiliates.
Neale Ranns810086d2017-11-05 16:26:46 -08004 * 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
Neale Rannsd0df49f2018-08-08 01:06:40 -070017/**
18 * @file
19 *
20 * This file defines vpp UDP control-plane API messages which are generally
21 * called through a shared memory interface.
22 */
Neale Ranns810086d2017-11-05 16:26:46 -080023
Neale Rannsd0df49f2018-08-08 01:06:40 -070024option version = "1.1.0";
25
26import "vnet/ip/ip_types.api";
27
28
29/**
30 * @brief UDP Encap object
31 * @param table_id - table ID associated with the encap destination
32 * @param dst_ip - Encap destination address
33 * @param src_ip - Encap source address
34 * @param dst_port - Encap destination port
35 * @param src_port - Encap source port
Neale Ranns9c0a3c42018-09-07 08:57:41 -070036 * @param id - VPP assigned id; ignored in add message, set in dump
Neale Rannsd0df49f2018-08-08 01:06:40 -070037 */
38typedef udp_encap
39{
Neale Rannsd0df49f2018-08-08 01:06:40 -070040 u32 table_id;
41 u16 src_port;
42 u16 dst_port;
43 vl_api_address_t src_ip;
44 vl_api_address_t dst_ip;
Neale Ranns9c0a3c42018-09-07 08:57:41 -070045 u32 id;
Neale Rannsd0df49f2018-08-08 01:06:40 -070046};
47
48/**
49 * @brief Add UDP encap
50 * @param client_index - opaque cookie to identify the sender
51 * @param context - sender context, to match reply w/ request
52 * @param udp_encap - UDP encap description
53 */
Neale Ranns9c0a3c42018-09-07 08:57:41 -070054define udp_encap_add
Neale Rannsd0df49f2018-08-08 01:06:40 -070055{
56 u32 client_index;
57 u32 context;
58 vl_api_udp_encap_t udp_encap;
59};
60
61/**
Neale Ranns9c0a3c42018-09-07 08:57:41 -070062 * @brief Add UDP encap reply
63 * @param context - sender context, to match reply w/ request
64 * @param retval - success/failure return value
65 * @param id - The ID of the encap object that should be used on delete
66 * and when reading stats from the stats segment.
67 */
68define udp_encap_add_reply
69{
70 u32 context;
71 i32 retval;
72 u32 id;
73};
74
75/**
Neale Rannsd0df49f2018-08-08 01:06:40 -070076 * @brief Del UDP encap
77 * @param client_index - opaque cookie to identify the sender
78 * @param context - sender context, to match reply w/ request
79 * @param id - ID of the encap object the client chose during the add
Neale Ranns810086d2017-11-05 16:26:46 -080080*/
Neale Rannsd0df49f2018-08-08 01:06:40 -070081autoreply define udp_encap_del
Neale Ranns810086d2017-11-05 16:26:46 -080082{
83 u32 client_index;
84 u32 context;
85 u32 id;
Neale Ranns810086d2017-11-05 16:26:46 -080086};
87
Neale Rannsd0df49f2018-08-08 01:06:40 -070088/**
89 * @brief dump UDP encaps
90 */
Neale Ranns810086d2017-11-05 16:26:46 -080091define udp_encap_dump
92{
93 u32 client_index;
94 u32 context;
95};
96
Neale Rannsd0df49f2018-08-08 01:06:40 -070097/**
98 * @brief UDP encap details during dump
99 */
Neale Ranns810086d2017-11-05 16:26:46 -0800100define udp_encap_details
101{
102 u32 context;
Neale Rannsd0df49f2018-08-08 01:06:40 -0700103 vl_api_udp_encap_t udp_encap;
Neale Ranns810086d2017-11-05 16:26:46 -0800104};
105
106/*
107 * Local Variables:
108 * eval: (c-set-style "gnu")
109 * End:
110 */