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 /* 230dc2366fSVenugopal Iyer * Copyright 2010 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> 3763f531d1SSriharsha Basavapatna #include <net/if.h> 3863f531d1SSriharsha Basavapatna #include <sys/mac_client.h> 39678453a8Sspeer 401ae08745Sheppo #define VNET_SUCCESS (0) /* successful return */ 411ae08745Sheppo #define VNET_FAILURE (-1) /* unsuccessful return */ 421ae08745Sheppo 431ae08745Sheppo #define KMEM_FREE(_p) kmem_free((_p), sizeof (*(_p))) 441ae08745Sheppo 45*7bd3a2e2SSriharsha Basavapatna #define VNET_NUM_DESCRIPTORS 512 /* power of 2 descriptors */ 46678453a8Sspeer 47678453a8Sspeer #define IS_BROADCAST(ehp) \ 48678453a8Sspeer (ether_cmp(&ehp->ether_dhost, ðerbroadcastaddr) == 0) 49678453a8Sspeer #define IS_MULTICAST(ehp) \ 50678453a8Sspeer ((ehp->ether_dhost.ether_addr_octet[0] & 01) == 1) 51678453a8Sspeer 52678453a8Sspeer #define VNET_MATCH_RES(vresp, vnetp) \ 53678453a8Sspeer (ether_cmp(vresp->local_macaddr, vnetp->curr_macaddr) == 0) 54c1c61f44Ssb155480 555460ddbdSSriharsha Basavapatna /* 565460ddbdSSriharsha Basavapatna * Flags used to indicate the state of the vnet device and its associated 575460ddbdSSriharsha Basavapatna * resources. 585460ddbdSSriharsha Basavapatna */ 595460ddbdSSriharsha Basavapatna typedef enum vnet_flags { 605460ddbdSSriharsha Basavapatna VNET_STOPPED = 0x0, 615460ddbdSSriharsha Basavapatna VNET_STARTED = 0x1, 625460ddbdSSriharsha Basavapatna VNET_STOPPING = 0x2 635460ddbdSSriharsha Basavapatna } vnet_flags_t; 645460ddbdSSriharsha Basavapatna 656ab6cb20SWENTAO YANG typedef struct vnet_hio_stats { 666ab6cb20SWENTAO YANG /* Link Input/Output stats */ 676ab6cb20SWENTAO YANG uint64_t ipackets; /* # rx packets */ 686ab6cb20SWENTAO YANG uint64_t ierrors; /* # rx error */ 696ab6cb20SWENTAO YANG uint64_t opackets; /* # tx packets */ 706ab6cb20SWENTAO YANG uint64_t oerrors; /* # tx error */ 716ab6cb20SWENTAO YANG 726ab6cb20SWENTAO YANG /* MIB II variables */ 736ab6cb20SWENTAO YANG uint64_t rbytes; /* # bytes received */ 746ab6cb20SWENTAO YANG uint64_t obytes; /* # bytes transmitted */ 756ab6cb20SWENTAO YANG uint32_t multircv; /* # multicast packets received */ 766ab6cb20SWENTAO YANG uint32_t multixmt; /* # multicast packets for xmit */ 776ab6cb20SWENTAO YANG uint32_t brdcstrcv; /* # broadcast packets received */ 786ab6cb20SWENTAO YANG uint32_t brdcstxmt; /* # broadcast packets for xmit */ 796ab6cb20SWENTAO YANG uint32_t norcvbuf; /* # rcv packets discarded */ 806ab6cb20SWENTAO YANG uint32_t noxmtbuf; /* # xmit packets discarded */ 816ab6cb20SWENTAO YANG } vnet_hio_stats_t; 826ab6cb20SWENTAO YANG 836ab6cb20SWENTAO YANG typedef struct vnet_hio_kstats { 846ab6cb20SWENTAO YANG /* Link Input/Output stats */ 856ab6cb20SWENTAO YANG kstat_named_t ipackets; 866ab6cb20SWENTAO YANG kstat_named_t ipackets64; 876ab6cb20SWENTAO YANG kstat_named_t ierrors; 886ab6cb20SWENTAO YANG kstat_named_t opackets; 896ab6cb20SWENTAO YANG kstat_named_t opackets64; 906ab6cb20SWENTAO YANG kstat_named_t oerrors; 916ab6cb20SWENTAO YANG 926ab6cb20SWENTAO YANG /* required by kstat for MIB II objects(RFC 1213) */ 936ab6cb20SWENTAO YANG kstat_named_t rbytes; /* MIB - ifInOctets */ 946ab6cb20SWENTAO YANG kstat_named_t rbytes64; 956ab6cb20SWENTAO YANG kstat_named_t obytes; /* MIB - ifOutOctets */ 966ab6cb20SWENTAO YANG kstat_named_t obytes64; 976ab6cb20SWENTAO YANG kstat_named_t multircv; /* MIB - ifInNUcastPkts */ 986ab6cb20SWENTAO YANG kstat_named_t multixmt; /* MIB - ifOutNUcastPkts */ 996ab6cb20SWENTAO YANG kstat_named_t brdcstrcv; /* MIB - ifInNUcastPkts */ 1006ab6cb20SWENTAO YANG kstat_named_t brdcstxmt; /* MIB - ifOutNUcastPkts */ 1016ab6cb20SWENTAO YANG kstat_named_t norcvbuf; /* MIB - ifInDiscards */ 1026ab6cb20SWENTAO YANG kstat_named_t noxmtbuf; /* MIB - ifOutDiscards */ 1036ab6cb20SWENTAO YANG } vnet_hio_kstats_t; 1046ab6cb20SWENTAO YANG 1050dc2366fSVenugopal Iyer typedef struct vnet_tx_ring_stats { 1060dc2366fSVenugopal Iyer uint64_t opackets; /* # tx packets */ 1070dc2366fSVenugopal Iyer uint64_t obytes; /* # bytes transmitted */ 1080dc2366fSVenugopal Iyer } vnet_tx_ring_stats_t; 1090dc2366fSVenugopal Iyer 1101ae08745Sheppo /* 111678453a8Sspeer * A vnet resource structure. 1121ae08745Sheppo */ 113678453a8Sspeer typedef struct vnet_res { 114678453a8Sspeer struct vnet_res *nextp; /* next resource in the list */ 115678453a8Sspeer mac_register_t macreg; /* resource's mac_reg */ 116678453a8Sspeer vio_net_res_type_t type; /* resource type */ 117678453a8Sspeer ether_addr_t local_macaddr; /* resource's macaddr */ 118678453a8Sspeer ether_addr_t rem_macaddr; /* resource's remote macaddr */ 1195460ddbdSSriharsha Basavapatna vnet_flags_t flags; /* resource flags */ 120c1c61f44Ssb155480 uint32_t refcnt; /* reference count */ 121678453a8Sspeer struct vnet *vnetp; /* back pointer to vnet */ 1226ab6cb20SWENTAO YANG kstat_t *ksp; /* hio kstats */ 12363f531d1SSriharsha Basavapatna void *rx_ringp; /* assoc pseudo rx ring */ 124678453a8Sspeer } vnet_res_t; 125678453a8Sspeer 126678453a8Sspeer #define VNET_DDS_TASK_ADD_SHARE 0x01 127678453a8Sspeer #define VNET_DDS_TASK_DEL_SHARE 0x02 128678453a8Sspeer #define VNET_DDS_TASK_REL_SHARE 0x04 129678453a8Sspeer 130678453a8Sspeer /* An instance specific DDS structure */ 131678453a8Sspeer typedef struct vnet_dds_info { 132678453a8Sspeer kmutex_t lock; /* lock for this structure */ 133678453a8Sspeer uint8_t task_flags; /* flags for taskq */ 134678453a8Sspeer uint8_t dds_req_id; /* DDS message request id */ 135678453a8Sspeer vio_dds_msg_t dmsg; /* Pending DDS message */ 136678453a8Sspeer dev_info_t *hio_dip; /* Hybrid device's dip */ 137678453a8Sspeer uint64_t hio_cookie; /* Hybrid device's cookie */ 13863f531d1SSriharsha Basavapatna char hio_ifname[LIFNAMSIZ]; /* Hybrid interface name */ 139678453a8Sspeer ddi_taskq_t *dds_taskqp; /* Taskq's used for DDS */ 140678453a8Sspeer struct vnet *vnetp; /* Back pointer to vnetp */ 141678453a8Sspeer } vnet_dds_info_t; 1421ae08745Sheppo 143c1c61f44Ssb155480 #define VNET_NFDB_HASH 64 1441ae08745Sheppo 145c1c61f44Ssb155480 #define KEY_HASH(key, addr) \ 146678453a8Sspeer (key = (((uint64_t)(addr[0])) << 40) | \ 147678453a8Sspeer (((uint64_t)(addr[1])) << 32) | \ 148678453a8Sspeer (((uint64_t)(addr[2])) << 24) | \ 149678453a8Sspeer (((uint64_t)(addr[3])) << 16) | \ 150678453a8Sspeer (((uint64_t)(addr[4])) << 8) | \ 151678453a8Sspeer ((uint64_t)(addr[5]))); 152678453a8Sspeer 1531ae08745Sheppo 1541ae08745Sheppo /* rwlock macros */ 1551ae08745Sheppo #define READ_ENTER(x) rw_enter(x, RW_READER) 1561ae08745Sheppo #define WRITE_ENTER(x) rw_enter(x, RW_WRITER) 1571ae08745Sheppo #define RW_EXIT(x) rw_exit(x) 1581ae08745Sheppo 159c1c61f44Ssb155480 #define VLAN_ID_KEY(key) ((mod_hash_key_t)(uintptr_t)(key)) 160c1c61f44Ssb155480 1616f09f0feSWENTAO YANG typedef enum { 1626f09f0feSWENTAO YANG AST_init = 0x0, AST_vnet_alloc = 0x1, 16363f531d1SSriharsha Basavapatna AST_ring_init = 0x2, AST_vdds_init = 0x4, 16463f531d1SSriharsha Basavapatna AST_read_macaddr = 0x8, AST_fdbh_alloc = 0x10, 16563f531d1SSriharsha Basavapatna AST_taskq_create = 0x20, AST_vnet_list = 0x40, 16663f531d1SSriharsha Basavapatna AST_vgen_init = 0x80, AST_macreg = 0x100, 16763f531d1SSriharsha Basavapatna AST_init_mdeg = 0x200 1686f09f0feSWENTAO YANG } vnet_attach_progress_t; 1696f09f0feSWENTAO YANG 17063f531d1SSriharsha Basavapatna #define VNET_NUM_PSEUDO_GROUPS 1 /* # of pseudo ring grps */ 17163f531d1SSriharsha Basavapatna #define VNET_NUM_HYBRID_RINGS 2 /* # of Hybrid tx/rx rings */ 17263f531d1SSriharsha Basavapatna #define VNET_HYBRID_RXRING_INDEX 1 /* Hybrid rx ring start index */ 17363f531d1SSriharsha Basavapatna 17463f531d1SSriharsha Basavapatna /* 17563f531d1SSriharsha Basavapatna * # of Pseudo TX Rings is defined based on the possible 17663f531d1SSriharsha Basavapatna * # of TX Hardware Rings from a Hybrid resource. 17763f531d1SSriharsha Basavapatna */ 17863f531d1SSriharsha Basavapatna #define VNET_NUM_PSEUDO_TXRINGS VNET_NUM_HYBRID_RINGS 17963f531d1SSriharsha Basavapatna 18063f531d1SSriharsha Basavapatna /* 18163f531d1SSriharsha Basavapatna * # of Pseudo RX Rings that are reserved and exposed by default. 18263f531d1SSriharsha Basavapatna * 1 for LDC resource to vsw + 2 for RX rings of Hybrid resource. 18363f531d1SSriharsha Basavapatna */ 18463f531d1SSriharsha Basavapatna #define VNET_NUM_PSEUDO_RXRINGS_DEFAULT (VNET_NUM_HYBRID_RINGS + 1) 18563f531d1SSriharsha Basavapatna 18663f531d1SSriharsha Basavapatna /* Pseudo RX Ring States */ 18763f531d1SSriharsha Basavapatna typedef enum { 18863f531d1SSriharsha Basavapatna VNET_RXRING_FREE = 0x0, /* Free */ 18963f531d1SSriharsha Basavapatna VNET_RXRING_INUSE = 0x1, /* In use */ 19063f531d1SSriharsha Basavapatna VNET_RXRING_LDC_SERVICE = 0x2, /* Mapped to vswitch */ 19163f531d1SSriharsha Basavapatna VNET_RXRING_LDC_GUEST = 0x4, /* Mapped to a peer vnet */ 19263f531d1SSriharsha Basavapatna VNET_RXRING_HYBRID = 0x8, /* Mapped to Hybrid resource */ 19363f531d1SSriharsha Basavapatna VNET_RXRING_STARTED = 0x10 /* Started */ 19463f531d1SSriharsha Basavapatna } vnet_rxring_state_t; 19563f531d1SSriharsha Basavapatna 19663f531d1SSriharsha Basavapatna /* Pseudo TX Ring States */ 19763f531d1SSriharsha Basavapatna typedef enum { 19863f531d1SSriharsha Basavapatna VNET_TXRING_FREE = 0x0, /* Free */ 19963f531d1SSriharsha Basavapatna VNET_TXRING_INUSE = 0x1, /* In use */ 20063f531d1SSriharsha Basavapatna VNET_TXRING_SHARED = 0x2, /* Shared among LDCs */ 20163f531d1SSriharsha Basavapatna VNET_TXRING_HYBRID = 0x4, /* Shared among LDCs, Hybrid resource */ 20263f531d1SSriharsha Basavapatna VNET_TXRING_STARTED = 0x8 /* Started */ 20363f531d1SSriharsha Basavapatna } vnet_txring_state_t; 20463f531d1SSriharsha Basavapatna 20563f531d1SSriharsha Basavapatna /* 20663f531d1SSriharsha Basavapatna * Psuedo TX Ring 20763f531d1SSriharsha Basavapatna */ 20863f531d1SSriharsha Basavapatna typedef struct vnet_pseudo_tx_ring { 20963f531d1SSriharsha Basavapatna uint_t index; /* ring index */ 21063f531d1SSriharsha Basavapatna vnet_txring_state_t state; /* ring state */ 21163f531d1SSriharsha Basavapatna void *grp; /* grp associated */ 21263f531d1SSriharsha Basavapatna void *vnetp; /* vnet associated */ 21363f531d1SSriharsha Basavapatna mac_ring_handle_t handle; /* ring handle in mac layer */ 21463f531d1SSriharsha Basavapatna mac_ring_handle_t hw_rh; /* Resource type dependent, internal */ 21563f531d1SSriharsha Basavapatna /* ring handle. Hybrid res: ring hdl */ 21663f531d1SSriharsha Basavapatna /* of hardware rx ring; LDC res: hdl */ 21763f531d1SSriharsha Basavapatna /* to the res itself (vnet_res_t) */ 2180dc2366fSVenugopal Iyer boolean_t woken_up; 2190dc2366fSVenugopal Iyer vnet_tx_ring_stats_t tx_ring_stats; /* ring statistics */ 22063f531d1SSriharsha Basavapatna } vnet_pseudo_tx_ring_t; 22163f531d1SSriharsha Basavapatna 22263f531d1SSriharsha Basavapatna /* 22363f531d1SSriharsha Basavapatna * Psuedo RX Ring 22463f531d1SSriharsha Basavapatna */ 22563f531d1SSriharsha Basavapatna typedef struct vnet_pseudo_rx_ring { 22663f531d1SSriharsha Basavapatna uint_t index; /* ring index */ 22763f531d1SSriharsha Basavapatna vnet_rxring_state_t state; /* ring state */ 22863f531d1SSriharsha Basavapatna void *grp; /* grp associated */ 22963f531d1SSriharsha Basavapatna void *vnetp; /* vnet associated */ 23063f531d1SSriharsha Basavapatna mac_ring_handle_t handle; /* ring handle in mac layer */ 23163f531d1SSriharsha Basavapatna mac_ring_handle_t hw_rh; /* Resource type dependent, internal */ 23263f531d1SSriharsha Basavapatna /* ring handle. Hybrid res: ring hdl */ 23363f531d1SSriharsha Basavapatna /* of hardware tx ring; otherwise */ 23463f531d1SSriharsha Basavapatna /* NULL */ 23563f531d1SSriharsha Basavapatna uint64_t gen_num; /* Mac layer gen_num */ 23663f531d1SSriharsha Basavapatna } vnet_pseudo_rx_ring_t; 23763f531d1SSriharsha Basavapatna 23863f531d1SSriharsha Basavapatna /* 23963f531d1SSriharsha Basavapatna * Psuedo TX Ring Group 24063f531d1SSriharsha Basavapatna */ 24163f531d1SSriharsha Basavapatna typedef struct vnet_pseudo_tx_group { 24263f531d1SSriharsha Basavapatna uint_t index; /* group index */ 24363f531d1SSriharsha Basavapatna void *vnetp; /* vnet associated */ 24463f531d1SSriharsha Basavapatna mac_group_handle_t handle; /* grp handle in mac layer */ 24563f531d1SSriharsha Basavapatna uint_t ring_cnt; /* total # of rings in grp */ 24663f531d1SSriharsha Basavapatna vnet_pseudo_tx_ring_t *rings; /* array of rings */ 2470dc2366fSVenugopal Iyer kmutex_t flowctl_lock; /* flow control lock */ 2480dc2366fSVenugopal Iyer kcondvar_t flowctl_cv; 2490dc2366fSVenugopal Iyer kthread_t *flowctl_thread; 2500dc2366fSVenugopal Iyer boolean_t flowctl_done; 2510dc2366fSVenugopal Iyer void *tx_notify_handle; /* Tx ring notification */ 25263f531d1SSriharsha Basavapatna } vnet_pseudo_tx_group_t; 25363f531d1SSriharsha Basavapatna 25463f531d1SSriharsha Basavapatna /* 25563f531d1SSriharsha Basavapatna * Psuedo RX Ring Group 25663f531d1SSriharsha Basavapatna */ 25763f531d1SSriharsha Basavapatna typedef struct vnet_pseudo_rx_group { 25863f531d1SSriharsha Basavapatna krwlock_t lock; /* sync rings access in grp */ 25963f531d1SSriharsha Basavapatna int index; /* group index */ 26063f531d1SSriharsha Basavapatna void *vnetp; /* vnet this grp belongs to */ 26163f531d1SSriharsha Basavapatna mac_group_handle_t handle; /* grp handle in mac layer */ 26263f531d1SSriharsha Basavapatna uint_t max_ring_cnt; /* total # of rings in grp */ 26363f531d1SSriharsha Basavapatna uint_t ring_cnt; /* # of rings in use */ 26463f531d1SSriharsha Basavapatna vnet_pseudo_rx_ring_t *rings; /* array of rings */ 26563f531d1SSriharsha Basavapatna } vnet_pseudo_rx_group_t; 26663f531d1SSriharsha Basavapatna 2671ae08745Sheppo /* 2681ae08745Sheppo * vnet instance state information 2691ae08745Sheppo */ 2701ae08745Sheppo typedef struct vnet { 2711ae08745Sheppo int instance; /* instance # */ 2721ae08745Sheppo dev_info_t *dip; /* dev_info */ 273678453a8Sspeer uint64_t reg; /* reg prop value */ 2746f09f0feSWENTAO YANG vnet_attach_progress_t attach_progress; /* attach progress flags */ 2751ae08745Sheppo struct vnet *nextp; /* next in list */ 276ba2e4443Sseb mac_handle_t mh; /* handle to GLDv3 mac module */ 2771ae08745Sheppo uchar_t vendor_addr[ETHERADDRL]; /* orig macadr */ 2781ae08745Sheppo uchar_t curr_macaddr[ETHERADDRL]; /* current macadr */ 279678453a8Sspeer void *vgenhdl; /* Handle for vgen */ 280c1c61f44Ssb155480 281c1c61f44Ssb155480 uint32_t fdb_nchains; /* # of hash chains in fdbtbl */ 282c1c61f44Ssb155480 mod_hash_t *fdb_hashp; /* forwarding database */ 283678453a8Sspeer vnet_res_t *vsw_fp; /* cached fdb entry of vsw */ 284c1c61f44Ssb155480 krwlock_t vsw_fp_rw; /* lock to protect vsw_fp */ 2857b1f684aSSriharsha Basavapatna uint32_t mtu; /* mtu of the device */ 286c1c61f44Ssb155480 287c1c61f44Ssb155480 uint16_t default_vlan_id; /* default vlan id */ 288c1c61f44Ssb155480 uint16_t pvid; /* port vlan id (untagged) */ 289c1c61f44Ssb155480 uint16_t *vids; /* vlan ids (tagged) */ 290c1c61f44Ssb155480 uint16_t nvids; /* # of vids */ 291678453a8Sspeer 2921107ea93SSriharsha Basavapatna link_state_t link_state; /* link status */ 2931107ea93SSriharsha Basavapatna boolean_t pls_update; /* phys link state update ? */ 2945460ddbdSSriharsha Basavapatna vnet_flags_t flags; /* interface flags */ 295678453a8Sspeer vnet_res_t *hio_fp; /* Hybrid IO resource */ 296678453a8Sspeer vnet_res_t *vres_list; /* Resource list */ 297678453a8Sspeer vnet_dds_info_t vdds_info; /* DDS related info */ 298678453a8Sspeer krwlock_t vrwlock; /* Resource list lock */ 299678453a8Sspeer ddi_taskq_t *taskqp; /* Resource taskq */ 30063f531d1SSriharsha Basavapatna 30163f531d1SSriharsha Basavapatna /* pseudo ring groups */ 30263f531d1SSriharsha Basavapatna vnet_pseudo_rx_group_t rx_grp[VNET_NUM_PSEUDO_GROUPS]; 30363f531d1SSriharsha Basavapatna vnet_pseudo_tx_group_t tx_grp[VNET_NUM_PSEUDO_GROUPS]; 30463f531d1SSriharsha Basavapatna 30563f531d1SSriharsha Basavapatna vio_net_handle_t hio_vhp; /* HIO resource hdl */ 30663f531d1SSriharsha Basavapatna mac_handle_t hio_mh; /* HIO mac hdl */ 30763f531d1SSriharsha Basavapatna mac_client_handle_t hio_mch; /* HIO mac client hdl */ 30863f531d1SSriharsha Basavapatna mac_unicast_handle_t hio_muh; /* HIO mac unicst hdl */ 30963f531d1SSriharsha Basavapatna mac_group_handle_t rx_hwgh; /* HIO rx ring-group hdl */ 31063f531d1SSriharsha Basavapatna mac_group_handle_t tx_hwgh; /* HIO tx ring-group hdl */ 3111ae08745Sheppo } vnet_t; 3121ae08745Sheppo 313844e62a3Sraghuram #ifdef DEBUG 314844e62a3Sraghuram /* 315844e62a3Sraghuram * debug levels: 316844e62a3Sraghuram * DBG_LEVEL1: Function entry/exit tracing 317844e62a3Sraghuram * DBG_LEVEL2: Info messages 318844e62a3Sraghuram * DBG_LEVEL3: Warning messages 319844e62a3Sraghuram * DBG_LEVEL4: Error messages 320844e62a3Sraghuram */ 321844e62a3Sraghuram 322844e62a3Sraghuram enum { DBG_LEVEL1 = 0x01, DBG_LEVEL2 = 0x02, DBG_WARN = 0x04, 323844e62a3Sraghuram DBG_ERR = 0x08 }; 324844e62a3Sraghuram 325844e62a3Sraghuram #define DBG1(...) do { \ 326844e62a3Sraghuram if ((vnet_dbglevel & DBG_LEVEL1) != 0) { \ 327*7bd3a2e2SSriharsha Basavapatna DEBUG_PRINTF(__func__, __VA_ARGS__); \ 328844e62a3Sraghuram } \ 329844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 330844e62a3Sraghuram 331844e62a3Sraghuram #define DBG2(...) do { \ 332844e62a3Sraghuram if ((vnet_dbglevel & DBG_LEVEL2) != 0) { \ 333*7bd3a2e2SSriharsha Basavapatna DEBUG_PRINTF(__func__, __VA_ARGS__); \ 334844e62a3Sraghuram } \ 335844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 336844e62a3Sraghuram 337844e62a3Sraghuram #define DWARN(...) do { \ 338844e62a3Sraghuram if ((vnet_dbglevel & DBG_WARN) != 0) { \ 339*7bd3a2e2SSriharsha Basavapatna DEBUG_PRINTF(__func__, __VA_ARGS__); \ 340844e62a3Sraghuram } \ 341844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 342844e62a3Sraghuram 343844e62a3Sraghuram #define DERR(...) do { \ 344844e62a3Sraghuram if ((vnet_dbglevel & DBG_ERR) != 0) { \ 345*7bd3a2e2SSriharsha Basavapatna DEBUG_PRINTF(__func__, __VA_ARGS__); \ 346844e62a3Sraghuram } \ 347844e62a3Sraghuram _NOTE(CONSTCOND) } while (0) 348844e62a3Sraghuram 349844e62a3Sraghuram #else 350844e62a3Sraghuram 351844e62a3Sraghuram #define DBG1(...) if (0) do { } while (0) 352844e62a3Sraghuram #define DBG2(...) if (0) do { } while (0) 353844e62a3Sraghuram #define DWARN(...) if (0) do { } while (0) 354844e62a3Sraghuram #define DERR(...) if (0) do { } while (0) 355844e62a3Sraghuram 356844e62a3Sraghuram #endif 357844e62a3Sraghuram 3581107ea93SSriharsha Basavapatna #ifdef VNET_IOC_DEBUG /* Debug ioctls */ 3591107ea93SSriharsha Basavapatna 3601107ea93SSriharsha Basavapatna #define VNET_FORCE_LINK_DOWN 0x1 3611107ea93SSriharsha Basavapatna #define VNET_FORCE_LINK_UP 0x2 3621107ea93SSriharsha Basavapatna 3631107ea93SSriharsha Basavapatna #endif 3641107ea93SSriharsha Basavapatna 3651ae08745Sheppo #ifdef __cplusplus 3661ae08745Sheppo } 3671ae08745Sheppo #endif 3681ae08745Sheppo 3691ae08745Sheppo #endif /* _VNET_H */ 370