xref: /illumos-gate/usr/src/uts/common/sys/dls_impl.h (revision a25df667)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5ba2e4443Sseb  * Common Development and Distribution License (the "License").
6ba2e4443Sseb  * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate  *
87c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate  * and limitations under the License.
127c478bd9Sstevel@tonic-gate  *
137c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate  *
197c478bd9Sstevel@tonic-gate  * CDDL HEADER END
207c478bd9Sstevel@tonic-gate  */
217c478bd9Sstevel@tonic-gate /*
22ae6aa22aSVenugopal Iyer  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
247c478bd9Sstevel@tonic-gate  */
257c478bd9Sstevel@tonic-gate 
267c478bd9Sstevel@tonic-gate #ifndef	_SYS_DLS_IMPL_H
277c478bd9Sstevel@tonic-gate #define	_SYS_DLS_IMPL_H
287c478bd9Sstevel@tonic-gate 
297c478bd9Sstevel@tonic-gate #include <sys/stream.h>
307c478bd9Sstevel@tonic-gate #include <sys/dls.h>
31da14cebeSEric Cheng #include <sys/mac_provider.h>
32da14cebeSEric Cheng #include <sys/mac_client.h>
33da14cebeSEric Cheng #include <sys/mac_client_priv.h>
34210db224Sericheng #include <sys/modhash.h>
357c478bd9Sstevel@tonic-gate #include <sys/kstat.h>
367c478bd9Sstevel@tonic-gate #include <net/if.h>
374b46d1efSkrgopi #include <sys/dlpi.h>
387c478bd9Sstevel@tonic-gate 
397c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
407c478bd9Sstevel@tonic-gate extern "C" {
417c478bd9Sstevel@tonic-gate #endif
427c478bd9Sstevel@tonic-gate 
43da14cebeSEric Cheng typedef struct dls_multicst_addr_s {
44da14cebeSEric Cheng 	struct dls_multicst_addr_s	*dma_nextp;		/* ds_rw_lock */
45ba2e4443Sseb 	uint8_t				dma_addr[MAXMACADDRLEN];
46da14cebeSEric Cheng } dls_multicst_addr_t;
47da14cebeSEric Cheng 
48da14cebeSEric Cheng struct dls_link_s {				/* Protected by */
49*a25df667SRobert Mustacchi 	char			dl_name[MAXNAMELEN];	/* RO */
50da14cebeSEric Cheng 	uint_t			dl_ddi_instance;	/* SL */
51da14cebeSEric Cheng 	mac_handle_t		dl_mh;			/* SL */
52da14cebeSEric Cheng 	mac_client_handle_t	dl_mch;			/* SL */
53da14cebeSEric Cheng 	mac_unicast_handle_t	dl_mah;			/* SL */
54*a25df667SRobert Mustacchi 	mac_notify_handle_t	dl_mnh;			/* SL */
55da14cebeSEric Cheng 	const mac_info_t	*dl_mip;		/* SL */
56da14cebeSEric Cheng 	uint_t			dl_ref;			/* SL */
57da14cebeSEric Cheng 	mod_hash_t		*dl_str_hash;		/* SL, modhash lock */
58da14cebeSEric Cheng 	uint_t			dl_impl_count;		/* SL */
59da14cebeSEric Cheng 	uint_t			dl_nactive;		/* SL */
60da14cebeSEric Cheng 	uint32_t		dl_unknowns;		/* atomic */
61da14cebeSEric Cheng 	zoneid_t		dl_zid;
62da14cebeSEric Cheng 	uint_t			dl_zone_ref;
63e75f0919SSebastien Roy 	link_tagmode_t		dl_tagmode;		/* atomic */
648d4cf8d8S 	uint_t			dl_nonip_cnt;		/* SL */
657c478bd9Sstevel@tonic-gate };
667c478bd9Sstevel@tonic-gate 
67da14cebeSEric Cheng typedef struct dls_head_s {
68da14cebeSEric Cheng 	kmutex_t		dh_lock;
69da14cebeSEric Cheng 	struct dld_str_s	*dh_list;		/* dh_ref */
70da14cebeSEric Cheng 	uint_t			dh_ref;			/* dh_lock */
71da14cebeSEric Cheng 	mod_hash_key_t		dh_key;			/* SL */
72da14cebeSEric Cheng 	kcondvar_t		dh_cv;			/* dh_lock */
73da14cebeSEric Cheng 	uint_t			dh_removing;		/* dh_lock */
74da14cebeSEric Cheng } dls_head_t;
75210db224Sericheng 
76ae6aa22aSVenugopal Iyer extern mod_hash_t	*i_dls_link_hash;
77ae6aa22aSVenugopal Iyer 
787c478bd9Sstevel@tonic-gate extern void		dls_link_init(void);
797c478bd9Sstevel@tonic-gate extern int		dls_link_fini(void);
80a08fa175Syz147064 extern int		dls_link_hold(const char *, dls_link_t **);
81da14cebeSEric Cheng extern int		dls_link_hold_create(const char *, dls_link_t **);
82da14cebeSEric Cheng extern int		dls_link_hold_by_dev(dev_t, dls_link_t **);
837c478bd9Sstevel@tonic-gate extern void		dls_link_rele(dls_link_t *);
84da14cebeSEric Cheng extern int		dls_link_rele_by_name(const char *);
85da14cebeSEric Cheng extern void		dls_link_add(dls_link_t *, uint32_t, dld_str_t *);
86da14cebeSEric Cheng extern void		dls_link_remove(dls_link_t *, dld_str_t *);
870a0e9771SDarren Reed extern int		dls_link_getzid(const char *, zoneid_t *);
88da14cebeSEric Cheng extern int		dls_link_setzid(const char *, zoneid_t);
89da14cebeSEric Cheng extern dev_info_t	*dls_link_devinfo(dev_t);
90da14cebeSEric Cheng extern dev_t		dls_link_dev(dls_link_t *);
91da14cebeSEric Cheng 
92da14cebeSEric Cheng extern void		i_dls_head_rele(dls_head_t *);
93da14cebeSEric Cheng extern int		dls_mac_active_set(dls_link_t *i);
94d62bc4baSyz147064 extern void		dls_mac_active_clear(dls_link_t *);
957c478bd9Sstevel@tonic-gate 
96da14cebeSEric Cheng extern void		dls_create_str_kstats(dld_str_t *);
97da14cebeSEric Cheng extern int		dls_stat_update(kstat_t *, dls_link_t *, int);
98d62bc4baSyz147064 extern int		dls_stat_create(const char *, int, const char *,
992b24ab6bSSebastien Roy 			    zoneid_t, int (*)(struct kstat *, int), void *,
1002b24ab6bSSebastien Roy 			    kstat_t **);
101d62bc4baSyz147064 
102da14cebeSEric Cheng extern int		dls_devnet_open_by_dev(dev_t, dls_link_t **,
103d62bc4baSyz147064 			    dls_dl_handle_t *);
104da14cebeSEric Cheng extern int		dls_devnet_hold_link(datalink_id_t, dls_dl_handle_t *,
105da14cebeSEric Cheng 			    dls_link_t **);
106da14cebeSEric Cheng extern void		dls_devnet_rele_link(dls_dl_handle_t, dls_link_t *);
107*a25df667SRobert Mustacchi extern int		dls_devnet_hold_tmp_by_link(dls_link_t *,
108*a25df667SRobert Mustacchi 			    dls_dl_handle_t *);
1097c478bd9Sstevel@tonic-gate 
1107c478bd9Sstevel@tonic-gate extern void		dls_init(void);
1117c478bd9Sstevel@tonic-gate extern int		dls_fini(void);
112a08fa175Syz147064 extern void		dls_link_txloop(void *, mblk_t *);
113da14cebeSEric Cheng extern boolean_t	dls_accept(dld_str_t *, mac_header_info_t *,
114cd93090eSericheng 			    dls_rx_t *, void **);
115da14cebeSEric Cheng extern boolean_t	dls_accept_loopback(dld_str_t *, mac_header_info_t *,
116605445d5Sdg199075 			    dls_rx_t *, void **);
117da14cebeSEric Cheng extern boolean_t	dls_accept_promisc(dld_str_t *, mac_header_info_t *,
118da14cebeSEric Cheng 			    dls_rx_t *, void **, boolean_t);
119da14cebeSEric Cheng extern void		i_dls_link_rx(void *, mac_resource_handle_t, mblk_t *,
120da14cebeSEric Cheng 			    boolean_t);
121da14cebeSEric Cheng extern void		dls_rx_promisc(void *, mac_resource_handle_t, mblk_t *,
122da14cebeSEric Cheng 			    boolean_t);
123da14cebeSEric Cheng extern void		dls_rx_vlan_promisc(void *, mac_resource_handle_t,
124da14cebeSEric Cheng 			    mblk_t *, boolean_t);
125da14cebeSEric Cheng extern int		dls_active_set(dld_str_t *);
1265d460eafSCathy Zhou extern void		dls_active_clear(dld_str_t *, boolean_t);
1277c478bd9Sstevel@tonic-gate 
128d62bc4baSyz147064 extern void		dls_mgmt_init(void);
129d62bc4baSyz147064 extern void		dls_mgmt_fini(void);
130d62bc4baSyz147064 
131d62bc4baSyz147064 extern int		dls_mgmt_get_phydev(datalink_id_t, dev_t *);
132d62bc4baSyz147064 
1337c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
1347c478bd9Sstevel@tonic-gate }
1357c478bd9Sstevel@tonic-gate #endif
1367c478bd9Sstevel@tonic-gate 
1377c478bd9Sstevel@tonic-gate #endif	/* _SYS_DLS_IMPL_H */
138