Print this page
4510 Lose SIOC*IPSECONFIG ioctl definitions
Reviewed by: Robert Mustacchi <rm@joyent.com>
| Split |
Close |
| Expand all |
| Collapse all |
--- old/usr/src/uts/common/sys/sockio.h
+++ new/usr/src/uts/common/sys/sockio.h
1 1 /*
2 2 * CDDL HEADER START
3 3 *
4 4 * The contents of this file are subject to the terms of the
5 5 * Common Development and Distribution License (the "License").
6 6 * You may not use this file except in compliance with the License.
7 7 *
8 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 9 * or http://www.opensolaris.org/os/licensing.
10 10 * See the License for the specific language governing permissions
11 11 * and limitations under the License.
12 12 *
|
↓ open down ↓ |
12 lines elided |
↑ open up ↑ |
13 13 * When distributing Covered Code, include this CDDL HEADER in each
14 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 15 * If applicable, add the following below this CDDL HEADER, with the
16 16 * fields enclosed by brackets "[]" replaced with your own identifying
17 17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 18 *
19 19 * CDDL HEADER END
20 20 */
21 21 /*
22 22 * Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
23 + * Copyright (c) 2014, OmniTI Computer Consulting, Inc. All rights reserved.
23 24 */
24 25
25 26 /* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
26 27 /* All Rights Reserved */
27 28
28 29 /*
29 30 * University Copyright- Copyright (c) 1982, 1986, 1988
30 31 * The Regents of the University of California
31 32 * All Rights Reserved
32 33 *
33 34 * University Acknowledgment- Portions of this document are derived from
34 35 * software developed by the University of California, Berkeley, and its
35 36 * contributors.
36 37 */
37 38
38 39 #ifndef _SYS_SOCKIO_H
39 40 #define _SYS_SOCKIO_H
40 41
41 42 /*
42 43 * General socket ioctl definitions.
43 44 */
44 45
45 46 #include <sys/ioccom.h>
46 47
47 48 #ifdef __cplusplus
48 49 extern "C" {
49 50 #endif
50 51
51 52 /* socket i/o controls */
52 53 #define SIOCSHIWAT _IOW('s', 0, int) /* set high watermark */
53 54 #define SIOCGHIWAT _IOR('s', 1, int) /* get high watermark */
54 55 #define SIOCSLOWAT _IOW('s', 2, int) /* set low watermark */
55 56 #define SIOCGLOWAT _IOR('s', 3, int) /* get low watermark */
56 57 #define SIOCATMARK _IOR('s', 7, int) /* at oob mark? */
57 58 #define SIOCSPGRP _IOW('s', 8, int) /* set process group */
58 59 #define SIOCGPGRP _IOR('s', 9, int) /* get process group */
59 60
60 61 /*
61 62 * SIOCADDRT and SIOCDELRT ioctls need to be defined using _IOWN macro to
62 63 * make them datamodel independent.
63 64 */
64 65 #define SIOCADDRT _IOWN('r', 10, 48) /* add route */
65 66 #define SIOCDELRT _IOWN('r', 11, 48) /* delete route */
66 67
67 68 /* For multicast routing. These might change in future release */
68 69 #define SIOCGETVIFCNT _IOWR('r', 20, struct sioc_vif_req)
69 70 /* get vif pkt count */
70 71 #define SIOCGETSGCNT _IOWR('r', 21, struct sioc_sg_req)
71 72 /* get s,g pkt count */
72 73 #define SIOCGETLSGCNT _IOWR('r', 21, struct sioc_lsg_req)
73 74 /* get s,g pkt count */
74 75
75 76 /*
76 77 * Obsolete interface ioctls using struct ifreq that are supported
77 78 * for compatibility. New interface ioctls use struct lifreq.
78 79 */
79 80 #define SIOCSIFADDR _IOW('i', 12, struct ifreq) /* set if address */
80 81 #define SIOCGIFADDR _IOWR('i', 13, struct ifreq) /* get if address */
81 82 #define SIOCSIFDSTADDR _IOW('i', 14, struct ifreq) /* set p-p address */
82 83 #define SIOCGIFDSTADDR _IOWR('i', 15, struct ifreq) /* get p-p address */
83 84 #define SIOCSIFFLAGS _IOW('i', 16, struct ifreq) /* set if flags */
84 85 #define SIOCGIFFLAGS _IOWR('i', 17, struct ifreq) /* get if flags */
85 86 #define SIOCSIFMEM _IOW('i', 18, struct ifreq) /* set interface mem */
86 87 #define SIOCGIFMEM _IOWR('i', 19, struct ifreq) /* get interface mem */
87 88
88 89 /*
89 90 * Needs to be defined using _IOWRN macro to make it datamodel independent.
90 91 * Argument is a struct ifconf.
91 92 */
92 93 #define O_SIOCGIFCONF _IOWRN('i', 20, 8) /* old get if list */
93 94
94 95 #define SIOCSIFMTU _IOW('i', 21, struct ifreq) /* set if mtu */
95 96 #define SIOCGIFMTU _IOWR('i', 22, struct ifreq) /* get if mtu */
96 97
97 98 /* from 4.3BSD */
98 99 #define SIOCGIFBRDADDR _IOWR('i', 23, struct ifreq) /* get broadcast addr */
99 100 #define SIOCSIFBRDADDR _IOW('i', 24, struct ifreq) /* set broadcast addr */
100 101 #define SIOCGIFNETMASK _IOWR('i', 25, struct ifreq) /* get subnetmask */
101 102 #define SIOCSIFNETMASK _IOW('i', 26, struct ifreq) /* set subnetmask */
102 103 #define SIOCGIFMETRIC _IOWR('i', 27, struct ifreq) /* get if metric */
103 104 #define SIOCSIFMETRIC _IOW('i', 28, struct ifreq) /* set if metric */
104 105
105 106 #define SIOCSARP _IOW('i', 30, struct arpreq) /* set arp entry */
106 107 #define SIOCGARP _IOWR('i', 31, struct arpreq) /* get arp entry */
107 108 #define SIOCDARP _IOW('i', 32, struct arpreq) /* delete arp entry */
108 109 #define SIOCUPPER _IOW('i', 40, struct ifreq) /* attach upper layer */
109 110 #define SIOCLOWER _IOW('i', 41, struct ifreq) /* attach lower layer */
110 111 #define SIOCSETSYNC _IOW('i', 44, struct ifreq) /* set syncmode */
111 112 #define SIOCGETSYNC _IOWR('i', 45, struct ifreq) /* get syncmode */
112 113 #define SIOCSSDSTATS _IOWR('i', 46, struct ifreq) /* sync data stats */
113 114 #define SIOCSSESTATS _IOWR('i', 47, struct ifreq) /* sync error stats */
114 115
115 116 #define SIOCSPROMISC _IOW('i', 48, int) /* request promisc */
116 117 /* mode on/off */
117 118 #define SIOCADDMULTI _IOW('i', 49, struct ifreq) /* set m/c address */
118 119 #define SIOCDELMULTI _IOW('i', 50, struct ifreq) /* clr m/c address */
119 120
120 121 /* STREAMS based socket emulation */
121 122
122 123 #define SIOCGETNAME _IOR('s', 52, struct sockaddr) /* getsockname */
123 124 #define SIOCGETPEER _IOR('s', 53, struct sockaddr) /* getpeername */
124 125 #define IF_UNITSEL _IOW('s', 54, int) /* set unit number */
125 126 #define SIOCXPROTO _IO('s', 55) /* empty proto table */
126 127
127 128 #define SIOCIFDETACH _IOW('i', 56, struct ifreq) /* detach interface */
128 129 #define SIOCGENPSTATS _IOWR('i', 57, struct ifreq) /* get ENP stats */
129 130 #define SIOCX25XMT _IOWR('i', 59, struct ifreq) /* start a slp proc */
130 131 /* in x25if */
131 132 #define SIOCX25RCV _IOWR('i', 60, struct ifreq) /* start a slp proc */
132 133 /* in x25if */
133 134 #define SIOCX25TBL _IOWR('i', 61, struct ifreq) /* xfer lun table to */
134 135 /* kernel */
135 136 #define SIOCSLGETREQ _IOWR('i', 71, struct ifreq) /* wait for switched */
136 137 /* SLIP request */
137 138 #define SIOCSLSTAT _IOW('i', 72, struct ifreq) /* pass SLIP info to */
138 139 /* kernel */
139 140 #define SIOCSIFNAME _IOW('i', 73, struct ifreq) /* set interface name */
140 141 #define SIOCGENADDR _IOWR('i', 85, struct ifreq) /* Get ethernet addr */
141 142 #define SIOCGIFNUM _IOR('i', 87, int) /* get number of ifs */
142 143
143 144 #define SIOCGIFMUXID _IOWR('i', 88, struct ifreq) /* get if muxid */
144 145 #define SIOCSIFMUXID _IOW('i', 89, struct ifreq) /* set if muxid */
145 146
146 147 #define SIOCGIFINDEX _IOWR('i', 90, struct ifreq) /* get if index */
147 148 #define SIOCSIFINDEX _IOW('i', 91, struct ifreq) /* set if index */
148 149 #define SIOCGIFCONF _IOWRN('i', 92, 8) /* get if list */
149 150
150 151 /*
151 152 * New interface ioctls that use the struct lifreq. Can be used for
152 153 * both IPv4 and IPv6.
153 154 */
154 155 #define SIOCLIFREMOVEIF _IOW('i', 110, struct lifreq) /* delete logical */
155 156 #define SIOCLIFADDIF _IOWR('i', 111, struct lifreq) /* create logical */
156 157
157 158 #define SIOCSLIFADDR _IOW('i', 112, struct lifreq) /* set if address */
158 159 #define SIOCGLIFADDR _IOWR('i', 113, struct lifreq) /* get if address */
159 160 #define SIOCSLIFDSTADDR _IOW('i', 114, struct lifreq) /* set p-p address */
160 161 #define SIOCGLIFDSTADDR _IOWR('i', 115, struct lifreq) /* get p-p address */
161 162 #define SIOCSLIFFLAGS _IOW('i', 116, struct lifreq) /* set if flags */
162 163 #define SIOCGLIFFLAGS _IOWR('i', 117, struct lifreq) /* get if flags */
163 164
164 165 /*
165 166 * Needs to be defined using _IOWRN macro to make it datamodel independent.
166 167 * Argument is a struct lifconf.
167 168 */
168 169 #define O_SIOCGLIFCONF _IOWRN('i', 120, 16) /* old get if list */
169 170 #define SIOCSLIFMTU _IOW('i', 121, struct lifreq) /* set if mtu */
170 171 #define SIOCGLIFMTU _IOWR('i', 122, struct lifreq) /* get if mtu */
171 172 #define SIOCGLIFBRDADDR _IOWR('i', 123, struct lifreq) /* get broadcast addr */
172 173 #define SIOCSLIFBRDADDR _IOW('i', 124, struct lifreq) /* set broadcast addr */
173 174 #define SIOCGLIFNETMASK _IOWR('i', 125, struct lifreq) /* get subnetmask */
174 175 #define SIOCSLIFNETMASK _IOW('i', 126, struct lifreq) /* set subnetmask */
175 176 #define SIOCGLIFMETRIC _IOWR('i', 127, struct lifreq) /* get if metric */
176 177 #define SIOCSLIFMETRIC _IOW('i', 128, struct lifreq) /* set if metric */
177 178 #define SIOCSLIFNAME _IOWR('i', 129, struct lifreq) /* set interface name */
178 179 #define SIOCGLIFNUM _IOWR('i', 130, struct lifnum) /* get number of ifs */
179 180 #define SIOCGLIFMUXID _IOWR('i', 131, struct lifreq) /* get if muxid */
180 181 #define SIOCSLIFMUXID _IOW('i', 132, struct lifreq) /* set if muxid */
181 182
182 183 #define SIOCGLIFINDEX _IOWR('i', 133, struct lifreq) /* get if index */
183 184 #define SIOCSLIFINDEX _IOW('i', 134, struct lifreq) /* set if index */
184 185
185 186 #define SIOCSLIFTOKEN _IOW('i', 135, struct lifreq) /* Set token for link */
186 187 /* local address and */
187 188 /* autoconf */
188 189 #define SIOCGLIFTOKEN _IOWR('i', 136, struct lifreq) /* Get token for link */
189 190 /* local address and */
190 191 /* autoconf */
191 192
192 193 #define SIOCSLIFSUBNET _IOW('i', 137, struct lifreq) /* set subnet prefix */
193 194 #define SIOCGLIFSUBNET _IOWR('i', 138, struct lifreq) /* get subnet prefix */
194 195
195 196 #define SIOCSLIFLNKINFO _IOW('i', 139, struct lifreq) /* set link info */
196 197 #define SIOCGLIFLNKINFO _IOWR('i', 140, struct lifreq) /* get link info */
197 198
198 199 #define SIOCLIFDELND _IOW('i', 141, struct lifreq) /* Delete ND entry */
199 200 #define SIOCLIFGETND _IOWR('i', 142, struct lifreq) /* Get ND entry */
200 201 #define SIOCLIFSETND _IOW('i', 143, struct lifreq) /* Set ND entry */
201 202
|
↓ open down ↓ |
169 lines elided |
↑ open up ↑ |
202 203 /*
203 204 * Address querying ioctls.
204 205 */
205 206 #define SIOCTMYADDR _IOWR('i', 144, struct sioc_addrreq)
206 207 /* My address? */
207 208 #define SIOCTONLINK _IOWR('i', 145, struct sioc_addrreq)
208 209 /* Address on-link? */
209 210 #define SIOCTMYSITE _IOWR('i', 146, struct sioc_addrreq)
210 211 /* In this site? */
211 212
212 -/* 147 and 148 were SIOC*TUNPARAM ioctls. Feel free to re-use. */
213 +/* 147-152 were SIOC*{TUNPARAM,IPSECONFIG} ioctls. Feel free to re-use. */
213 214
214 -#define SIOCFIPSECONFIG _IOW('i', 149, 0) /* Flush Policy */
215 -#define SIOCSIPSECONFIG _IOW('i', 150, 0) /* Set Policy */
216 -#define SIOCDIPSECONFIG _IOW('i', 151, 0) /* Delete Policy */
217 -#define SIOCLIPSECONFIG _IOW('i', 152, 0) /* List Policy */
218 -
219 215 /*
220 216 * 153 can be reused (was consolidation-private SIOCLIFFAILOVER).
221 217 */
222 218
223 219 /*
224 220 * IP Multipathing ioctls.
225 221 */
226 222 #define SIOCGLIFBINDING _IOWR('i', 154, struct lifreq)
227 223 #define SIOCSLIFGROUPNAME _IOW('i', 155, struct lifreq)
228 224 #define SIOCGLIFGROUPNAME _IOWR('i', 156, struct lifreq)
229 225 #define SIOCGLIFGROUPINFO _IOWR('i', 157, struct lifgroupinfo)
230 226
231 227 /*
232 228 * Leave 158 - 160 unused; used to be SIOC*IFARP ioctls.
233 229 * However, 161 can be reused (was consolidation-private SIOCSLIFOINDEX).
234 230 */
235 231
236 232 /*
237 233 * IOCTLS which provide an interface to the IPv6 address selection policy.
238 234 */
239 235 #define SIOCGIP6ADDRPOLICY _IOWRN('i', 162, 0)
240 236 #define SIOCSIP6ADDRPOLICY _IOWN('i', 163, 0)
241 237
242 238 /*
243 239 * IOCTL for retrieving sorting info for a list of destination addrs.
244 240 * Use the _IOWRN macro to make it datamodel independent. Argument
245 241 * is a struct dstinfo.
246 242 */
247 243 #define SIOCGDSTINFO _IOWRN('i', 164, 0)
248 244 #define SIOCGLIFCONF _IOWRN('i', 165, 16) /* get if list */
249 245
250 246 /*
251 247 * Extended IOCTLS for manipulating ARP cache entries.
252 248 */
253 249 #define SIOCSXARP _IOW('i', 166, struct xarpreq) /* set an ARP entry */
254 250 #define SIOCGXARP _IOWR('i', 167, struct xarpreq) /* get an ARP entry */
255 251 #define SIOCDXARP _IOW('i', 168, struct xarpreq) /* delete ARP entry */
256 252
257 253 /*
258 254 * IOCTL private to sockfs.
259 255 */
260 256 #define _SIOCSOCKFALLBACK _IOW('i', 169, 0)
261 257
262 258 /*
263 259 * IOCTLs for getting and setting zone associated with an interface, and
264 260 * unplumbing interfaces associated with a given zone.
265 261 */
266 262 #define SIOCGLIFZONE _IOWR('i', 170, struct lifreq) /* get zone id */
267 263 #define SIOCSLIFZONE _IOW('i', 171, struct lifreq) /* set zone id */
268 264
269 265 /*
270 266 * IOCTLS for handling SCTP options.
271 267 */
272 268 #define SIOCSCTPSOPT _IOWN('i', 172, 16) /* Set SCTP option */
273 269 #define SIOCSCTPGOPT _IOWRN('i', 173, 16) /* Get SCTP option */
274 270 #define SIOCSCTPPEELOFF _IOWR('i', 174, int) /* SCTP peeloff */
275 271
276 272 /*
277 273 * IOCTLs for getting and setting the source address that is used for packets
278 274 * going out on the given interface.
279 275 */
280 276 #define SIOCGLIFUSESRC _IOWR('i', 175, struct lifreq) /* get src addr */
281 277 #define SIOCSLIFUSESRC _IOW('i', 176, struct lifreq) /* set src addr */
282 278
283 279 /*
284 280 * IOCTL used to get all the interfaces that use the the specified interfaces'
285 281 * source address
286 282 */
287 283 #define SIOCGLIFSRCOF _IOWRN('i', 177, 16) /* source of */
288 284
289 285 /*
290 286 * IOCTLs for source specific multicast; get or set a socket's
291 287 * source filter for a particular multicast group. Argument is
292 288 * a struct group_filter. Defined in RFC 3678.
293 289 */
294 290 #define SIOCGMSFILTER _IOWR('i', 178, 0)
295 291 #define SIOCSMSFILTER _IOW('i', 179, 0)
296 292 /*
297 293 * IPv4-specific versions of the above; get or set a socket's source
298 294 * filter for a particular multicast group, for PF_INET sockets only.
299 295 * Argument is a struct ip_msfilter.
300 296 */
301 297 #define SIOCGIPMSFILTER _IOWR('i', 180, 0)
302 298 #define SIOCSIPMSFILTER _IOW('i', 181, 0)
303 299
304 300 /*
305 301 * 182 can be reused (was consolidation-private SIOCSIPMPFAILBACK).
306 302 */
307 303
308 304 #define SIOCSENABLESDP _IOWR('i', 183, int) /* Enable SDP */
309 305
310 306 #define SIOCSQPTR _IOWR('i', 184, int) /* set q_ptr of stream */
311 307
312 308 /*
313 309 * SIOCGIFHWADDR and SIOCGLIFHWADDR (below) are available for PF_PACKET,
314 310 * PF_INET and PF_INET6 sockets.
315 311 */
316 312 #define SIOCGIFHWADDR _IOWR('i', 185, struct ifreq)
317 313
318 314 #define SIOCGSTAMP _IOWR('i', 186, struct timeval) /* PF_PACKET */
319 315
320 316 /*
321 317 * Private ioctl for Integrated Load Balancer. The ioctl length varies.
322 318 */
323 319 #define SIOCILB _IOWR('i', 187, 0)
324 320
325 321 /*
326 322 * IOCTL's to get/set module specific or interface specific properties.
327 323 * Argument is a struct mod_ioc_prop_s. These ioctls are Consolidation Private.
328 324 */
329 325 #define SIOCGETPROP _IOWRN('p', 188, 0)
330 326 #define SIOCSETPROP _IOW('p', 189, 0)
331 327
332 328 /*
333 329 * IOCTL used to check for the given ipif, whether DAD is in progress or
334 330 * DAD has completed. This ioctl is Consolidation Private.
335 331 */
336 332 #define SIOCGLIFDADSTATE _IOWR('i', 190, struct lifreq)
337 333
338 334 /*
339 335 * IOCTL used to generate an IPv6 address using the given prefix and the
340 336 * default token for the interface.
341 337 */
342 338 #define SIOCSLIFPREFIX _IOWR('i', 191, struct lifreq)
343 339
344 340 #define SIOCGLIFHWADDR _IOWR('i', 192, struct lifreq)
345 341
346 342 #ifdef __cplusplus
347 343 }
348 344 #endif
349 345
350 346 #endif /* _SYS_SOCKIO_H */
|
↓ open down ↓ |
122 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX