blob: b82036052f7da7e4bb31270035008fae3883d0e2 [file] [log] [blame]
Neale Rannscbe25aa2019-09-30 10:53:31 +00001/* Hey Emacs use -*- mode: C -*- */
2/*
3 * Copyright (c) 2018 Cisco and/or its affiliates.
4 * 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
17/** \file
18
19 This file defines vpp IP neighbor control-plane API messages which are generally
20 called through a shared memory interface.
21*/
22
23option version = "1.0.0";
24
25import "vnet/ip/ip_types.api";
26import "vnet/ethernet/ethernet_types.api";
27import "vnet/interface_types.api";
28
29/** \brief IP neighbor flags
30 @param is_static - A static neighbor Entry - there are not flushed
31 If the interface goes down.
32 @param is_no_fib_entry - Do not create a corresponding entry in the FIB
33 table for the neighbor.
34*/
35enum ip_neighbor_flags: u8
36{
37 IP_API_NEIGHBOR_FLAG_NONE = 0,
38 IP_API_NEIGHBOR_FLAG_STATIC = 0x1,
39 IP_API_NEIGHBOR_FLAG_NO_FIB_ENTRY = 0x2,
40};
41
42/** \brief IP neighbor
43 @param sw_if_index - interface used to reach neighbor
44 @param flags - flags for the nieghbor
45 @param mac_address - l2 address of the neighbor
46 @param ip_address - ip4 or ip6 address of the neighbor
47*/
48typedef ip_neighbor {
49 vl_api_interface_index_t sw_if_index;
50 vl_api_ip_neighbor_flags_t flags;
51 vl_api_mac_address_t mac_address;
52 vl_api_address_t ip_address;
53};
54
55/** \brief IP neighbor add / del request
56 @param client_index - opaque cookie to identify the sender
57 @param context - sender context, to match reply w/ request
58 @param is_add - 1 to add neighbor, 0 to delete
59 @param neighbor - the neighor to add/remove
60*/
61define ip_neighbor_add_del
62{
63 u32 client_index;
64 u32 context;
65 /* 1 = add, 0 = delete */
66 bool is_add;
67 vl_api_ip_neighbor_t neighbor;
68};
69/** \brief IP neighbor add / del reply
70 @param client_index - opaque cookie to identify the sender
71 @param context - sender context, to match reply w/ request
72 @param retval - return value
73 @param stats_index - the index to use for this neighbor in the stats segement
74*/
75define ip_neighbor_add_del_reply
76{
77 u32 context;
78 i32 retval;
79 u32 stats_index;
80};
81
82/** \brief Dump IP neighboors
83 @param client_index - opaque cookie to identify the sender
84 @param context - sender context, to match reply w/ request
85 @param sw_if_index - the interface to dump neighboors, ~0 == all
86 @param af - address family is ipv[6|4]
87*/
88define ip_neighbor_dump
89{
90 u32 client_index;
91 u32 context;
92 vl_api_interface_index_t sw_if_index [default=0xffffffff];
93 vl_api_address_family_t af;
94};
95
96/** \brief IP neighboors dump response
97 @param context - sender context which was passed in the request
Vratko Polak8e7fddd2020-03-09 18:30:02 +010098 @param age - time between last update and sending this message, in seconds
Neale Rannscbe25aa2019-09-30 10:53:31 +000099 @param neighbour - the neighbor
100*/
101define ip_neighbor_details {
102 u32 context;
Vladimir Ratnikov9c1928f2020-02-28 08:48:21 -0500103 f64 age;
Neale Rannscbe25aa2019-09-30 10:53:31 +0000104 vl_api_ip_neighbor_t neighbor;
105};
106
107/** \brief Enable/disable periodic IP neighbor scan
108 @param client_index - opaque cookie to identify the sender
109 @param context - sender context, to match reply w/ request
110 @param af - Address family v4/v6
111 @param max_number - The maximum number of neighbours that will be created.
112 default 50k
113 @param max_age - The maximum age (in seconds) before an inactive neighbour
114 is flushed
115 default 0 => never
116 @param recycle - If max_number of neighbours is reached and new ones need
117 to be created should the oldest neighbour be 'recycled'.
118*/
119autoreply define ip_neighbor_config
120{
121 u32 client_index;
122 u32 context;
123 vl_api_address_family_t af;
124 u32 max_number;
125 u32 max_age;
126 bool recycle;
127};
128
129/** \brief Register for IP4 ARP resolution event on receing ARP reply or
130 MAC/IP info from ARP requests in L2 BDs
131 @param client_index - opaque cookie to identify the sender
132 @param context - sender context, to match reply w/ request
133 @param enable - 1 => register for events, 0 => cancel registration
134 @param pid - sender's pid
135 @param ip - exact IP address of interested neighbor resolution event
136 @param sw_if_index - interface on which the IP address is present.
137*/
138autoreply define want_ip_neighbor_events
139{
140 u32 client_index;
141 u32 context;
142 bool enable;
143 u32 pid;
144 vl_api_address_t ip;
145 vl_api_interface_index_t sw_if_index [default=0xffffffff];
146};
147
148/** \brief Tell client about an IP4 ARP resolution event or
149 MAC/IP info from ARP requests in L2 BDs
150 @param client_index - opaque cookie to identify the sender
151 @param pid - client pid registered to receive notification
152 @param neighbor - new neighbor created
153*/
154define ip_neighbor_event
155{
156 u32 client_index;
157 u32 pid;
158 vl_api_ip_neighbor_t neighbor;
159};
160
161service {
162 rpc want_ip_neighbor_events returns want_ip_neighbor_events_reply
163 events ip_neighbor_event;
164};
165
166/*
167 * Local Variables:
168 * eval: (c-set-style "gnu")
169 * End:
170 */