summaryrefslogtreecommitdiff
path: root/sys/dev/pci/if_bnx.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci/if_bnx.c')
-rw-r--r--sys/dev/pci/if_bnx.c183
1 files changed, 84 insertions, 99 deletions
diff --git a/sys/dev/pci/if_bnx.c b/sys/dev/pci/if_bnx.c
index a370c93d54a..366619de82c 100644
--- a/sys/dev/pci/if_bnx.c
+++ b/sys/dev/pci/if_bnx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bnx.c,v 1.8 2006/08/13 06:39:58 brad Exp $ */
+/* $OpenBSD: if_bnx.c,v 1.9 2006/08/13 19:29:46 marco Exp $ */
/*-
* Copyright (c) 2006 Broadcom Corporation
@@ -1889,7 +1889,7 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
struct tx_bd *txbd = NULL;
int i = 0, nseg;
u_int16_t prod, chain_prod;
- u_int32_t prod_bseq;
+ u_int32_t prod_bseq, addr;
#ifdef BNX_DEBUG
u_int16_t debug_prod;
#endif
@@ -1933,8 +1933,10 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
txbd = &map_arg->tx_chain[TX_PAGE(chain_prod)][TX_IDX(chain_prod)];
/* Setup the first tx_bd for the first segment. */
- txbd->tx_bd_haddr_lo = htole32(BNX_ADDR_LO(map->dm_segs[i].ds_addr));
- txbd->tx_bd_haddr_hi = htole32(BNX_ADDR_HI(map->dm_segs[i].ds_addr));
+ addr = (u_int32_t)(map->dm_segs[i].ds_addr);
+ txbd->tx_bd_haddr_lo = htole32(addr);
+ addr = (u_int32_t)((u_int64_t)map->dm_segs[i].ds_addr >> 32);
+ txbd->tx_bd_haddr_hi = htole32(addr);
txbd->tx_bd_mss_nbytes = htole16(map->dm_segs[i].ds_len);
txbd->tx_bd_vlan_tag_flags = htole16(map_arg->tx_flags |
TX_BD_FLAGS_START);
@@ -1947,8 +1949,10 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
txbd = &map_arg->tx_chain[TX_PAGE(chain_prod)][TX_IDX(chain_prod)];
- txbd->tx_bd_haddr_lo = htole32(BNX_ADDR_LO(map->dm_segs[i].ds_addr));
- txbd->tx_bd_haddr_hi = htole32(BNX_ADDR_HI(map->dm_segs[i].ds_addr));
+ addr = (u_int32_t)(map->dm_segs[i].ds_addr);
+ txbd->tx_bd_haddr_lo = htole32(addr);
+ addr = (u_int32_t)((u_int64_t)map->dm_segs[i].ds_addr >> 32);
+ txbd->tx_bd_haddr_hi = htole32(addr);
txbd->tx_bd_mss_nbytes = htole16(map->dm_segs[i].ds_len);
txbd->tx_bd_vlan_tag_flags = htole16(map_arg->tx_flags);
@@ -2973,15 +2977,15 @@ bnx_blockinit(struct bnx_softc *sc)
/* Program the physical address of the status block. */
REG_WR(sc, BNX_HC_STATUS_ADDR_L,
- BNX_ADDR_LO(sc->status_block_paddr));
+ (u_int32_t)(sc->status_block_paddr));
REG_WR(sc, BNX_HC_STATUS_ADDR_H,
- BNX_ADDR_HI(sc->status_block_paddr));
+ (u_int32_t)((u_int64_t)sc->status_block_paddr >> 32));
/* Program the physical address of the statistics block. */
REG_WR(sc, BNX_HC_STATISTICS_ADDR_L,
- BNX_ADDR_LO(sc->stats_block_paddr));
+ (u_int32_t)(sc->stats_block_paddr));
REG_WR(sc, BNX_HC_STATISTICS_ADDR_H,
- BNX_ADDR_HI(sc->stats_block_paddr));
+ (u_int32_t)((u_int64_t)sc->stats_block_paddr >> 32));
/* Program various host coalescing parameters. */
REG_WR(sc, BNX_HC_TX_QUICK_CONS_TRIP,
@@ -3068,12 +3072,13 @@ int
bnx_get_buf(struct bnx_softc *sc, struct mbuf *m, u_int16_t *prod, u_int16_t *chain_prod,
u_int32_t *prod_bseq)
{
- bus_dmamap_t map;
- struct mbuf *m_new = NULL;
- struct rx_bd *rxbd;
- int i, rc = 0;
+ bus_dmamap_t map;
+ struct mbuf *m_new = NULL;
+ struct rx_bd *rxbd;
+ int i, rc = 0;
+ u_int32_t addr;
#ifdef BNX_DEBUG
- u_int16_t debug_chain_prod = *chain_prod;
+ u_int16_t debug_chain_prod = *chain_prod;
#endif
DBPRINT(sc, (BNX_VERBOSE_RESET | BNX_VERBOSE_RECV), "Entering %s()\n",
@@ -3160,8 +3165,10 @@ bnx_get_buf(struct bnx_softc *sc, struct mbuf *m, u_int16_t *prod, u_int16_t *ch
/* Setup the rx_bd for the first segment. */
rxbd = &sc->rx_bd_chain[RX_PAGE(*chain_prod)][RX_IDX(*chain_prod)];
- rxbd->rx_bd_haddr_lo = htole32(BNX_ADDR_LO(map->dm_segs[0].ds_addr));
- rxbd->rx_bd_haddr_hi = htole32(BNX_ADDR_HI(map->dm_segs[0].ds_addr));
+ addr = (u_int32_t)(map->dm_segs[0].ds_addr);
+ rxbd->rx_bd_haddr_lo = htole32(addr);
+ addr = (u_int32_t)((u_int64_t)map->dm_segs[0].ds_addr >> 32);
+ rxbd->rx_bd_haddr_hi = htole32(addr);
rxbd->rx_bd_len = htole32(map->dm_segs[0].ds_len);
rxbd->rx_bd_flags = htole32(RX_BD_FLAGS_START);
*prod_bseq += map->dm_segs[0].ds_len;
@@ -3173,8 +3180,10 @@ bnx_get_buf(struct bnx_softc *sc, struct mbuf *m, u_int16_t *prod, u_int16_t *ch
rxbd = &sc->rx_bd_chain[RX_PAGE(*chain_prod)][RX_IDX(*chain_prod)];
- rxbd->rx_bd_haddr_lo = htole32(BNX_ADDR_LO(map->dm_segs[i].ds_addr));
- rxbd->rx_bd_haddr_hi = htole32(BNX_ADDR_HI(map->dm_segs[i].ds_addr));
+ addr = (u_int32_t)(map->dm_segs[i].ds_addr);
+ rxbd->rx_bd_haddr_lo = htole32(addr);
+ addr = (u_int32_t)((u_int64_t)map->dm_segs[i].ds_addr >> 32);
+ rxbd->rx_bd_haddr_hi = htole32(addr);
rxbd->rx_bd_len = htole32(map->dm_segs[i].ds_len);
rxbd->rx_bd_flags = 0;
*prod_bseq += map->dm_segs[i].ds_len;
@@ -3209,7 +3218,7 @@ int
bnx_init_tx_chain(struct bnx_softc *sc)
{
struct tx_bd *txbd;
- u_int32_t val;
+ u_int32_t val, addr;
int i, rc = 0;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -3243,8 +3252,10 @@ bnx_init_tx_chain(struct bnx_softc *sc)
else
j = i + 1;
- txbd->tx_bd_haddr_hi = htole32(BNX_ADDR_HI(sc->tx_bd_chain_paddr[j]));
- txbd->tx_bd_haddr_lo = htole32(BNX_ADDR_LO(sc->tx_bd_chain_paddr[j]));
+ addr = (u_int32_t)(sc->tx_bd_chain_paddr[j]);
+ txbd->tx_bd_haddr_lo = htole32(addr);
+ addr = (u_int32_t)((u_int64_t)sc->tx_bd_chain_paddr[j] >> 32);
+ txbd->tx_bd_haddr_hi = htole32(addr);
}
/*
@@ -3258,9 +3269,9 @@ bnx_init_tx_chain(struct bnx_softc *sc)
CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_CMD_TYPE, val);
/* Point the hardware to the first page in the chain. */
- val = BNX_ADDR_HI(sc->tx_bd_chain_paddr[0]);
+ val = (u_int32_t)((u_int64_t)sc->tx_bd_chain_paddr[0] >> 32);
CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TBDR_BHADDR_HI, val);
- val = BNX_ADDR_LO(sc->tx_bd_chain_paddr[0]);
+ val = (u_int32_t)(sc->tx_bd_chain_paddr[0]);
CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TBDR_BHADDR_LO, val);
DBRUN(BNX_VERBOSE_SEND, bnx_dump_tx_chain(sc, 0, TOTAL_TX_BD));
@@ -3322,7 +3333,7 @@ bnx_init_rx_chain(struct bnx_softc *sc)
struct rx_bd *rxbd;
int i, rc = 0;
u_int16_t prod, chain_prod;
- u_int32_t prod_bseq, val;
+ u_int32_t prod_bseq, val, addr;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -3346,8 +3357,10 @@ bnx_init_rx_chain(struct bnx_softc *sc)
j = i + 1;
/* Setup the chain page pointers. */
- rxbd->rx_bd_haddr_hi = htole32(BNX_ADDR_HI(sc->rx_bd_chain_paddr[j]));
- rxbd->rx_bd_haddr_lo = htole32(BNX_ADDR_LO(sc->rx_bd_chain_paddr[j]));
+ addr = (u_int32_t)((u_int64_t)sc->rx_bd_chain_paddr[j] >> 32);
+ rxbd->rx_bd_haddr_hi = htole32(addr);
+ addr = (u_int32_t)(sc->rx_bd_chain_paddr[j]);
+ rxbd->rx_bd_haddr_lo = htole32(addr);
}
/* Initialize the context ID for an L2 RX chain. */
@@ -3357,9 +3370,9 @@ bnx_init_rx_chain(struct bnx_softc *sc)
CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_CTX_TYPE, val);
/* Point the hardware to the first page in the chain. */
- val = BNX_ADDR_HI(sc->rx_bd_chain_paddr[0]);
+ val = (u_int32_t)((u_int64_t)sc->rx_bd_chain_paddr[0] >> 32);
CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_NX_BDHADDR_HI, val);
- val = BNX_ADDR_LO(sc->rx_bd_chain_paddr[0]);
+ val = (u_int32_t)(sc->rx_bd_chain_paddr[0]);
CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_NX_BDHADDR_LO, val);
/* Allocate mbuf clusters for the rx_bd chain. */
@@ -4835,7 +4848,6 @@ bnx_tick_locked_exit:
void
bnx_dump_mbuf(struct bnx_softc *sc, struct mbuf *m)
{
- u_int32_t val_hi, val_lo;
struct mbuf *mp = m;
if (m == NULL) {
@@ -4845,10 +4857,8 @@ bnx_dump_mbuf(struct bnx_softc *sc, struct mbuf *m)
}
while (mp) {
- val_hi = BNX_ADDR_HI(mp);
- val_lo = BNX_ADDR_LO(mp);
- printf("mbuf: vaddr = 0x%08X:%08X, m_len = %d, m_flags = ",
- val_hi, val_lo, mp->m_len);
+ printf("mbuf: vaddr = %p, m_len = %d, m_flags = ",
+ mp, mp->m_len);
if (mp->m_flags & M_EXT)
printf("M_EXT ");
@@ -4856,12 +4866,9 @@ bnx_dump_mbuf(struct bnx_softc *sc, struct mbuf *m)
printf("M_PKTHDR ");
printf("\n");
- if (mp->m_flags & M_EXT) {
- val_hi = BNX_ADDR_HI(mp->m_ext.ext_buf);
- val_lo = BNX_ADDR_LO(mp->m_ext.ext_buf);
- printf("- m_ext: vaddr = 0x%08X:%08X, ext_size = 0x%04X\n",
- val_hi, val_lo, mp->m_ext.ext_size);
- }
+ if (mp->m_flags & M_EXT)
+ printf("- m_ext: vaddr = %p, ext_size = 0x%04X\n",
+ mp, mp->m_ext.ext_size);
mp = mp->m_next;
}
@@ -5371,110 +5378,88 @@ bnx_dump_stats_block(struct bnx_softc *sc)
void
bnx_dump_driver_state(struct bnx_softc *sc)
{
- u_int32_t val_hi, val_lo;
-
BNX_PRINTF(sc,
- "-----------------------------"
- " Driver State "
- "-----------------------------\n");
+ "-----------------------------"
+ " Driver State "
+ "-----------------------------\n");
- val_hi = BNX_ADDR_HI(sc);
- val_lo = BNX_ADDR_LO(sc);
- BNX_PRINTF(sc, "0x%08X:%08X - (sc) driver softc structure virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc) driver softc structure virtual "
+ "address\n", sc);
- val_hi = BNX_ADDR_HI(sc->status_block);
- val_lo = BNX_ADDR_LO(sc->status_block);
- BNX_PRINTF(sc, "0x%08X:%08X - (sc->status_block) status block virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->status_block) status block virtual address\n",
+ sc->status_block);
- val_hi = BNX_ADDR_HI(sc->stats_block);
- val_lo = BNX_ADDR_LO(sc->stats_block);
- BNX_PRINTF(sc, "0x%08X:%08X - (sc->stats_block) statistics block virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->stats_block) statistics block virtual "
+ "address\n", sc->stats_block);
- val_hi = BNX_ADDR_HI(sc->tx_bd_chain);
- val_lo = BNX_ADDR_LO(sc->tx_bd_chain);
- BNX_PRINTF(sc,
- "0x%08X:%08X - (sc->tx_bd_chain) tx_bd chain virtual adddress\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->tx_bd_chain) tx_bd chain virtual "
+ "adddress\n", sc->tx_bd_chain);
- val_hi = BNX_ADDR_HI(sc->rx_bd_chain);
- val_lo = BNX_ADDR_LO(sc->rx_bd_chain);
- BNX_PRINTF(sc,
- "0x%08X:%08X - (sc->rx_bd_chain) rx_bd chain virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->rx_bd_chain) rx_bd chain virtual address\n",
+ sc->rx_bd_chain);
- val_hi = BNX_ADDR_HI(sc->tx_mbuf_ptr);
- val_lo = BNX_ADDR_LO(sc->tx_mbuf_ptr);
- BNX_PRINTF(sc,
- "0x%08X:%08X - (sc->tx_mbuf_ptr) tx mbuf chain virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->tx_mbuf_ptr) tx mbuf chain virtual address\n",
+ sc->tx_mbuf_ptr);
- val_hi = BNX_ADDR_HI(sc->rx_mbuf_ptr);
- val_lo = BNX_ADDR_LO(sc->rx_mbuf_ptr);
- BNX_PRINTF(sc,
- "0x%08X:%08X - (sc->rx_mbuf_ptr) rx mbuf chain virtual address\n",
- val_hi, val_lo);
+ BNX_PRINTF(sc, "%p - (sc->rx_mbuf_ptr) rx mbuf chain virtual address\n",
+ sc->rx_mbuf_ptr);
BNX_PRINTF(sc, " 0x%08X - (sc->interrupts_generated) h/w intrs\n",
- sc->interrupts_generated);
+ sc->interrupts_generated);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_interrupts) rx interrupts handled\n",
- sc->rx_interrupts);
+ sc->rx_interrupts);
BNX_PRINTF(sc, " 0x%08X - (sc->tx_interrupts) tx interrupts handled\n",
- sc->tx_interrupts);
+ sc->tx_interrupts);
BNX_PRINTF(sc, " 0x%08X - (sc->last_status_idx) status block index\n",
- sc->last_status_idx);
+ sc->last_status_idx);
BNX_PRINTF(sc, " 0x%08X - (sc->tx_prod) tx producer index\n",
- sc->tx_prod);
+ sc->tx_prod);
BNX_PRINTF(sc, " 0x%08X - (sc->tx_cons) tx consumer index\n",
- sc->tx_cons);
+ sc->tx_cons);
BNX_PRINTF(sc, " 0x%08X - (sc->tx_prod_bseq) tx producer bseq index\n",
- sc->tx_prod_bseq);
+ sc->tx_prod_bseq);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_prod) rx producer index\n",
- sc->rx_prod);
+ sc->rx_prod);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_cons) rx consumer index\n",
- sc->rx_cons);
+ sc->rx_cons);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_prod_bseq) rx producer bseq index\n",
- sc->rx_prod_bseq);
+ sc->rx_prod_bseq);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_mbuf_alloc) rx mbufs allocated\n",
- sc->rx_mbuf_alloc);
+ sc->rx_mbuf_alloc);
BNX_PRINTF(sc, " 0x%08X - (sc->free_rx_bd) free rx_bd's\n",
- sc->free_rx_bd);
+ sc->free_rx_bd);
BNX_PRINTF(sc, "0x%08X/%08X - (sc->rx_low_watermark) rx low watermark\n",
- sc->rx_low_watermark, (u_int32_t) USABLE_RX_BD);
+ sc->rx_low_watermark, (u_int32_t) USABLE_RX_BD);
BNX_PRINTF(sc, " 0x%08X - (sc->txmbuf_alloc) tx mbufs allocated\n",
- sc->tx_mbuf_alloc);
+ sc->tx_mbuf_alloc);
BNX_PRINTF(sc, " 0x%08X - (sc->rx_mbuf_alloc) rx mbufs allocated\n",
- sc->rx_mbuf_alloc);
+ sc->rx_mbuf_alloc);
BNX_PRINTF(sc, " 0x%08X - (sc->used_tx_bd) used tx_bd's\n",
- sc->used_tx_bd);
+ sc->used_tx_bd);
BNX_PRINTF(sc, "0x%08X/%08X - (sc->tx_hi_watermark) tx hi watermark\n",
- sc->tx_hi_watermark, (u_int32_t) USABLE_TX_BD);
+ sc->tx_hi_watermark, (u_int32_t) USABLE_TX_BD);
BNX_PRINTF(sc, " 0x%08X - (sc->mbuf_alloc_failed) failed mbuf alloc\n",
- sc->mbuf_alloc_failed);
+ sc->mbuf_alloc_failed);
- BNX_PRINTF(sc,
- "-----------------------------"
- "--------------"
- "-----------------------------\n");
+ BNX_PRINTF(sc, "-------------------------------------------"
+ "-----------------------------\n");
}
void