xref: /illumos-gate/usr/src/uts/common/sys/dld.h (revision 5fbc1fe0da7f34cf8155bf7624c94583cc98e47c)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2010 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  * Copyright (c) 2017, Joyent, Inc.
25  */
26 
27 #ifndef	_SYS_DLD_H
28 #define	_SYS_DLD_H
29 
30 /*
31  * Data-Link Driver ioctl interfaces.
32  *
33  * Note that the data structures defined here define an ioctl interface
34  * that is shared betwen user and kernel space.  The dld driver thus
35  * assumes that the structures have identical layout and size when
36  * compiled in either IPL32 or LP64.
37  */
38 
39 #include <sys/types.h>
40 #include <sys/stream.h>
41 #include <sys/mac_flow.h>
42 #include <sys/conf.h>
43 #include <sys/sad.h>
44 #include <sys/mac.h>
45 
46 #ifdef	__cplusplus
47 extern "C" {
48 #endif
49 
50 /*
51  * Data-Link Driver Information (text emitted by modinfo(1m))
52  */
53 #define	DLD_INFO	"Data-Link Driver"
54 
55 /*
56  * Options: To enable an option set the property name to a non-zero value
57  *	    in kernel/drv/dld.conf.
58  */
59 
60 /*
61  * Prevent use of the IP fast-path (direct M_DATA transmit).
62  */
63 #define	DLD_PROP_NO_FASTPATH	"no-fastpath"
64 
65 /*
66  * Prevent advertising of the DL_CAPAB_POLL capability.
67  */
68 #define	DLD_PROP_NO_POLL	"no-poll"
69 
70 /*
71  * Prevent advertising of the DL_CAPAB_ZEROCOPY capability.
72  */
73 #define	DLD_PROP_NO_ZEROCOPY	"no-zerocopy"
74 
75 /*
76  * Prevent advertising of the DL_CAPAB_SOFTRING capability.
77  */
78 #define	DLD_PROP_NO_SOFTRING	"no-softring"
79 
80 /*
81  * The name of the driver.
82  */
83 #define	DLD_DRIVER_NAME		"dld"
84 
85 #if _LONG_LONG_ALIGNMENT == 8 && _LONG_LONG_ALIGNMENT_32 == 4
86 #pragma pack(4)
87 #endif
88 
89 /*
90  * IOCTL codes and data structures.
91  */
92 #define	DLDIOC_ATTR	DLDIOC(0x03)
93 
94 typedef struct dld_ioc_attr {
95 	datalink_id_t		dia_linkid;
96 	uint_t			dia_max_sdu;
97 } dld_ioc_attr_t;
98 
99 #define	DLDIOC_VLAN_ATTR	DLDIOC(0x04)
100 typedef struct dld_ioc_vlan_attr {
101 	datalink_id_t	div_vlanid;
102 	uint16_t	div_vid;
103 	datalink_id_t	div_linkid;
104 	boolean_t	div_force;
105 } dld_ioc_vlan_attr_t;
106 
107 #define	DLDIOC_PHYS_ATTR	DLDIOC(0x05)
108 #define	DLPI_LINKNAME_MAX	32
109 
110 typedef struct dld_ioc_phys_attr {
111 	datalink_id_t	dip_linkid;
112 	/*
113 	 * Whether this physical link supports vanity naming. Note that
114 	 * physical links whose media type is not supported by GLDv3
115 	 * can not support vanity naming.
116 	 */
117 	boolean_t	dip_novanity;
118 	char		dip_dev[MAXLINKNAMELEN];
119 } dld_ioc_phys_attr_t;
120 
121 /*
122  * Secure objects ioctls
123  */
124 typedef enum {
125 	DLD_SECOBJ_CLASS_WEP = 1,
126 	DLD_SECOBJ_CLASS_WPA
127 } dld_secobj_class_t;
128 
129 #define	DLD_SECOBJ_OPT_CREATE	0x00000001
130 #define	DLD_SECOBJ_NAME_MAX	32
131 #define	DLD_SECOBJ_VAL_MAX	256
132 typedef struct dld_secobj {
133 	char			so_name[DLD_SECOBJ_NAME_MAX];
134 	dld_secobj_class_t	so_class;
135 	uint8_t			so_val[DLD_SECOBJ_VAL_MAX];
136 	uint_t			so_len;
137 } dld_secobj_t;
138 
139 #define	DLDIOC_SECOBJ_SET	DLDIOC(0x06)
140 typedef struct dld_ioc_secobj_set {
141 	dld_secobj_t		ss_obj;
142 	uint_t			ss_flags;
143 } dld_ioc_secobj_set_t;
144 
145 #define	DLDIOC_SECOBJ_GET	DLDIOC(0x07)
146 typedef struct dld_ioc_secobj_get {
147 	dld_secobj_t		sg_obj;
148 	uint_t			sg_count;
149 	uint_t			sg_size;
150 } dld_ioc_secobj_get_t;
151 
152 /*
153  * The following two slots were used outside of ON, so don't reuse them.
154  *
155  * #define DLDIOCHOLDVLAN DLDIOC(0x08)
156  * #define DLDIOCRELEVLAN DLDIOC(0x09)
157  */
158 
159 #define	DLDIOC_SECOBJ_UNSET	DLDIOC(0x0a)
160 typedef struct dld_ioc_secobj_unset {
161 	char			su_name[DLD_SECOBJ_NAME_MAX];
162 } dld_ioc_secobj_unset_t;
163 
164 #define	DLDIOC_CREATE_VLAN	DLDIOC(0x0b)
165 typedef struct dld_ioc_create_vlan {
166 	datalink_id_t	dic_vlanid;
167 	datalink_id_t	dic_linkid;
168 	uint16_t	dic_vid;
169 	boolean_t	dic_force;
170 } dld_ioc_create_vlan_t;
171 
172 #define	DLDIOC_DELETE_VLAN	DLDIOC(0x0c)
173 typedef struct dld_ioc_delete_vlan {
174 	datalink_id_t	did_linkid;
175 } dld_ioc_delete_vlan_t;
176 
177 /*
178  * The following constants have been removed, and the slots are open:
179  *
180  * #define DLDIOC_SETAUTOPUSH	DLDIOC(0x0d)
181  * #define DLDIOC_GETAUTOPUSH	DLDIOC(0x0e)
182  * #define DLDIOC_CLRAUTOPUSH	DLDIOC(0x0f)
183  */
184 
185 #define	DLDIOC_DOORSERVER	DLDIOC(0x10)
186 typedef struct dld_ioc_door {
187 	boolean_t	did_start_door;
188 } dld_ioc_door_t;
189 
190 #define	DLDIOC_RENAME		DLDIOC(0x11)
191 typedef struct dld_ioc_rename {
192 	datalink_id_t	dir_linkid1;
193 	datalink_id_t	dir_linkid2;
194 	char		dir_link[MAXLINKNAMELEN];
195 } dld_ioc_rename_t;
196 
197 /*
198  * The following constants have been removed, and the slots are open:
199  *
200  * #define DLDIOC_SETZID	DLDIOC(0x12)
201  * #define DLDIOC_GETZID	DLDIOC(0x13)
202  */
203 
204 typedef struct dld_ioc_zid {
205 	zoneid_t	diz_zid;
206 	datalink_id_t	diz_linkid;
207 } dld_ioc_zid_t;
208 
209 /*
210  * data-link autopush configuration.
211  */
212 struct dlautopush {
213 	uint_t	dap_anchor;
214 	uint_t	dap_npush;
215 	char	dap_aplist[MAXAPUSH][FMNAMESZ+1];
216 };
217 
218 #define	DLDIOC_MACADDRGET	DLDIOC(0x15)
219 typedef struct dld_ioc_macaddrget {
220 	datalink_id_t	dig_linkid;
221 	uint_t		dig_count;
222 	uint_t		dig_size;
223 } dld_ioc_macaddrget_t;
224 
225 /* possible flags for dmi_flags below */
226 #define	DLDIOCMACADDR_USED	0x1	/* address slot used */
227 
228 typedef struct dld_macaddrinfo {
229 	uint_t		dmi_slot;
230 	uint_t		dmi_flags;
231 	uint_t		dmi_addrlen;
232 	uchar_t		dmi_addr[MAXMACADDRLEN];
233 	char		dmi_client_name[MAXNAMELEN];
234 	datalink_id_t	dma_client_linkid;
235 } dld_macaddrinfo_t;
236 
237 /*
238  * IOCTL codes and data structures for flowadm.
239  */
240 #define	DLDIOC_ADDFLOW		DLDIOC(0x16)
241 typedef struct dld_ioc_addflow {
242 	datalink_id_t		af_linkid;
243 	flow_desc_t		af_flow_desc;
244 	mac_resource_props_t	af_resource_props;
245 	char			af_name[MAXFLOWNAMELEN];
246 } dld_ioc_addflow_t;
247 
248 #define	DLDIOC_REMOVEFLOW	DLDIOC(0x17)
249 typedef struct dld_ioc_removeflow {
250 	char			rf_name[MAXFLOWNAMELEN];
251 } dld_ioc_removeflow_t;
252 
253 #define	DLDIOC_MODIFYFLOW	DLDIOC(0x18)
254 typedef struct dld_ioc_modifyflow {
255 	char			mf_name[MAXFLOWNAMELEN];
256 	mac_resource_props_t	mf_resource_props;
257 } dld_ioc_modifyflow_t;
258 
259 #define	DLDIOC_WALKFLOW		DLDIOC(0x19)
260 typedef struct dld_ioc_walkflow {
261 	datalink_id_t		wf_linkid;
262 	char			wf_name[MAXFLOWNAMELEN];
263 	uint32_t		wf_nflows;
264 	uint_t			wf_len;
265 } dld_ioc_walkflow_t;
266 
267 typedef struct dld_flowinfo {
268 	datalink_id_t		fi_linkid;
269 	flow_desc_t		fi_flow_desc;
270 	mac_resource_props_t	fi_resource_props;
271 	char			fi_flowname[MAXFLOWNAMELEN];
272 	uint32_t		fi_pad;
273 } dld_flowinfo_t;
274 
275 #define	DLDIOC_USAGELOG		DLDIOC(0x1a)
276 typedef struct dld_ioc_usagelog {
277 	mac_logtype_t	ul_type;
278 	boolean_t	ul_onoff;
279 	uint_t		ul_interval;
280 } dld_ioc_usagelog_t;
281 
282 #define	DLDIOC_SETMACPROP	DLDIOC(0x1b)
283 #define	DLDIOC_GETMACPROP	DLDIOC(0x1c)
284 
285 /* pr_flags can be set to a combination of the following flags */
286 #define	DLD_PROP_DEFAULT	0x0001
287 #define	DLD_PROP_POSSIBLE	0x0002
288 
289 typedef struct dld_ioc_macprop_s {
290 	uint_t		pr_flags;
291 	datalink_id_t	pr_linkid;
292 	mac_prop_id_t	pr_num;
293 	uint_t		pr_perm_flags;
294 	char		pr_name[MAXLINKPROPNAME];
295 	uint_t		pr_valsize;		/* sizeof pr_val */
296 	char		pr_val[1];
297 } dld_ioc_macprop_t;
298 
299 #define	DLDIOC_GETHWGRP		DLDIOC(0x1d)
300 
301 typedef struct dld_ioc_hwgrpget {
302 	datalink_id_t	dih_linkid;
303 	uint_t		dih_n_groups;	/* number of groups included in ioc */
304 	uint_t		dih_size;
305 } dld_ioc_hwgrpget_t;
306 
307 #define	MAXCLIENTNAMELEN	1024
308 typedef struct dld_hwgrpinfo {
309 	char	dhi_link_name[MAXLINKNAMELEN];
310 	uint_t	dhi_grp_num;
311 	uint_t	dhi_grp_type;
312 	uint_t	dhi_n_rings;
313 	uint_t	dhi_n_clnts;
314 	uint_t	dhi_rings[MAX_RINGS_PER_GROUP];
315 	char	dhi_clnts[MAXCLIENTNAMELEN];
316 } dld_hwgrpinfo_t;
317 
318 #define	DLDIOC_GETTRAN		DLDIOC(0x1e)
319 
320 #define	DLDIOC_GETTRAN_GETNTRAN	UINT32_MAX
321 
322 typedef struct dld_ioc_gettran {
323 	datalink_id_t		dgt_linkid;
324 	uint_t			dgt_tran_id;
325 	boolean_t		dgt_present;
326 	boolean_t		dgt_usable;
327 } dld_ioc_gettran_t;
328 
329 #define	DLDIOC_READTRAN		DLDIOC(0x1f)
330 typedef struct dld_ioc_tranio {
331 	datalink_id_t	dti_linkid;
332 	uint_t		dti_tran_id;
333 	uint_t		dti_page;
334 	uint_t		dti_nbytes;
335 	uint_t		dti_off;
336 	uint64_t	dti_buf;
337 } dld_ioc_tranio_t;
338 
339 #define	DLDIOC_GETLED		DLDIOC(0x20)
340 #define	DLDIOC_SETLED		DLDIOC(0x21)
341 
342 typedef struct dld_ioc_led {
343 	datalink_id_t	dil_linkid;
344 	mac_led_mode_t	dil_supported;
345 	mac_led_mode_t	dil_active;
346 	uint_t		dil_pad;
347 } dld_ioc_led_t;
348 
349 #if _LONG_LONG_ALIGNMENT == 8 && _LONG_LONG_ALIGNMENT_32 == 4
350 #pragma pack()
351 #endif
352 
353 #ifdef _KERNEL
354 
355 #define	DLD_CAPAB_DIRECT	0x00000001
356 #define	DLD_CAPAB_POLL		0x00000002
357 #define	DLD_CAPAB_PERIM		0x00000003
358 #define	DLD_CAPAB_LSO		0x00000004
359 
360 #define	DLD_ENABLE		0x00000001
361 #define	DLD_DISABLE		0x00000002
362 #define	DLD_QUERY		0x00000003
363 
364 /*
365  * GLDv3 entry point for negotiating capabilities.
366  * This is exposed to IP after negotiation of DL_CAPAB_DLD.
367  *
368  * This function takes the following arguments:
369  * handle: used for identifying the interface to operate on (provided by dld).
370  * type: capability type.
371  * arg: points to a capability-specific structure.
372  * flags: used for indicating whether to enable or disable a capability.
373  *
374  * With this function, capability negotiation is reduced from a multi-step
375  * process to just one single function call.
376  * e.g. the following code would pass 'x' from IP to dld and obtain
377  * arg.output_arg from dld:
378  *
379  * arg.input_arg = x;
380  * rc = (*dld_capab)(handle, DLD_CAPAB_XXX, &arg, DLD_ENABLE);
381  * ill->info1 = arg.output_arg;
382  */
383 typedef	int	(*dld_capab_func_t)(void *, uint_t, void *, uint_t);
384 
385 /*
386  * Direct Tx/Rx capability.
387  */
388 typedef struct dld_capab_direct_s {
389 	/*
390 	 * Rx entry point and handle, owned by IP.
391 	 */
392 	uintptr_t	di_rx_cf;
393 	void		*di_rx_ch;
394 
395 	/*
396 	 * Tx entry points and handle, owned by DLD.
397 	 */
398 	/* Entry point for transmitting packets */
399 	uintptr_t	di_tx_df;
400 	void		*di_tx_dh;
401 
402 	/* flow control notification callback */
403 	uintptr_t	di_tx_cb_df; /* callback registration/de-registration */
404 	void		*di_tx_cb_dh;
405 
406 	/* flow control "can I put on a ring" callback */
407 	uintptr_t	di_tx_fctl_df; /* canput-like callback */
408 	void		*di_tx_fctl_dh;
409 } dld_capab_direct_t;
410 
411 /*
412  * Polling/softring capability.
413  */
414 #define	POLL_SOFTRING		0x00000001
415 typedef struct dld_capab_poll_s {
416 	uintptr_t	poll_ring_add_cf;
417 	uintptr_t	poll_ring_remove_cf;
418 	uintptr_t	poll_ring_quiesce_cf;
419 	uintptr_t	poll_ring_restart_cf;
420 	uintptr_t	poll_ring_bind_cf;
421 	void		*poll_ring_ch;
422 	uintptr_t	poll_mac_accept_df;
423 	void		*poll_mac_dh;
424 } dld_capab_poll_t;
425 
426 /*
427  * LSO capability
428  */
429 /*
430  * Currently supported flags for LSO.
431  */
432 #define	DLD_LSO_BASIC_TCP_IPV4	0x01	/* TCP LSO over IPv4 capability */
433 #define	DLD_LSO_BASIC_TCP_IPV6	0x02	/* TCP LSO over IPv6 capability */
434 
435 typedef struct dld_capab_lso_s {
436 	uint_t  lso_flags;	/* capability flags */
437 	uint_t  lso_max_tcpv4;	/* maximum TCPv4 payload */
438 	uint_t  lso_max_tcpv6;	/* maximum TCPv6 payload */
439 } dld_capab_lso_t;
440 
441 int	dld_getinfo(dev_info_t *, ddi_info_cmd_t, void *, void **);
442 int	dld_devt_to_instance(dev_t);
443 int	dld_open(queue_t *, dev_t *, int, int, cred_t *);
444 int	dld_close(queue_t *, int, cred_t *);
445 int	dld_wput(queue_t *, mblk_t *);
446 int	dld_wsrv(queue_t *);
447 int	dld_str_open(queue_t *, dev_t *, void *);
448 int	dld_str_close(queue_t *);
449 void	*dld_str_private(queue_t *);
450 void	dld_init_ops(struct dev_ops *, const char *);
451 void	dld_fini_ops(struct dev_ops *);
452 int	dld_autopush(dev_t *, struct dlautopush *);
453 
454 int	dld_add_flow(datalink_id_t, char *, flow_desc_t *,
455     mac_resource_props_t *);
456 int	dld_remove_flow(char *);
457 int	dld_modify_flow(char *, mac_resource_props_t *);
458 int	dld_walk_flow(dld_ioc_walkflow_t *, intptr_t, cred_t *);
459 
460 #endif
461 
462 #ifdef	__cplusplus
463 }
464 #endif
465 
466 #endif	/* _SYS_DLD_H */
467