- Added systcls for header splitting, RX/TX buffer count, interrupt

coalescing, strict RX MTU, verbose output, and shared memory debug.
- Added additional debug counters (VLAN tags and split header frames).
- Updated debug counters to 64 bit definitions.
- Updated l2fhdr bit definitions.
- Combined RX buffer sizing into a single function.
- Added buffer size and interrupt coalescing settings to adapter info
  printout.

Submitted by:	davidch
MFC after:	2 weeks
This commit is contained in:
David Christensen 2011-02-07 23:00:24 +00:00
parent 3b8227640a
commit 2306fc3f4c
2 changed files with 1116 additions and 707 deletions

File diff suppressed because it is too large Load Diff

View File

@ -1155,20 +1155,19 @@ struct tx_bd {
u32 tx_bd_haddr_lo;
u32 tx_bd_mss_nbytes;
u16 tx_bd_flags;
#define TX_BD_FLAGS_CONN_FAULT (1<<0)
#define TX_BD_FLAGS_TCP_UDP_CKSUM (1<<1)
#define TX_BD_FLAGS_IP_CKSUM (1<<2)
#define TX_BD_FLAGS_VLAN_TAG (1<<3)
#define TX_BD_FLAGS_COAL_NOW (1<<4)
#define TX_BD_FLAGS_DONT_GEN_CRC (1<<5)
#define TX_BD_FLAGS_END (1<<6)
#define TX_BD_FLAGS_START (1<<7)
#define TX_BD_FLAGS_SW_OPTION_WORD (0x1f<<8)
#define TX_BD_FLAGS_SW_FLAGS (1<<13)
#define TX_BD_FLAGS_SW_SNAP (1<<14)
#define TX_BD_FLAGS_SW_LSO (1<<15)
u16 tx_bd_vlan_tag;
#define TX_BD_FLAGS_CONN_FAULT (1<<0)
#define TX_BD_FLAGS_TCP_UDP_CKSUM (1<<1)
#define TX_BD_FLAGS_IP_CKSUM (1<<2)
#define TX_BD_FLAGS_VLAN_TAG (1<<3)
#define TX_BD_FLAGS_COAL_NOW (1<<4)
#define TX_BD_FLAGS_DONT_GEN_CRC (1<<5)
#define TX_BD_FLAGS_END (1<<6)
#define TX_BD_FLAGS_START (1<<7)
#define TX_BD_FLAGS_SW_OPTION_WORD (0x1f<<8)
#define TX_BD_FLAGS_SW_FLAGS (1<<13)
#define TX_BD_FLAGS_SW_SNAP (1<<14)
#define TX_BD_FLAGS_SW_LSO (1<<15)
};
@ -1180,11 +1179,10 @@ struct rx_bd {
u32 rx_bd_haddr_lo;
u32 rx_bd_len;
u32 rx_bd_flags;
#define RX_BD_FLAGS_NOPUSH (1<<0)
#define RX_BD_FLAGS_DUMMY (1<<1)
#define RX_BD_FLAGS_END (1<<2)
#define RX_BD_FLAGS_START (1<<3)
#define RX_BD_FLAGS_NOPUSH (1<<0)
#define RX_BD_FLAGS_DUMMY (1<<1)
#define RX_BD_FLAGS_END (1<<2)
#define RX_BD_FLAGS_START (1<<3)
};
@ -1387,6 +1385,7 @@ struct l2_fhdr {
#define L2_FHDR_ERRORS_ALIGNMENT (1<<19)
#define L2_FHDR_ERRORS_TOO_SHORT (1<<20)
#define L2_FHDR_ERRORS_GIANT_FRAME (1<<21)
#define L2_FHDR_ERRORS_IPV4_BAD_LEN (1<<22)
#define L2_FHDR_ERRORS_TCP_XSUM (1<<28)
#define L2_FHDR_ERRORS_UDP_XSUM (1<<31)
@ -1415,7 +1414,7 @@ struct l2_fhdr {
"\32b25" \
"\31b24" \
"\30b23" \
"\27b22" \
"\27IPv4_BAL_LEN" \
"\26GIANT_ERR" \
"\25SHORT_ERR" \
"\24ALIGN_ERR" \
@ -1425,16 +1424,19 @@ struct l2_fhdr {
"\20UDP" \
"\17TCP" \
"\16IP" \
"\15b12" \
"\14b11" \
"\13b10" \
"\12b09" \
"\15SORT_b3" \
"\14SORT_b2" \
"\13SORT_b1" \
"\12SORT_b0" \
"\11RSS" \
"\10SNAP" \
"\07VLAN" \
"\06P4" \
"\05P3" \
"\04P2"
"\04P2" \
"\03RULE_b2" \
"\02RULE_b1" \
"\01RULE_b0"
/*
@ -6150,18 +6152,20 @@ struct l2_fhdr {
* Page count must remain a power of 2 for all
* of the math to work correctly.
*/
#define TX_PAGES 2
#define DEFAULT_TX_PAGES 2
#define MAX_TX_PAGES 8
#define TOTAL_TX_BD_PER_PAGE (BCM_PAGE_SIZE / sizeof(struct tx_bd))
#define USABLE_TX_BD_PER_PAGE (TOTAL_TX_BD_PER_PAGE - 1)
#define TOTAL_TX_BD (TOTAL_TX_BD_PER_PAGE * TX_PAGES)
#define USABLE_TX_BD (USABLE_TX_BD_PER_PAGE * TX_PAGES)
#define MAX_TX_BD (TOTAL_TX_BD - 1)
#define MAX_TX_BD_AVAIL (MAX_TX_PAGES * TOTAL_TX_BD_PER_PAGE)
#define TOTAL_TX_BD_ALLOC (TOTAL_TX_BD_PER_PAGE * sc->tx_pages)
#define USABLE_TX_BD_ALLOC (USABLE_TX_BD_PER_PAGE * sc->tx_pages)
#define MAX_TX_BD_ALLOC (TOTAL_TX_BD_ALLOC - 1)
/* Advance to the next tx_bd, skipping any next page pointers. */
#define NEXT_TX_BD(x) (((x) & USABLE_TX_BD_PER_PAGE) == \
(USABLE_TX_BD_PER_PAGE - 1)) ? (x) + 2 : (x) + 1
#define TX_CHAIN_IDX(x) ((x) & MAX_TX_BD)
#define TX_CHAIN_IDX(x) ((x) & MAX_TX_BD_ALLOC)
#define TX_PAGE(x) (((x) & ~USABLE_TX_BD_PER_PAGE) >> (BCM_PAGE_BITS - 4))
#define TX_IDX(x) ((x) & USABLE_TX_BD_PER_PAGE)
@ -6170,45 +6174,46 @@ struct l2_fhdr {
* Page count must remain a power of 2 for all
* of the math to work correctly.
*/
#define RX_PAGES 2
#define DEFAULT_RX_PAGES 2
#define MAX_RX_PAGES 8
#define TOTAL_RX_BD_PER_PAGE (BCM_PAGE_SIZE / sizeof(struct rx_bd))
#define USABLE_RX_BD_PER_PAGE (TOTAL_RX_BD_PER_PAGE - 1)
#define TOTAL_RX_BD (TOTAL_RX_BD_PER_PAGE * RX_PAGES)
#define USABLE_RX_BD (USABLE_RX_BD_PER_PAGE * RX_PAGES)
#define MAX_RX_BD (TOTAL_RX_BD - 1)
#define MAX_RX_BD_AVAIL (MAX_RX_PAGES * TOTAL_RX_BD_PER_PAGE)
#define TOTAL_RX_BD_ALLOC (TOTAL_RX_BD_PER_PAGE * sc->rx_pages)
#define USABLE_RX_BD_ALLOC (USABLE_RX_BD_PER_PAGE * sc->rx_pages)
#define MAX_RX_BD_ALLOC (TOTAL_RX_BD_ALLOC - 1)
/* Advance to the next rx_bd, skipping any next page pointers. */
#define NEXT_RX_BD(x) (((x) & USABLE_RX_BD_PER_PAGE) == \
(USABLE_RX_BD_PER_PAGE - 1)) ? (x) + 2 : (x) + 1
#define RX_CHAIN_IDX(x) ((x) & MAX_RX_BD)
#define RX_CHAIN_IDX(x) ((x) & MAX_RX_BD_ALLOC)
#define RX_PAGE(x) (((x) & ~USABLE_RX_BD_PER_PAGE) >> (BCM_PAGE_BITS - 4))
#define RX_IDX(x) ((x) & USABLE_RX_BD_PER_PAGE)
#ifdef BCE_JUMBO_HDRSPLIT
/*
* To accomodate jumbo frames, the page chain should
* be 4 times larger than the receive chain.
*/
#define PG_PAGES (RX_PAGES * 4)
#define DEFAULT_PG_PAGES (DEFAULT_RX_PAGES * 4)
#define MAX_PG_PAGES (MAX_RX_PAGES * 4)
#define TOTAL_PG_BD_PER_PAGE (BCM_PAGE_SIZE / sizeof(struct rx_bd))
#define USABLE_PG_BD_PER_PAGE (TOTAL_PG_BD_PER_PAGE - 1)
#define TOTAL_PG_BD (TOTAL_PG_BD_PER_PAGE * PG_PAGES)
#define USABLE_PG_BD (USABLE_PG_BD_PER_PAGE * PG_PAGES)
#define MAX_PG_BD (TOTAL_PG_BD - 1)
#define MAX_PG_BD_AVAIL (MAX_PG_PAGES * TOTAL_PG_BD_PER_PAGE)
#define TOTAL_PG_BD_ALLOC (TOTAL_PG_BD_PER_PAGE * sc->pg_pages)
#define USABLE_PG_BD_ALLOC (USABLE_PG_BD_PER_PAGE * sc->pg_pages)
#define MAX_PG_BD_ALLOC (TOTAL_PG_BD_ALLOC - 1)
/* Advance to the next pg_bd, skipping any next page pointers. */
#define NEXT_PG_BD(x) (((x) & USABLE_PG_BD_PER_PAGE) == \
(USABLE_PG_BD_PER_PAGE - 1)) ? (x) + 2 : (x) + 1
#define PG_CHAIN_IDX(x) ((x) & MAX_PG_BD)
#define PG_CHAIN_IDX(x) ((x) & MAX_PG_BD_ALLOC)
#define PG_PAGE(x) (((x) & ~USABLE_PG_BD_PER_PAGE) >> (BCM_PAGE_BITS - 4))
#define PG_IDX(x) ((x) & USABLE_PG_BD_PER_PAGE)
#endif /* BCE_JUMBO_HDRSPLIT */
#define CTX_INIT_RETRY_COUNT 10
/* Context size. */
@ -6236,6 +6241,15 @@ struct l2_fhdr {
#define TX_CID 16
#define RX_CID 0
#define DEFAULT_TX_QUICK_CONS_TRIP_INT 20
#define DEFAULT_TX_QUICK_CONS_TRIP 20
#define DEFAULT_TX_TICKS_INT 80
#define DEFAULT_TX_TICKS 80
#define DEFAULT_RX_QUICK_CONS_TRIP_INT 6
#define DEFAULT_RX_QUICK_CONS_TRIP 6
#define DEFAULT_RX_TICKS_INT 18
#define DEFAULT_RX_TICKS 18
/****************************************************************************/
/* BCE Processor Firmwware Load Definitions */
/****************************************************************************/
@ -6530,22 +6544,23 @@ struct bce_softc
/* The device handle for the MII bus child device. */
device_t bce_miibus;
/* Driver maintained TX chain pointers and byte counter. */
/* Driver maintained RX chain pointers and byte counter. */
u16 rx_prod;
u16 rx_cons;
/* Counts the bytes used in the RX chain. */
u32 rx_prod_bseq;
/* Driver maintained TX chain pointers and byte counter. */
u16 tx_prod;
u16 tx_cons;
/* Counts the bytes used in the TX chain. */
u32 tx_prod_bseq;
#ifdef BCE_JUMBO_HDRSPLIT
/* Driver maintained PG chain pointers. */
u16 pg_prod;
u16 pg_cons;
#endif
int bce_link_up;
struct callout bce_tick_callout;
@ -6559,10 +6574,7 @@ struct bce_softc
int rx_bd_mbuf_alloc_size;
int rx_bd_mbuf_data_len;
int rx_bd_mbuf_align_pad;
#ifdef BCE_JUMBO_HDRSPLIT
int pg_bd_mbuf_alloc_size;
#endif
/* Receive mode settings (i.e promiscuous, multicast, etc.). */
u32 rx_mode;
@ -6571,24 +6583,25 @@ struct bce_softc
bus_dma_tag_t parent_tag;
/* H/W maintained TX buffer descriptor chain structure. */
int tx_pages;
bus_dma_tag_t tx_bd_chain_tag;
bus_dmamap_t tx_bd_chain_map[TX_PAGES];
struct tx_bd *tx_bd_chain[TX_PAGES];
bus_addr_t tx_bd_chain_paddr[TX_PAGES];
bus_dmamap_t tx_bd_chain_map[MAX_TX_PAGES];
struct tx_bd *tx_bd_chain[MAX_TX_PAGES];
bus_addr_t tx_bd_chain_paddr[MAX_TX_PAGES];
/* H/W maintained RX buffer descriptor chain structure. */
int rx_pages;
bus_dma_tag_t rx_bd_chain_tag;
bus_dmamap_t rx_bd_chain_map[RX_PAGES];
struct rx_bd *rx_bd_chain[RX_PAGES];
bus_addr_t rx_bd_chain_paddr[RX_PAGES];
bus_dmamap_t rx_bd_chain_map[MAX_RX_PAGES];
struct rx_bd *rx_bd_chain[MAX_RX_PAGES];
bus_addr_t rx_bd_chain_paddr[MAX_RX_PAGES];
#ifdef BCE_JUMBO_HDRSPLIT
/* H/W maintained page buffer descriptor chain structure. */
int pg_pages;
bus_dma_tag_t pg_bd_chain_tag;
bus_dmamap_t pg_bd_chain_map[PG_PAGES];
struct rx_bd *pg_bd_chain[PG_PAGES];
bus_addr_t pg_bd_chain_paddr[PG_PAGES];
#endif
bus_dmamap_t pg_bd_chain_map[MAX_PG_PAGES];
struct rx_bd *pg_bd_chain[MAX_PG_PAGES];
bus_addr_t pg_bd_chain_paddr[MAX_PG_PAGES];
/* H/W maintained status block. */
bus_dma_tag_t status_tag;
@ -6619,35 +6632,27 @@ struct bce_softc
/* Bus tag for RX/TX mbufs. */
bus_dma_tag_t rx_mbuf_tag;
bus_dma_tag_t tx_mbuf_tag;
#ifdef BCE_JUMBO_HDRSPLIT
bus_dma_tag_t pg_mbuf_tag;
#endif
/* S/W maintained mbuf TX chain structure. */
bus_dmamap_t tx_mbuf_map[TOTAL_TX_BD];
struct mbuf *tx_mbuf_ptr[TOTAL_TX_BD];
bus_dmamap_t tx_mbuf_map[MAX_TX_BD_AVAIL];
struct mbuf *tx_mbuf_ptr[MAX_TX_BD_AVAIL];
/* S/W maintained mbuf RX chain structure. */
bus_dmamap_t rx_mbuf_map[TOTAL_RX_BD];
struct mbuf *rx_mbuf_ptr[TOTAL_RX_BD];
bus_dmamap_t rx_mbuf_map[MAX_RX_BD_AVAIL];
struct mbuf *rx_mbuf_ptr[MAX_RX_BD_AVAIL];
#ifdef BCE_JUMBO_HDRSPLIT
/* S/W maintained mbuf page chain structure. */
bus_dmamap_t pg_mbuf_map[TOTAL_PG_BD];
struct mbuf *pg_mbuf_ptr[TOTAL_PG_BD];
#endif
bus_dmamap_t pg_mbuf_map[MAX_PG_BD_AVAIL];
struct mbuf *pg_mbuf_ptr[MAX_PG_BD_AVAIL];
/* Track the number of buffer descriptors in use. */
u16 free_rx_bd;
u16 max_rx_bd;
u16 used_tx_bd;
u16 max_tx_bd;
#ifdef BCE_JUMBO_HDRSPLIT
u16 free_pg_bd;
u16 max_pg_bd;
#endif
/* Provides access to hardware statistics through sysctl. */
u64 stat_IfHCInOctets;
@ -6733,63 +6738,61 @@ struct bce_softc
/* Track the number of enqueued mbufs. */
int debug_tx_mbuf_alloc;
int debug_rx_mbuf_alloc;
#ifdef BCE_JUMBO_HDRSPLIT
int debug_pg_mbuf_alloc;
#endif
/* Track how many and what type of interrupts are generated. */
u32 interrupts_generated;
u32 interrupts_handled;
u32 interrupts_rx;
u32 interrupts_tx;
u32 phy_interrupts;
/* Track interrupt time (25MHz clock). */
u64 rx_intr_time;
u64 tx_intr_time;
u64 interrupts_generated;
u64 interrupts_handled;
u64 interrupts_rx;
u64 interrupts_tx;
u64 phy_interrupts;
/* Lowest number of rx_bd's free. */
u32 rx_low_watermark;
u16 rx_low_watermark;
/* Number of times the RX chain was empty. */
u32 rx_empty_count;
u64 rx_empty_count;
#ifdef BCE_JUMBO_HDRSPLIT
/* Lowest number of pages free. */
u32 pg_low_watermark;
u16 pg_low_watermark;
/* Number of times the page chain was empty. */
u32 pg_empty_count;
#endif
u64 pg_empty_count;
/* Greatest number of tx_bd's used. */
u32 tx_hi_watermark;
u16 tx_hi_watermark;
/* Number of times the TX chain was full. */
u32 tx_full_count;
u64 tx_full_count;
/* Number of TSO frames requested. */
u32 tso_frames_requested;
u64 tso_frames_requested;
/* Number of TSO frames completed. */
u32 tso_frames_completed;
u64 tso_frames_completed;
/* Number of TSO frames failed. */
u32 tso_frames_failed;
u64 tso_frames_failed;
/* Number of IP checksum offload frames.*/
u32 csum_offload_ip;
u64 csum_offload_ip;
/* Number of TCP/UDP checksum offload frames.*/
u32 csum_offload_tcp_udp;
u64 csum_offload_tcp_udp;
/* Number of VLAN tagged frames received. */
u32 vlan_tagged_frames_rcvd;
u64 vlan_tagged_frames_rcvd;
/* Number of VLAN tagged frames stripped. */
u32 vlan_tagged_frames_stripped;
#endif
u64 vlan_tagged_frames_stripped;
/* Number of split header frames received. */
u64 split_header_frames_rcvd;
/* Number of split header TCP frames received. */
u64 split_header_tcp_frames_rcvd;
#endif /* BCE_DEBUG */
uint8_t *nvram_buf;
};