#ifndef _SYS_DLS_IMPL_H
#define _SYS_DLS_IMPL_H
#include <sys/stream.h>
#include <sys/dls.h>
#include <sys/mac_provider.h>
#include <sys/mac_client.h>
#include <sys/mac_client_priv.h>
#include <sys/modhash.h>
#include <sys/kstat.h>
#include <net/if.h>
#include <sys/dlpi.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef struct dls_multicst_addr_s {
struct dls_multicst_addr_s *dma_nextp;
uint8_t dma_addr[MAXMACADDRLEN];
} dls_multicst_addr_t;
struct dls_link_s {
char dl_name[MAXNAMELEN];
uint_t dl_ddi_instance;
mac_handle_t dl_mh;
mac_client_handle_t dl_mch;
mac_unicast_handle_t dl_mah;
mac_notify_handle_t dl_mnh;
const mac_info_t *dl_mip;
uint_t dl_ref;
mod_hash_t *dl_str_hash;
uint_t dl_impl_count;
uint_t dl_nactive;
uint32_t dl_unknowns;
zoneid_t dl_zid;
uint_t dl_zone_ref;
link_tagmode_t dl_tagmode;
uint_t dl_nonip_cnt;
};
typedef struct dls_head_s {
kmutex_t dh_lock;
struct dld_str_s *dh_list;
uint_t dh_ref;
mod_hash_key_t dh_key;
kcondvar_t dh_cv;
uint_t dh_removing;
} dls_head_t;
extern mod_hash_t *i_dls_link_hash;
extern void dls_link_init(void);
extern int dls_link_fini(void);
extern int dls_link_hold(const char *, dls_link_t **);
extern int dls_link_hold_create(const char *, dls_link_t **);
extern int dls_link_hold_by_dev(dev_t, dls_link_t **);
extern void dls_link_rele(dls_link_t *);
extern int dls_link_rele_by_name(const char *);
extern void dls_link_add(dls_link_t *, uint32_t, dld_str_t *);
extern void dls_link_remove(dls_link_t *, dld_str_t *);
extern int dls_link_getzid(const char *, zoneid_t *);
extern int dls_link_setzid(const char *, zoneid_t);
extern dev_info_t *dls_link_devinfo(dev_t);
extern dev_t dls_link_dev(dls_link_t *);
extern void i_dls_head_rele(dls_head_t *);
extern int dls_mac_active_set(dls_link_t *i);
extern void dls_mac_active_clear(dls_link_t *);
extern void dls_create_str_kstats(dld_str_t *);
extern int dls_stat_update(kstat_t *, dls_link_t *, int);
extern int dls_stat_create(const char *, int, const char *,
zoneid_t, int (*)(struct kstat *, int), void *,
kstat_t **);
extern int dls_devnet_open_by_dev(dev_t, dls_link_t **,
dls_dl_handle_t *);
extern int dls_devnet_hold_link(datalink_id_t, dls_dl_handle_t *,
dls_link_t **);
extern void dls_devnet_rele_link(dls_dl_handle_t, dls_link_t *);
extern int dls_devnet_hold_tmp_by_link(dls_link_t *,
dls_dl_handle_t *);
extern void dls_init(void);
extern int dls_fini(void);
extern void dls_link_txloop(void *, mblk_t *);
extern boolean_t dls_accept(dld_str_t *, mac_header_info_t *,
dls_rx_t *, void **);
extern boolean_t dls_accept_loopback(dld_str_t *, mac_header_info_t *,
dls_rx_t *, void **);
extern boolean_t dls_accept_promisc(dld_str_t *, mac_header_info_t *,
dls_rx_t *, void **, boolean_t);
extern void i_dls_link_rx(void *, mac_resource_handle_t, mblk_t *,
boolean_t);
extern void dls_rx_promisc(void *, mac_resource_handle_t, mblk_t *,
boolean_t);
extern void dls_rx_vlan_promisc(void *, mac_resource_handle_t,
mblk_t *, boolean_t);
extern int dls_active_set(dld_str_t *);
extern void dls_active_clear(dld_str_t *, boolean_t);
extern void dls_mgmt_init(void);
extern void dls_mgmt_fini(void);
extern int dls_mgmt_get_phydev(datalink_id_t, dev_t *);
#ifdef __cplusplus
}
#endif
#endif