2007-03-14 02:37:44 +00:00
|
|
|
/**************************************************************************
|
|
|
|
|
|
|
|
Copyright (c) 2007, Chelsio Inc.
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
|
|
|
|
1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
this list of conditions and the following disclaimer.
|
|
|
|
|
2007-05-25 09:48:20 +00:00
|
|
|
2. Neither the name of the Chelsio Corporation nor the names of its
|
2007-03-14 02:37:44 +00:00
|
|
|
contributors may be used to endorse or promote products derived from
|
|
|
|
this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
|
|
|
|
$FreeBSD$
|
|
|
|
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _CXGB_ADAPTER_H_
|
|
|
|
#define _CXGB_ADAPTER_H_
|
|
|
|
|
|
|
|
#include <sys/lock.h>
|
|
|
|
#include <sys/mutex.h>
|
2007-06-17 04:33:38 +00:00
|
|
|
#include <sys/sx.h>
|
2007-03-14 02:37:44 +00:00
|
|
|
#include <sys/rman.h>
|
|
|
|
#include <sys/mbuf.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <sys/sockio.h>
|
2007-12-17 08:17:51 +00:00
|
|
|
#include <sys/condvar.h>
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
#include <net/ethernet.h>
|
|
|
|
#include <net/if.h>
|
|
|
|
#include <net/if_media.h>
|
|
|
|
|
|
|
|
#include <machine/bus.h>
|
|
|
|
#include <machine/resource.h>
|
2007-12-17 08:17:51 +00:00
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
#include <sys/bus_dma.h>
|
|
|
|
#include <dev/pci/pcireg.h>
|
|
|
|
#include <dev/pci/pcivar.h>
|
|
|
|
|
2007-05-28 22:57:27 +00:00
|
|
|
#ifdef CONFIG_DEFINED
|
2007-06-13 05:36:00 +00:00
|
|
|
#include <cxgb_osdep.h>
|
2007-12-15 21:54:59 +00:00
|
|
|
#include <t3cdev.h>
|
|
|
|
#include <ulp/toecore/cxgb_toedev.h>
|
2007-12-17 08:17:51 +00:00
|
|
|
#include <sys/mbufq.h>
|
2007-05-28 22:57:27 +00:00
|
|
|
#else
|
2007-06-13 05:36:00 +00:00
|
|
|
#include <dev/cxgb/cxgb_osdep.h>
|
2007-12-15 21:54:59 +00:00
|
|
|
#include <dev/cxgb/t3cdev.h>
|
2007-06-13 05:36:00 +00:00
|
|
|
#include <dev/cxgb/sys/mbufq.h>
|
2007-12-15 21:54:59 +00:00
|
|
|
#include <dev/cxgb/ulp/toecore/cxgb_toedev.h>
|
2007-05-28 22:57:27 +00:00
|
|
|
#endif
|
2007-05-25 09:48:20 +00:00
|
|
|
|
2007-06-17 04:33:38 +00:00
|
|
|
#define USE_SX
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct adapter;
|
|
|
|
struct sge_qset;
|
|
|
|
extern int cxgb_debug;
|
|
|
|
|
2007-06-17 04:33:38 +00:00
|
|
|
#ifdef DEBUG_LOCKING
|
|
|
|
#define MTX_INIT(lock, lockname, class, flags) \
|
|
|
|
do { \
|
|
|
|
printf("initializing %s at %s:%d\n", lockname, __FILE__, __LINE__); \
|
|
|
|
mtx_init((lock), lockname, class, flags); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define MTX_DESTROY(lock) \
|
|
|
|
do { \
|
|
|
|
printf("destroying %s at %s:%d\n", (lock)->lock_object.lo_name, __FILE__, __LINE__); \
|
|
|
|
mtx_destroy((lock)); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define SX_INIT(lock, lockname) \
|
|
|
|
do { \
|
|
|
|
printf("initializing %s at %s:%d\n", lockname, __FILE__, __LINE__); \
|
|
|
|
sx_init((lock), lockname); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define SX_DESTROY(lock) \
|
|
|
|
do { \
|
|
|
|
printf("destroying %s at %s:%d\n", (lock)->lock_object.lo_name, __FILE__, __LINE__); \
|
|
|
|
sx_destroy((lock)); \
|
|
|
|
} while (0)
|
|
|
|
#else
|
|
|
|
#define MTX_INIT mtx_init
|
|
|
|
#define MTX_DESTROY mtx_destroy
|
|
|
|
#define SX_INIT sx_init
|
|
|
|
#define SX_DESTROY sx_destroy
|
|
|
|
#endif
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct port_info {
|
|
|
|
struct adapter *adapter;
|
|
|
|
struct ifnet *ifp;
|
|
|
|
int if_flags;
|
|
|
|
const struct port_type_info *port_type;
|
|
|
|
struct cphy phy;
|
|
|
|
struct cmac mac;
|
|
|
|
struct link_config link_config;
|
2007-06-17 04:33:38 +00:00
|
|
|
struct ifmedia media;
|
|
|
|
#ifdef USE_SX
|
|
|
|
struct sx lock;
|
|
|
|
#else
|
2007-03-14 02:37:44 +00:00
|
|
|
struct mtx lock;
|
2007-06-17 04:33:38 +00:00
|
|
|
#endif
|
2007-08-25 21:07:37 +00:00
|
|
|
uint8_t port_id;
|
|
|
|
uint8_t tx_chan;
|
|
|
|
uint8_t txpkt_intf;
|
2007-03-14 02:37:44 +00:00
|
|
|
uint8_t first_qset;
|
2008-01-09 08:12:24 +00:00
|
|
|
uint32_t nqsets;
|
2007-08-25 21:07:37 +00:00
|
|
|
|
|
|
|
uint8_t hw_addr[ETHER_ADDR_LEN];
|
2007-03-14 02:37:44 +00:00
|
|
|
struct taskqueue *tq;
|
|
|
|
struct task start_task;
|
2007-06-13 05:36:00 +00:00
|
|
|
struct task timer_reclaim_task;
|
2007-03-14 02:37:44 +00:00
|
|
|
struct cdev *port_cdev;
|
2007-06-17 04:33:38 +00:00
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
#define PORT_LOCK_NAME_LEN 32
|
2007-06-17 04:33:38 +00:00
|
|
|
#define TASKQ_NAME_LEN 32
|
2007-12-17 08:17:51 +00:00
|
|
|
#define PORT_NAME_LEN 32
|
|
|
|
char lockbuf[PORT_LOCK_NAME_LEN];
|
2007-06-17 04:33:38 +00:00
|
|
|
char taskqbuf[TASKQ_NAME_LEN];
|
2007-12-17 08:17:51 +00:00
|
|
|
char namebuf[PORT_NAME_LEN];
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum { /* adapter flags */
|
|
|
|
FULL_INIT_DONE = (1 << 0),
|
|
|
|
USING_MSI = (1 << 1),
|
|
|
|
USING_MSIX = (1 << 2),
|
|
|
|
QUEUES_BOUND = (1 << 3),
|
|
|
|
FW_UPTODATE = (1 << 4),
|
2007-07-17 06:50:35 +00:00
|
|
|
TPS_UPTODATE = (1 << 5),
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#define FL_Q_SIZE 4096
|
2007-12-17 08:17:51 +00:00
|
|
|
#define JUMBO_Q_SIZE 1024
|
2007-03-14 02:37:44 +00:00
|
|
|
#define RSPQ_Q_SIZE 1024
|
|
|
|
#define TX_ETH_Q_SIZE 1024
|
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
enum { TXQ_ETH = 0,
|
|
|
|
TXQ_OFLD = 1,
|
|
|
|
TXQ_CTRL = 2, };
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* careful, the following are set on priv_flags and must not collide with
|
|
|
|
* IFF_ flags!
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
LRO_ACTIVE = (1 << 8),
|
|
|
|
};
|
|
|
|
|
2007-05-25 09:48:20 +00:00
|
|
|
/* Max concurrent LRO sessions per queue set */
|
|
|
|
#define MAX_LRO_SES 8
|
|
|
|
|
|
|
|
struct t3_lro_session {
|
|
|
|
struct mbuf *head;
|
|
|
|
struct mbuf *tail;
|
2007-03-14 02:37:44 +00:00
|
|
|
uint32_t seq;
|
|
|
|
uint16_t ip_len;
|
2007-09-09 01:28:03 +00:00
|
|
|
uint16_t mss;
|
2007-05-25 09:48:20 +00:00
|
|
|
uint16_t vtag;
|
|
|
|
uint8_t npkts;
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
2007-05-25 09:48:20 +00:00
|
|
|
struct lro_state {
|
|
|
|
unsigned short enabled;
|
|
|
|
unsigned short active_idx;
|
|
|
|
unsigned int nactive;
|
|
|
|
struct t3_lro_session sess[MAX_LRO_SES];
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#define RX_BUNDLE_SIZE 8
|
|
|
|
|
|
|
|
struct rsp_desc;
|
|
|
|
|
|
|
|
struct sge_rspq {
|
|
|
|
uint32_t credits;
|
|
|
|
uint32_t size;
|
|
|
|
uint32_t cidx;
|
|
|
|
uint32_t gen;
|
|
|
|
uint32_t polling;
|
|
|
|
uint32_t holdoff_tmr;
|
|
|
|
uint32_t next_holdoff;
|
|
|
|
uint32_t imm_data;
|
|
|
|
struct rsp_desc *desc;
|
|
|
|
uint32_t cntxt_id;
|
2007-05-25 09:48:20 +00:00
|
|
|
struct mtx lock;
|
|
|
|
struct mbuf *rx_head; /* offload packet receive queue head */
|
|
|
|
struct mbuf *rx_tail; /* offload packet receive queue tail */
|
|
|
|
|
|
|
|
uint32_t offload_pkts;
|
|
|
|
uint32_t offload_bundles;
|
|
|
|
uint32_t pure_rsps;
|
|
|
|
uint32_t unhandled_irqs;
|
|
|
|
|
|
|
|
bus_addr_t phys_addr;
|
2007-03-14 02:37:44 +00:00
|
|
|
bus_dma_tag_t desc_tag;
|
|
|
|
bus_dmamap_t desc_map;
|
2007-09-09 04:34:03 +00:00
|
|
|
|
|
|
|
struct t3_mbuf_hdr rspq_mh;
|
2007-06-17 04:33:38 +00:00
|
|
|
#define RSPQ_NAME_LEN 32
|
|
|
|
char lockbuf[RSPQ_NAME_LEN];
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
2007-09-09 04:34:03 +00:00
|
|
|
#ifndef DISABLE_MBUF_IOVEC
|
|
|
|
#define rspq_mbuf rspq_mh.mh_head
|
|
|
|
#endif
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct rx_desc;
|
|
|
|
struct rx_sw_desc;
|
|
|
|
|
|
|
|
struct sge_fl {
|
|
|
|
uint32_t buf_size;
|
|
|
|
uint32_t credits;
|
|
|
|
uint32_t size;
|
|
|
|
uint32_t cidx;
|
|
|
|
uint32_t pidx;
|
|
|
|
uint32_t gen;
|
|
|
|
struct rx_desc *desc;
|
|
|
|
struct rx_sw_desc *sdesc;
|
|
|
|
bus_addr_t phys_addr;
|
|
|
|
uint32_t cntxt_id;
|
|
|
|
uint64_t empty;
|
|
|
|
bus_dma_tag_t desc_tag;
|
|
|
|
bus_dmamap_t desc_map;
|
2007-04-04 05:29:18 +00:00
|
|
|
bus_dma_tag_t entry_tag;
|
|
|
|
uma_zone_t zone;
|
|
|
|
int type;
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct tx_desc;
|
|
|
|
struct tx_sw_desc;
|
|
|
|
|
2007-07-17 06:50:35 +00:00
|
|
|
#define TXQ_TRANSMITTING 0x1
|
2007-07-10 06:01:45 +00:00
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct sge_txq {
|
|
|
|
uint64_t flags;
|
|
|
|
uint32_t in_use;
|
|
|
|
uint32_t size;
|
|
|
|
uint32_t processed;
|
|
|
|
uint32_t cleaned;
|
|
|
|
uint32_t stop_thres;
|
|
|
|
uint32_t cidx;
|
|
|
|
uint32_t pidx;
|
|
|
|
uint32_t gen;
|
|
|
|
uint32_t unacked;
|
|
|
|
struct tx_desc *desc;
|
|
|
|
struct tx_sw_desc *sdesc;
|
|
|
|
uint32_t token;
|
|
|
|
bus_addr_t phys_addr;
|
2007-07-10 06:01:45 +00:00
|
|
|
struct task qresume_task;
|
|
|
|
struct task qreclaim_task;
|
|
|
|
struct port_info *port;
|
2007-03-14 02:37:44 +00:00
|
|
|
uint32_t cntxt_id;
|
|
|
|
uint64_t stops;
|
|
|
|
uint64_t restarts;
|
|
|
|
bus_dma_tag_t desc_tag;
|
|
|
|
bus_dmamap_t desc_map;
|
2007-04-04 05:29:18 +00:00
|
|
|
bus_dma_tag_t entry_tag;
|
2007-05-25 09:48:20 +00:00
|
|
|
struct mbuf_head sendq;
|
2007-12-17 08:17:51 +00:00
|
|
|
/*
|
|
|
|
* cleanq should really be an buf_ring to avoid extra
|
|
|
|
* mbuf touches
|
|
|
|
*/
|
|
|
|
struct mbuf_head cleanq;
|
|
|
|
struct buf_ring txq_mr;
|
|
|
|
struct mbuf *immpkt;
|
|
|
|
uint32_t txq_drops;
|
|
|
|
uint32_t txq_skipped;
|
|
|
|
uint32_t txq_coalesced;
|
|
|
|
uint32_t txq_enqueued;
|
2008-01-09 08:12:24 +00:00
|
|
|
uint32_t txq_dump_start;
|
|
|
|
uint32_t txq_dump_count;
|
2007-12-17 08:17:51 +00:00
|
|
|
unsigned long txq_frees;
|
2007-03-14 02:37:44 +00:00
|
|
|
struct mtx lock;
|
2007-12-17 08:17:51 +00:00
|
|
|
struct sg_ent txq_sgl[TX_MAX_SEGS / 2 + 1];
|
|
|
|
bus_dma_segment_t txq_segs[TX_MAX_SEGS];
|
|
|
|
struct mbuf *txq_m_vec[TX_WR_COUNT_MAX];
|
2007-06-17 04:33:38 +00:00
|
|
|
#define TXQ_NAME_LEN 32
|
|
|
|
char lockbuf[TXQ_NAME_LEN];
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
enum {
|
|
|
|
SGE_PSTAT_TSO, /* # of TSO requests */
|
|
|
|
SGE_PSTAT_RX_CSUM_GOOD, /* # of successful RX csum offloads */
|
|
|
|
SGE_PSTAT_TX_CSUM, /* # of TX checksum offloads */
|
|
|
|
SGE_PSTAT_VLANEX, /* # of VLAN tag extractions */
|
|
|
|
SGE_PSTAT_VLANINS, /* # of VLAN tag insertions */
|
|
|
|
SGE_PSTATS_LRO_QUEUED, /* # of LRO appended packets */
|
|
|
|
SGE_PSTATS_LRO_FLUSHED, /* # of LRO flushed packets */
|
|
|
|
SGE_PSTATS_LRO_X_STREAMS, /* # of exceeded LRO contexts */
|
|
|
|
};
|
|
|
|
|
|
|
|
#define SGE_PSTAT_MAX (SGE_PSTATS_LRO_X_STREAMS+1)
|
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
#define QS_EXITING 0x1
|
|
|
|
#define QS_RUNNING 0x2
|
|
|
|
#define QS_BOUND 0x4
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct sge_qset {
|
|
|
|
struct sge_rspq rspq;
|
|
|
|
struct sge_fl fl[SGE_RXQ_PER_SET];
|
2007-05-25 09:48:20 +00:00
|
|
|
struct lro_state lro;
|
2007-03-14 02:37:44 +00:00
|
|
|
struct sge_txq txq[SGE_TXQ_PER_SET];
|
2007-05-25 09:48:20 +00:00
|
|
|
uint32_t txq_stopped; /* which Tx queues are stopped */
|
2007-03-14 02:37:44 +00:00
|
|
|
uint64_t port_stats[SGE_PSTAT_MAX];
|
|
|
|
struct port_info *port;
|
2007-03-21 07:25:40 +00:00
|
|
|
int idx; /* qset # */
|
2007-12-17 08:17:51 +00:00
|
|
|
int qs_cpuid;
|
|
|
|
int qs_flags;
|
|
|
|
struct cv qs_cv;
|
|
|
|
struct mtx qs_mtx;
|
|
|
|
#define QS_NAME_LEN 32
|
|
|
|
char namebuf[QS_NAME_LEN];
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct sge {
|
|
|
|
struct sge_qset qs[SGE_QSETS];
|
|
|
|
struct mtx reg_lock;
|
|
|
|
};
|
|
|
|
|
2007-07-17 06:50:35 +00:00
|
|
|
struct filter_info;
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
struct adapter {
|
|
|
|
device_t dev;
|
|
|
|
int flags;
|
2007-05-25 09:48:20 +00:00
|
|
|
TAILQ_ENTRY(adapter) adapter_entry;
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
/* PCI register resources */
|
2007-08-17 05:57:04 +00:00
|
|
|
int regs_rid;
|
2007-03-14 02:37:44 +00:00
|
|
|
struct resource *regs_res;
|
|
|
|
bus_space_handle_t bh;
|
|
|
|
bus_space_tag_t bt;
|
|
|
|
bus_size_t mmio_len;
|
2007-03-24 04:28:33 +00:00
|
|
|
uint32_t link_width;
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
/* DMA resources */
|
|
|
|
bus_dma_tag_t parent_dmat;
|
|
|
|
bus_dma_tag_t rx_dmat;
|
|
|
|
bus_dma_tag_t rx_jumbo_dmat;
|
|
|
|
bus_dma_tag_t tx_dmat;
|
|
|
|
|
|
|
|
/* Interrupt resources */
|
|
|
|
struct resource *irq_res;
|
|
|
|
int irq_rid;
|
|
|
|
void *intr_tag;
|
|
|
|
|
|
|
|
uint32_t msix_regs_rid;
|
|
|
|
struct resource *msix_regs_res;
|
|
|
|
|
|
|
|
struct resource *msix_irq_res[SGE_QSETS];
|
|
|
|
int msix_irq_rid[SGE_QSETS];
|
|
|
|
void *msix_intr_tag[SGE_QSETS];
|
2007-07-17 06:50:35 +00:00
|
|
|
uint8_t rxpkt_map[8]; /* maps RX_PKT interface values to port ids */
|
|
|
|
uint8_t rrss_map[SGE_QSETS]; /* revers RSS map table */
|
2007-12-17 08:17:51 +00:00
|
|
|
uint16_t rspq_map[RSS_TABLE_SIZE]; /* maps 7-bit cookie to qidx */
|
|
|
|
union {
|
|
|
|
uint8_t fill[SGE_QSETS];
|
|
|
|
uint64_t coalesce;
|
|
|
|
} u;
|
|
|
|
|
|
|
|
#define tunq_fill u.fill
|
|
|
|
#define tunq_coalesce u.coalesce
|
|
|
|
|
2007-07-17 06:50:35 +00:00
|
|
|
struct filter_info *filters;
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
/* Tasks */
|
|
|
|
struct task ext_intr_task;
|
|
|
|
struct task slow_intr_task;
|
2007-06-17 04:33:38 +00:00
|
|
|
struct task tick_task;
|
2007-03-14 02:37:44 +00:00
|
|
|
struct task process_responses_task;
|
|
|
|
struct taskqueue *tq;
|
|
|
|
struct callout cxgb_tick_ch;
|
|
|
|
struct callout sge_timer_ch;
|
|
|
|
|
|
|
|
/* Register lock for use by the hardware layer */
|
|
|
|
struct mtx mdio_lock;
|
2007-06-13 05:36:00 +00:00
|
|
|
struct mtx elmer_lock;
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
/* Bookkeeping for the hardware layer */
|
|
|
|
struct adapter_params params;
|
|
|
|
unsigned int slow_intr_mask;
|
|
|
|
unsigned long irq_stats[IRQ_NUM_STATS];
|
|
|
|
|
|
|
|
struct sge sge;
|
|
|
|
struct mc7 pmrx;
|
|
|
|
struct mc7 pmtx;
|
|
|
|
struct mc7 cm;
|
|
|
|
struct mc5 mc5;
|
|
|
|
|
|
|
|
struct port_info port[MAX_NPORTS];
|
|
|
|
device_t portdev[MAX_NPORTS];
|
2007-12-15 21:54:59 +00:00
|
|
|
struct t3cdev tdev;
|
2007-03-14 02:37:44 +00:00
|
|
|
char fw_version[64];
|
|
|
|
uint32_t open_device_map;
|
2007-05-25 09:48:20 +00:00
|
|
|
uint32_t registered_device_map;
|
2007-06-17 04:33:38 +00:00
|
|
|
#ifdef USE_SX
|
|
|
|
struct sx lock;
|
|
|
|
#else
|
2007-03-14 02:37:44 +00:00
|
|
|
struct mtx lock;
|
2007-06-17 04:33:38 +00:00
|
|
|
#endif
|
2007-05-25 09:48:20 +00:00
|
|
|
driver_intr_t *cxgb_intr;
|
|
|
|
int msi_count;
|
2007-06-17 04:33:38 +00:00
|
|
|
|
|
|
|
#define ADAPTER_LOCK_NAME_LEN 32
|
|
|
|
char lockbuf[ADAPTER_LOCK_NAME_LEN];
|
|
|
|
char reglockbuf[ADAPTER_LOCK_NAME_LEN];
|
|
|
|
char mdiolockbuf[ADAPTER_LOCK_NAME_LEN];
|
|
|
|
char elmerlockbuf[ADAPTER_LOCK_NAME_LEN];
|
2007-03-14 02:37:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct t3_rx_mode {
|
|
|
|
|
|
|
|
uint32_t idx;
|
|
|
|
struct port_info *port;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#define MDIO_LOCK(adapter) mtx_lock(&(adapter)->mdio_lock)
|
|
|
|
#define MDIO_UNLOCK(adapter) mtx_unlock(&(adapter)->mdio_lock)
|
2007-06-13 05:36:00 +00:00
|
|
|
#define ELMR_LOCK(adapter) mtx_lock(&(adapter)->elmer_lock)
|
|
|
|
#define ELMR_UNLOCK(adapter) mtx_unlock(&(adapter)->elmer_lock)
|
2007-03-14 02:37:44 +00:00
|
|
|
|
2007-06-17 04:33:38 +00:00
|
|
|
|
|
|
|
#ifdef USE_SX
|
|
|
|
#define PORT_LOCK(port) sx_xlock(&(port)->lock);
|
|
|
|
#define PORT_UNLOCK(port) sx_xunlock(&(port)->lock);
|
|
|
|
#define PORT_LOCK_INIT(port, name) SX_INIT(&(port)->lock, name)
|
|
|
|
#define PORT_LOCK_DEINIT(port) SX_DESTROY(&(port)->lock)
|
|
|
|
#define PORT_LOCK_ASSERT_OWNED(port) sx_assert(&(port)->lock, SA_LOCKED)
|
|
|
|
|
|
|
|
#define ADAPTER_LOCK(adap) sx_xlock(&(adap)->lock);
|
|
|
|
#define ADAPTER_UNLOCK(adap) sx_xunlock(&(adap)->lock);
|
|
|
|
#define ADAPTER_LOCK_INIT(adap, name) SX_INIT(&(adap)->lock, name)
|
|
|
|
#define ADAPTER_LOCK_DEINIT(adap) SX_DESTROY(&(adap)->lock)
|
|
|
|
#define ADAPTER_LOCK_ASSERT_NOTOWNED(adap) sx_assert(&(adap)->lock, SA_UNLOCKED)
|
|
|
|
#else
|
|
|
|
#define PORT_LOCK(port) mtx_lock(&(port)->lock);
|
|
|
|
#define PORT_UNLOCK(port) mtx_unlock(&(port)->lock);
|
|
|
|
#define PORT_LOCK_INIT(port, name) mtx_init(&(port)->lock, name, 0, MTX_DEF)
|
|
|
|
#define PORT_LOCK_DEINIT(port) mtx_destroy(&(port)->lock)
|
|
|
|
#define PORT_LOCK_ASSERT_OWNED(port) mtx_assert(&(port)->lock, MA_OWNED)
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
#define ADAPTER_LOCK(adap) mtx_lock(&(adap)->lock);
|
|
|
|
#define ADAPTER_UNLOCK(adap) mtx_unlock(&(adap)->lock);
|
2007-06-17 04:33:38 +00:00
|
|
|
#define ADAPTER_LOCK_INIT(adap, name) mtx_init(&(adap)->lock, name, 0, MTX_DEF)
|
|
|
|
#define ADAPTER_LOCK_DEINIT(adap) mtx_destroy(&(adap)->lock)
|
|
|
|
#define ADAPTER_LOCK_ASSERT_NOTOWNED(adap) mtx_assert(&(adap)->lock, MO_NOTOWNED)
|
|
|
|
#endif
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
static __inline uint32_t
|
|
|
|
t3_read_reg(adapter_t *adapter, uint32_t reg_addr)
|
|
|
|
{
|
|
|
|
return (bus_space_read_4(adapter->bt, adapter->bh, reg_addr));
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_write_reg(adapter_t *adapter, uint32_t reg_addr, uint32_t val)
|
|
|
|
{
|
|
|
|
bus_space_write_4(adapter->bt, adapter->bh, reg_addr, val);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_os_pci_read_config_4(adapter_t *adapter, int reg, uint32_t *val)
|
|
|
|
{
|
|
|
|
*val = pci_read_config(adapter->dev, reg, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_os_pci_write_config_4(adapter_t *adapter, int reg, uint32_t val)
|
|
|
|
{
|
|
|
|
pci_write_config(adapter->dev, reg, val, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_os_pci_read_config_2(adapter_t *adapter, int reg, uint16_t *val)
|
|
|
|
{
|
|
|
|
*val = pci_read_config(adapter->dev, reg, 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_os_pci_write_config_2(adapter_t *adapter, int reg, uint16_t val)
|
|
|
|
{
|
|
|
|
pci_write_config(adapter->dev, reg, val, 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline uint8_t *
|
|
|
|
t3_get_next_mcaddr(struct t3_rx_mode *rm)
|
|
|
|
{
|
|
|
|
uint8_t *macaddr = NULL;
|
|
|
|
|
|
|
|
if (rm->idx == 0)
|
2007-12-17 08:17:51 +00:00
|
|
|
macaddr = (uint8_t *)rm->port->hw_addr;
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
rm->idx++;
|
|
|
|
return (macaddr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
t3_init_rx_mode(struct t3_rx_mode *rm, struct port_info *port)
|
|
|
|
{
|
|
|
|
rm->idx = 0;
|
|
|
|
rm->port = port;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline struct port_info *
|
|
|
|
adap2pinfo(struct adapter *adap, int idx)
|
|
|
|
{
|
|
|
|
return &adap->port[idx];
|
|
|
|
}
|
|
|
|
|
|
|
|
int t3_os_find_pci_capability(adapter_t *adapter, int cap);
|
|
|
|
int t3_os_pci_save_state(struct adapter *adapter);
|
|
|
|
int t3_os_pci_restore_state(struct adapter *adapter);
|
|
|
|
void t3_os_link_changed(adapter_t *adapter, int port_id, int link_status,
|
|
|
|
int speed, int duplex, int fc);
|
|
|
|
void t3_sge_err_intr_handler(adapter_t *adapter);
|
2007-12-15 21:54:59 +00:00
|
|
|
int t3_offload_tx(struct t3cdev *, struct mbuf *);
|
2007-03-14 02:37:44 +00:00
|
|
|
void t3_os_ext_intr_handler(adapter_t *adapter);
|
|
|
|
void t3_os_set_hw_addr(adapter_t *adapter, int port_idx, u8 hw_addr[]);
|
|
|
|
int t3_mgmt_tx(adapter_t *adap, struct mbuf *m);
|
|
|
|
|
|
|
|
|
|
|
|
int t3_sge_alloc(struct adapter *);
|
|
|
|
int t3_sge_free(struct adapter *);
|
|
|
|
int t3_sge_alloc_qset(adapter_t *, uint32_t, int, int, const struct qset_params *,
|
|
|
|
int, struct port_info *);
|
|
|
|
void t3_free_sge_resources(adapter_t *);
|
|
|
|
void t3_sge_start(adapter_t *);
|
2007-05-25 09:48:20 +00:00
|
|
|
void t3_sge_stop(adapter_t *);
|
2007-03-14 02:37:44 +00:00
|
|
|
void t3b_intr(void *data);
|
|
|
|
void t3_intr_msi(void *data);
|
|
|
|
void t3_intr_msix(void *data);
|
2007-12-17 08:17:51 +00:00
|
|
|
int t3_encap(struct sge_qset *, struct mbuf **, int);
|
2007-03-14 02:37:44 +00:00
|
|
|
|
2007-06-13 05:36:00 +00:00
|
|
|
int t3_sge_init_adapter(adapter_t *);
|
|
|
|
int t3_sge_init_port(struct port_info *);
|
2007-03-14 02:37:44 +00:00
|
|
|
void t3_sge_deinit_sw(adapter_t *);
|
2007-12-17 08:17:51 +00:00
|
|
|
void t3_free_tx_desc(struct sge_txq *q, int n);
|
|
|
|
void t3_free_tx_desc_all(struct sge_txq *q);
|
2007-03-14 02:37:44 +00:00
|
|
|
|
2007-04-08 15:04:19 +00:00
|
|
|
void t3_rx_eth_lro(adapter_t *adap, struct sge_rspq *rq, struct mbuf *m,
|
2007-03-14 02:37:44 +00:00
|
|
|
int ethpad, uint32_t rss_hash, uint32_t rss_csum, int lro);
|
2007-08-25 21:07:37 +00:00
|
|
|
void t3_rx_eth(struct adapter *adap, struct sge_rspq *rq, struct mbuf *m, int ethpad);
|
2007-05-25 09:48:20 +00:00
|
|
|
void t3_lro_flush(adapter_t *adap, struct sge_qset *qs, struct lro_state *state);
|
2007-03-14 02:37:44 +00:00
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
void t3_add_attach_sysctls(adapter_t *sc);
|
|
|
|
void t3_add_configured_sysctls(adapter_t *sc);
|
2007-03-14 02:37:44 +00:00
|
|
|
int t3_get_desc(const struct sge_qset *qs, unsigned int qnum, unsigned int idx,
|
|
|
|
unsigned char *data);
|
|
|
|
void t3_update_qset_coalesce(struct sge_qset *qs, const struct qset_params *p);
|
|
|
|
/*
|
|
|
|
* XXX figure out how we can return this to being private to sge
|
|
|
|
*/
|
2007-03-21 07:25:40 +00:00
|
|
|
#define desc_reclaimable(q) ((int)((q)->processed - (q)->cleaned - TX_MAX_DESC))
|
2007-03-14 02:37:44 +00:00
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
#define container_of(p, stype, field) ((stype *)(((uint8_t *)(p)) - offsetof(stype, field)))
|
2007-03-14 02:37:44 +00:00
|
|
|
|
|
|
|
static __inline struct sge_qset *
|
|
|
|
fl_to_qset(struct sge_fl *q, int qidx)
|
|
|
|
{
|
|
|
|
return container_of(q, struct sge_qset, fl[qidx]);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline struct sge_qset *
|
|
|
|
rspq_to_qset(struct sge_rspq *q)
|
|
|
|
{
|
|
|
|
return container_of(q, struct sge_qset, rspq);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline struct sge_qset *
|
|
|
|
txq_to_qset(struct sge_txq *q, int qidx)
|
|
|
|
{
|
|
|
|
return container_of(q, struct sge_qset, txq[qidx]);
|
|
|
|
}
|
|
|
|
|
2007-05-25 09:48:20 +00:00
|
|
|
static __inline struct adapter *
|
2007-12-15 21:54:59 +00:00
|
|
|
tdev2adap(struct t3cdev *d)
|
2007-05-25 09:48:20 +00:00
|
|
|
{
|
|
|
|
return container_of(d, struct adapter, tdev);
|
|
|
|
}
|
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
#undef container_of
|
|
|
|
|
2007-05-25 09:48:20 +00:00
|
|
|
#define OFFLOAD_DEVMAP_BIT 15
|
|
|
|
static inline int offload_running(adapter_t *adapter)
|
|
|
|
{
|
|
|
|
return isset(&adapter->open_device_map, OFFLOAD_DEVMAP_BIT);
|
|
|
|
}
|
|
|
|
|
2007-12-17 08:17:51 +00:00
|
|
|
#ifdef IFNET_MULTIQUEUE
|
|
|
|
int cxgb_pcpu_enqueue_packet(struct ifnet *ifp, struct mbuf *m);
|
|
|
|
int cxgb_pcpu_start(struct ifnet *ifp, struct mbuf *m);
|
|
|
|
int32_t cxgb_pcpu_get_cookie(struct ifnet *ifp, struct in6_addr *lip, uint16_t lport,
|
|
|
|
struct in6_addr *rip, uint16_t rport, int ipv6);
|
|
|
|
void cxgb_pcpu_shutdown_threads(struct adapter *sc);
|
|
|
|
void cxgb_pcpu_startup_threads(struct adapter *sc);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
int process_responses(adapter_t *adap, struct sge_qset *qs, int budget);
|
|
|
|
int cxgb_tx_common(struct ifnet *ifp, struct sge_qset *qs, uint32_t txmax);
|
|
|
|
void t3_free_qset(adapter_t *sc, struct sge_qset *q);
|
|
|
|
int cxgb_dequeue_packet(struct ifnet *, struct sge_txq *, struct mbuf **);
|
|
|
|
void cxgb_start(struct ifnet *ifp);
|
|
|
|
void refill_fl_service(adapter_t *adap, struct sge_fl *fl);
|
2007-05-25 09:48:20 +00:00
|
|
|
|
2007-03-14 02:37:44 +00:00
|
|
|
#endif
|