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 /*
  23  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  24  * Use is subject to license terms.
  25  */
  26 
  27 #ifndef _SYS_XNF_H
  28 #define _SYS_XNF_H
  29 
  30 #ifdef __cplusplus
  31 extern "C" {
  32 #endif
  33 
  34 #define NET_TX_RING_SIZE  __CONST_RING_SIZE(netif_tx, PAGESIZE)
  35 #define NET_RX_RING_SIZE  __CONST_RING_SIZE(netif_rx, PAGESIZE)
  36 
  37 #define XNF_MAXPKT      1500            /* MTU size */
  38 #define XNF_FRAMESIZE   1514            /* frame size including MAC header */
  39 
  40 /* DEBUG flags */
  41 #define XNF_DEBUG_DDI           0x01
  42 #define XNF_DEBUG_TRACE         0x02
  43 
  44 /*
  45  * Information about each receive buffer and any transmit look-aside
  46  * buffers.
  47  */
  48 typedef struct xnf_buf {
  49         frtn_t                  free_rtn;
  50         struct xnf              *xnfp;
  51         ddi_dma_handle_t        dma_handle;
  52         caddr_t                 buf;            /* DMA-able data buffer */
  53         paddr_t                 buf_phys;
  54         mfn_t                   buf_mfn;
  55         size_t                  len;
  56         struct xnf_buf          *next;  /* For linking into free list */
  57         ddi_acc_handle_t        acc_handle;
  58         grant_ref_t             grant_ref;      /* grant table reference */
  59         uint16_t                id;             /* buffer id */
  60         unsigned int            gen;
  61 } xnf_buf_t;
  62 
  63 /*
  64  * Information about each transmit buffer.
  65  */
  66 typedef struct xnf_txbuf {
  67         struct xnf_txbuf        *tx_next;
  68         mblk_t                  *tx_mp; /* mblk associated with packet */
  69         netif_tx_request_t      tx_txreq;
  70         caddr_t                 tx_bufp;
  71         ddi_dma_handle_t        tx_dma_handle;
  72         mfn_t                   tx_mfn;
  73         xnf_buf_t               *tx_bdesc; /* Look-aside buffer, if used. */
  74         unsigned char           tx_type;
  75         int16_t                 tx_status;
  76         RING_IDX                tx_slot;
  77 
  78 #define TX_DATA         1
  79 #define TX_MCAST_REQ    2
  80 #define TX_MCAST_RSP    3
  81 } xnf_txbuf_t;
  82 
  83 /*
  84  * Information about each outstanding transmit operation.
  85  */
  86 typedef struct xnf_txid {
  87         uint16_t        id;     /* Id of this transmit buffer. */
  88         uint16_t        next;   /* Freelist of ids. */
  89         xnf_txbuf_t     *txbuf; /* Buffer details. */
  90 } xnf_txid_t;
  91 
  92 /*
  93  * Per-instance data.
  94  */
  95 typedef struct xnf {
  96         /* most interesting stuff first to assist debugging */
  97         dev_info_t              *xnf_devinfo;
  98         mac_handle_t            xnf_mh;
  99         unsigned char           xnf_mac_addr[ETHERADDRL];
 100 
 101         unsigned int            xnf_gen;        /* Increments on resume. */
 102 
 103         boolean_t               xnf_connected;
 104         boolean_t               xnf_running;
 105 
 106         boolean_t               xnf_be_rx_copy;
 107         boolean_t               xnf_be_mcast_control;
 108 
 109         uint64_t                xnf_stat_interrupts;
 110         uint64_t                xnf_stat_unclaimed_interrupts;
 111         uint64_t                xnf_stat_norxbuf;
 112         uint64_t                xnf_stat_drop;
 113         uint64_t                xnf_stat_errrx;
 114 
 115         uint64_t                xnf_stat_tx_attempt;
 116         uint64_t                xnf_stat_tx_pullup;
 117         uint64_t                xnf_stat_tx_pagebndry;
 118         uint64_t                xnf_stat_tx_defer;
 119         uint64_t                xnf_stat_mac_rcv_error;
 120         uint64_t                xnf_stat_runt;
 121 
 122         uint64_t                xnf_stat_ipackets;
 123         uint64_t                xnf_stat_opackets;
 124         uint64_t                xnf_stat_rbytes;
 125         uint64_t                xnf_stat_obytes;
 126 
 127         uint64_t                xnf_stat_tx_cksum_deferred;
 128         uint64_t                xnf_stat_rx_cksum_no_need;
 129 
 130         uint64_t                xnf_stat_buf_allocated;
 131         uint64_t                xnf_stat_buf_outstanding;
 132         uint64_t                xnf_stat_gref_outstanding;
 133         uint64_t                xnf_stat_gref_failure;
 134         uint64_t                xnf_stat_gref_peak;
 135         uint64_t                xnf_stat_rx_allocb_fail;
 136         uint64_t                xnf_stat_rx_desballoc_fail;
 137 
 138         kstat_t                 *xnf_kstat_aux;
 139 
 140         ddi_iblock_cookie_t     xnf_icookie;
 141 
 142         netif_tx_front_ring_t   xnf_tx_ring;
 143         ddi_dma_handle_t        xnf_tx_ring_dma_handle;
 144         ddi_acc_handle_t        xnf_tx_ring_dma_acchandle;
 145         paddr_t                 xnf_tx_ring_phys_addr;
 146         grant_ref_t             xnf_tx_ring_ref;
 147 
 148         xnf_txid_t              xnf_tx_pkt_id[NET_TX_RING_SIZE];
 149         uint16_t                xnf_tx_pkt_id_head;
 150         kmutex_t                xnf_txlock;
 151         kmutex_t                xnf_schedlock;
 152         boolean_t               xnf_need_sched;
 153         kcondvar_t              xnf_cv_tx_slots;
 154         kmem_cache_t            *xnf_tx_buf_cache;
 155 
 156         netif_rx_front_ring_t   xnf_rx_ring;
 157         ddi_dma_handle_t        xnf_rx_ring_dma_handle;
 158         ddi_acc_handle_t        xnf_rx_ring_dma_acchandle;
 159         paddr_t                 xnf_rx_ring_phys_addr;
 160         grant_ref_t             xnf_rx_ring_ref;
 161 
 162         xnf_buf_t               *xnf_rx_pkt_info[NET_RX_RING_SIZE];
 163         kmutex_t                xnf_rxlock;
 164         mblk_t                  *xnf_rx_head;
 165         mblk_t                  *xnf_rx_tail;
 166         boolean_t               xnf_rx_new_buffers_posted;
 167         kmem_cache_t            *xnf_buf_cache;
 168 
 169         uint16_t                xnf_evtchn;
 170 
 171         kmutex_t                xnf_gref_lock;
 172         grant_ref_t             xnf_gref_head;
 173 
 174         kcondvar_t              xnf_cv_state;
 175         kcondvar_t              xnf_cv_multicast;
 176         uint_t                  xnf_pending_multicast;
 177 } xnf_t;
 178 
 179 #ifdef __cplusplus
 180 }
 181 #endif
 182 
 183 #endif  /* _SYS_XNF_H */