11ae08745Sheppo /* 21ae08745Sheppo * CDDL HEADER START 31ae08745Sheppo * 41ae08745Sheppo * The contents of this file are subject to the terms of the 51ae08745Sheppo * Common Development and Distribution License (the "License"). 61ae08745Sheppo * You may not use this file except in compliance with the License. 71ae08745Sheppo * 81ae08745Sheppo * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 91ae08745Sheppo * or http://www.opensolaris.org/os/licensing. 101ae08745Sheppo * See the License for the specific language governing permissions 111ae08745Sheppo * and limitations under the License. 121ae08745Sheppo * 131ae08745Sheppo * When distributing Covered Code, include this CDDL HEADER in each 141ae08745Sheppo * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 151ae08745Sheppo * If applicable, add the following below this CDDL HEADER, with the 161ae08745Sheppo * fields enclosed by brackets "[]" replaced with your own identifying 171ae08745Sheppo * information: Portions Copyright [yyyy] [name of copyright owner] 181ae08745Sheppo * 191ae08745Sheppo * CDDL HEADER END 201ae08745Sheppo */ 211ae08745Sheppo 221ae08745Sheppo /* 236f09f0feSWENTAO YANG * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 241ae08745Sheppo * Use is subject to license terms. 251ae08745Sheppo */ 261ae08745Sheppo 271ae08745Sheppo #ifndef _VNET_H 281ae08745Sheppo #define _VNET_H 291ae08745Sheppo 301ae08745Sheppo #ifdef __cplusplus 311ae08745Sheppo extern "C" { 321ae08745Sheppo #endif 331ae08745Sheppo 34678453a8Sspeer #include <sys/vnet_res.h> 35678453a8Sspeer #include <sys/vnet_mailbox.h> 363fd94f8cSam223141 #include <sys/modhash.h> 37678453a8Sspeer 381ae08745Sheppo #define VNET_SUCCESS (0) /* successful return */ 391ae08745Sheppo #define VNET_FAILURE (-1) /* unsuccessful return */ 401ae08745Sheppo 411ae08745Sheppo #define KMEM_FREE(_p) kmem_free((_p), sizeof (*(_p))) 421ae08745Sheppo 431ae08745Sheppo #define VNET_NTXDS 512 /* power of 2 tx descriptors */ 441ae08745Sheppo #define VNET_LDCWD_INTERVAL 1000 /* watchdog freq in msec */ 451ae08745Sheppo #define VNET_LDCWD_TXTIMEOUT 1000 /* tx timeout in msec */ 46e1ebb9ecSlm66018 #define VNET_LDC_MTU 64 /* ldc mtu */ 471ae08745Sheppo 48678453a8Sspeer 49678453a8Sspeer #define IS_BROADCAST(ehp) \ 50678453a8Sspeer (ether_cmp(&ehp->ether_dhost, ðerbroadcastaddr) == 0) 51678453a8Sspeer #define IS_MULTICAST(ehp) \ 52678453a8Sspeer ((ehp->ether_dhost.ether_addr_octet[0] & 01) == 1) 53678453a8Sspeer 54678453a8Sspeer #define VNET_MATCH_RES(vresp, vnetp) \ 55678453a8Sspeer (ether_cmp(vresp->local_macaddr, vnetp->curr_macaddr) == 0) 56c1c61f44Ssb155480 57*5460ddbdSSriharsha Basavapatna /* 58*5460ddbdSSriharsha Basavapatna * Flags used to indicate the state of the vnet device and its associated 59*5460ddbdSSriharsha Basavapatna * resources. 60*5460ddbdSSriharsha Basavapatna */ 61*5460ddbdSSriharsha Basavapatna typedef enum vnet_flags { 62*5460ddbdSSriharsha Basavapatna VNET_STOPPED = 0x0, 63*5460ddbdSSriharsha Basavapatna VNET_STARTED = 0x1, 64*5460ddbdSSriharsha Basavapatna VNET_STOPPING = 0x2 65*5460ddbdSSriharsha Basavapatna } vnet_flags_t; 66*5460ddbdSSriharsha Basavapatna 676ab6cb20SWENTAO YANG typedef struct vnet_hio_stats { 686ab6cb20SWENTAO YANG /* Link Input/Output stats */ 696ab6cb20SWENTAO YANG uint64_t ipackets; /* # rx packets */ 706ab6cb20SWENTAO YANG uint64_t ierrors; /* # rx error */ 716ab6cb20SWENTAO YANG uint64_t opackets; /* # tx packets */ 726ab6cb20SWENTAO YANG uint64_t oerrors; /* # tx error */ 736ab6cb20SWENTAO YANG 746ab6cb20SWENTAO YANG /* MIB II variables */ 756ab6cb20SWENTAO YANG uint64_t rbytes; /* # bytes received */ 766ab6cb20SWENTAO YANG uint64_t obytes; /* # bytes transmitted */ 776ab6cb20SWENTAO YANG uint32_t multircv; /* # multicast packets received */ 786ab6cb20SWENTAO YANG uint32_t multixmt; /* # multicast packets for xmit */ 796ab6cb20SWENTAO YANG uint32_t brdcstrcv; /* # broadcast packets received */ 806ab6cb20SWENTAO YANG uint32_t brdcstxmt; /* # broadcast packets for xmit */ 816ab6cb20SWENTAO YANG uint32_t norcvbuf; /* # rcv packets discarded */ 826ab6cb20SWENTAO YANG uint32_t noxmtbuf; /* # xmit packets discarded */ 836ab6cb20SWENTAO YANG } vnet_hio_stats_t; 846ab6cb20SWENTAO YANG 856ab6cb20SWENTAO YANG typedef struct vnet_hio_kstats { 866ab6cb20SWENTAO YANG /* Link Input/Output stats */ 876ab6cb20SWENTAO YANG kstat_named_t ipackets; 886ab6cb20SWENTAO YANG kstat_named_t ipackets64; 896ab6cb20SWENTAO YANG kstat_named_t ierrors; 906ab6cb20SWENTAO YANG kstat_named_t opackets; 916ab6cb20SWENTAO YANG kstat_named_t opackets64; 926ab6cb20SWENTAO YANG kstat_named_t oerrors; 936ab6cb20SWENTAO YANG 946ab6cb20SWENTAO YANG /* required by kstat for MIB II objects(RFC 1213) */ 956ab6cb20SWENTAO YANG kstat_named_t rbytes; /* MIB - ifInOctets */ 966ab6cb20SWENTAO YANG kstat_named_t rbytes64; 976ab6cb20SWENTAO YANG kstat_named_t obytes; /* MIB - ifOutOctets */ 986ab6cb20SWENTAO YANG kstat_named_t obytes64; 996ab6cb20SWENTAO YANG kstat_named_t multircv; /* MIB - ifInNUcastPkts */ 1006ab6cb20SWENTAO YANG kstat_named_t multixmt; /* MIB - ifOutNUcastPkts */ 1016ab6cb20SWENTAO YANG kstat_named_t brdcstrcv; /* MIB - ifInNUcastPkts */ 1026ab6cb20SWENTAO YANG kstat_named_t brdcstxmt; /* MIB - ifOutNUcastPkts */ 1036ab6cb20SWENTAO YANG kstat_named_t norcvbuf; /* MIB - ifInDiscards */ 1046ab6cb20SWENTAO YANG kstat_named_t noxmtbuf; /* MIB - ifOutDiscards */ 1056ab6cb20SWENTAO YANG } vnet_hio_kstats_t; 1066ab6cb20SWENTAO YANG 1071ae08745Sheppo /* 108678453a8Sspeer * A vnet resource structure. 1091ae08745Sheppo */ 110678453a8Sspeer typedef struct vnet_res { 111678453a8Sspeer struct vnet_res *nextp; /* next resource in the list */ 112678453a8Sspeer mac_register_t macreg; /* resource's mac_reg */ 113678453a8Sspeer vio_net_res_type_t type; /* resource type */ 114678453a8Sspeer ether_addr_t local_macaddr; /* resource's macaddr */ 115678453a8Sspeer ether_addr_t rem_macaddr; /* resource's remote macaddr */ 116*5460ddbdSSriharsha Basavapatna vnet_flags_t flags; /* resource flags */ 117c1c61f44Ssb155480 uint32_t refcnt; /* reference count */ 118678453a8Sspeer struct vnet *vnetp; /* back pointer to vnet */ 1196ab6cb20SWENTAO YANG kstat_t *ksp; /* hio kstats */ 120678453a8Sspeer } vnet_res_t; 121678453a8Sspeer 122678453a8Sspeer #define VNET_DDS_TASK_ADD_SHARE 0x01 123678453a8Sspeer #define VNET_DDS_TASK_DEL_SHARE 0x02 124678453a8Sspeer #define VNET_DDS_TASK_REL_SHARE 0x04 125678453a8Sspeer 126678453a8Sspeer /* An instance specific DDS structure */ 127678453a8Sspeer typedef struct vnet_dds_info { 128678453a8Sspeer kmutex_t lock; /* lock for this structure */ 129678453a8Sspeer uint8_t task_flags; /* flags for taskq */ 130678453a8Sspeer uint8_t dds_req_id; /* DDS message request id */ 131678453a8Sspeer vio_dds_msg_t dmsg; /* Pending DDS message */ 132678453a8Sspeer dev_info_t *hio_dip; /* Hybrid device's dip */ 133678453a8Sspeer uint64_t hio_cookie; /* Hybrid device's cookie */ 134678453a8Sspeer ddi_taskq_t *dds_taskqp; /* Taskq's used for DDS */ 135678453a8Sspeer struct vnet *vnetp; /* Back pointer to vnetp */ 136678453a8Sspeer } vnet_dds_info_t; 1371ae08745Sheppo 138c1c61f44Ssb155480 #define VNET_NFDB_HASH 64 1391ae08745Sheppo 140c1c61f44Ssb155480 #define KEY_HASH(key, addr) \ 141678453a8Sspeer (key = (((uint64_t)(addr[0])) << 40) | \ 142678453a8Sspeer (((uint64_t)(addr[1])) << 32) | \ 143678453a8Sspeer (((uint64_t)(addr[2])) << 24) | \ 144678453a8Sspeer (((uint64_t)(addr[3])) << 16) | \ 145678453a8Sspeer (((uint64_t)(addr[4])) << 8) | \ 146678453a8Sspeer ((uint64_t)(addr[5]))); 147678453a8Sspeer 1481ae08745Sheppo 1491ae08745Sheppo /* rwlock macros */ 1501ae08745Sheppo #define READ_ENTER(x) rw_enter(x, RW_READER) 1511ae08745Sheppo #define WRITE_ENTER(x) rw_enter(x, RW_WRITER) 1521ae08745Sheppo #define RW_EXIT(x) rw_exit(x) 1531ae08745Sheppo 154c1c61f44Ssb155480 #define VLAN_ID_KEY(key) ((mod_hash_key_t)(uintptr_t)(key)) 155c1c61f44Ssb155480 1566f09f0feSWENTAO YANG typedef enum { 1576f09f0feSWENTAO YANG AST_init = 0x0, AST_vnet_alloc = 0x1, 1586f09f0feSWENTAO YANG AST_mac_alloc = 0x2, AST_read_macaddr = 0x4, 1596f09f0feSWENTAO YANG AST_vgen_init = 0x8, AST_fdbh_alloc = 0x10, 1606f09f0feSWENTAO YANG AST_vdds_init = 0x20, AST_taskq_create = 0x40, 1616f09f0feSWENTAO YANG AST_vnet_list = 0x80, AST_macreg = 0x100 1626f09f0feSWENTAO YANG } vnet_attach_progress_t; 1636f09f0feSWENTAO YANG 1641ae08745Sheppo /* 1651ae08745Sheppo * vnet instance state information 1661ae08745Sheppo */ 1671ae08745Sheppo typedef struct vnet { 1681ae08745Sheppo int instance; /* instance # */ 1691ae08745Sheppo dev_info_t *dip; /* dev_info */ 170678453a8Sspeer uint64_t reg; /* reg prop value */ 1716f09f0feSWENTAO YANG vnet_attach_progress_t attach_progress; /* attach progress flags */ 1721ae08745Sheppo struct vnet *nextp; /* next in list */ 173ba2e4443Sseb mac_handle_t mh; /* handle to GLDv3 mac module */ 1741ae08745Sheppo uchar_t vendor_addr[ETHERADDRL]; /* orig macadr */ 1751ae08745Sheppo uchar_t curr_macaddr[ETHERADDRL]; /* current macadr */ 176678453a8Sspeer void *vgenhdl; /* Handle for vgen */ 177c1c61f44Ssb155480 178c1c61f44Ssb155480 uint32_t fdb_nchains; /* # of hash chains in fdbtbl */ 179c1c61f44Ssb155480 mod_hash_t *fdb_hashp; /* forwarding database */ 180678453a8Sspeer vnet_res_t *vsw_fp; /* cached fdb entry of vsw */ 181c1c61f44Ssb155480 krwlock_t vsw_fp_rw; /* lock to protect vsw_fp */ 1827b1f684aSSriharsha Basavapatna uint32_t mtu; /* mtu of the device */ 183c1c61f44Ssb155480 184c1c61f44Ssb155480 uint16_t default_vlan_id; /* default vlan id */ 185c1c61f44Ssb155480 uint16_t pvid; /* port vlan id (untagged) */ 186c1c61f44Ssb155480 uint16_t *vids; /* vlan ids (tagged) */ 187c1c61f44Ssb155480 uint16_t nvids; /* # of vids */ 188678453a8Sspeer 1891107ea93SSriharsha Basavapatna link_state_t link_state; /* link status */ 1901107ea93SSriharsha Basavapatna boolean_t pls_update; /* phys link state update ? */ 191*5460ddbdSSriharsha Basavapatna vnet_flags_t flags; /* interface flags */ 192678453a8Sspeer vnet_res_t *hio_fp; /* Hybrid IO resource */ 193678453a8Sspeer vnet_res_t *vres_list; /* Resource list */ 194678453a8Sspeer vnet_dds_info_t vdds_info; /* DDS related info */ 195678453a8Sspeer krwlock_t vrwlock; /* Resource list lock */ 196678453a8Sspeer ddi_taskq_t *taskqp; /* Resource taskq */ 1971ae08745Sheppo } vnet_t; 1981ae08745Sheppo 199844e62a3Sraghuram #ifdef DEBUG 200844e62a3Sraghuram /* 201844e62a3Sraghuram * debug levels: 202844e62a3Sraghuram * DBG_LEVEL1: Function entry/exit tracing 203844e62a3Sraghuram * DBG_LEVEL2: Info messages 204844e62a3Sraghuram * DBG_LEVEL3: Warning messages 205844e62a3Sraghuram * DBG_LEVEL4: Error messages 206844e62a3Sraghuram */ 207844e62a3Sraghuram 208844e62a3Sraghuram enum { DBG_LEVEL1 = 0x01, DBG_LEVEL2 = 0x02, DBG_WARN = 0x04, 209844e62a3Sraghuram DBG_ERR = 0x08 }; 210844e62a3Sraghuram 211844e62a3Sraghuram #define DBG1(...) do { \ 212844e62a3Sraghuram if ((vnet_dbglevel & DBG_LEVEL1) != 0) { \ 213844e62a3Sraghuram debug_printf(__func__, __VA_ARGS__); \ 214844e62a3Sraghuram } \ 215844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 216844e62a3Sraghuram 217844e62a3Sraghuram #define DBG2(...) do { \ 218844e62a3Sraghuram if ((vnet_dbglevel & DBG_LEVEL2) != 0) { \ 219844e62a3Sraghuram debug_printf(__func__, __VA_ARGS__); \ 220844e62a3Sraghuram } \ 221844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 222844e62a3Sraghuram 223844e62a3Sraghuram #define DWARN(...) do { \ 224844e62a3Sraghuram if ((vnet_dbglevel & DBG_WARN) != 0) { \ 225844e62a3Sraghuram debug_printf(__func__, __VA_ARGS__); \ 226844e62a3Sraghuram } \ 227844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 228844e62a3Sraghuram 229844e62a3Sraghuram #define DERR(...) do { \ 230844e62a3Sraghuram if ((vnet_dbglevel & DBG_ERR) != 0) { \ 231844e62a3Sraghuram debug_printf(__func__, __VA_ARGS__); \ 232844e62a3Sraghuram } \ 233844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 234844e62a3Sraghuram 235844e62a3Sraghuram #else 236844e62a3Sraghuram 237844e62a3Sraghuram #define DBG1(...) if (0) do { } while (0) 238844e62a3Sraghuram #define DBG2(...) if (0) do { } while (0) 239844e62a3Sraghuram #define DWARN(...) if (0) do { } while (0) 240844e62a3Sraghuram #define DERR(...) if (0) do { } while (0) 241844e62a3Sraghuram 242844e62a3Sraghuram #endif 243844e62a3Sraghuram 2441107ea93SSriharsha Basavapatna #ifdef VNET_IOC_DEBUG /* Debug ioctls */ 2451107ea93SSriharsha Basavapatna 2461107ea93SSriharsha Basavapatna #define VNET_FORCE_LINK_DOWN 0x1 2471107ea93SSriharsha Basavapatna #define VNET_FORCE_LINK_UP 0x2 2481107ea93SSriharsha Basavapatna 2491107ea93SSriharsha Basavapatna #endif 2501107ea93SSriharsha Basavapatna 2511ae08745Sheppo #ifdef __cplusplus 2521ae08745Sheppo } 2531ae08745Sheppo #endif 2541ae08745Sheppo 2551ae08745Sheppo #endif /* _VNET_H */ 256