summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/if_bnx.c356
1 files changed, 177 insertions, 179 deletions
diff --git a/sys/dev/pci/if_bnx.c b/sys/dev/pci/if_bnx.c
index 9cbb0e83773..8ff51ee1f5a 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.12 2006/08/14 17:26:35 marco Exp $ */
+/* $OpenBSD: if_bnx.c,v 1.13 2006/08/14 18:07:46 marco Exp $ */
/*-
* Copyright (c) 2006 Broadcom Corporation
@@ -1427,17 +1427,17 @@ bnx_init_nvram(struct bnx_softc *sc)
/****************************************************************************/
int
bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
- int buf_size)
+ int buf_size)
{
- int rc = 0;
- u_int32_t cmd_flags, offset32, len32, extra;
+ int rc = 0;
+ u_int32_t cmd_flags, offset32, len32, extra;
if (buf_size == 0)
- return 0;
+ return (0);
/* Request access to the flash interface. */
if ((rc = bnx_acquire_nvram_lock(sc)) != 0)
- return rc;
+ return (rc);
/* Enable access to flash interface */
bnx_enable_nvram_access(sc);
@@ -1457,16 +1457,15 @@ bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
if (pre_len >= len32) {
pre_len = len32;
- cmd_flags = BNX_NVM_COMMAND_FIRST | BNX_NVM_COMMAND_LAST;
- }
- else {
+ cmd_flags =
+ BNX_NVM_COMMAND_FIRST | BNX_NVM_COMMAND_LAST;
+ } else
cmd_flags = BNX_NVM_COMMAND_FIRST;
- }
rc = bnx_nvram_read_dword(sc, offset32, buf, cmd_flags);
if (rc)
- return rc;
+ return (rc);
memcpy(ret_buf, buf + (offset & 3), pre_len);
@@ -1486,14 +1485,13 @@ bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
if (cmd_flags)
cmd_flags = BNX_NVM_COMMAND_LAST;
else
- cmd_flags = BNX_NVM_COMMAND_FIRST |
- BNX_NVM_COMMAND_LAST;
+ cmd_flags =
+ BNX_NVM_COMMAND_FIRST | BNX_NVM_COMMAND_LAST;
rc = bnx_nvram_read_dword(sc, offset32, buf, cmd_flags);
memcpy(ret_buf, buf, 4 - extra);
- }
- else if (len32 > 0) {
+ } else if (len32 > 0) {
u_int8_t buf[4];
/* Read the first word. */
@@ -1519,7 +1517,7 @@ bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
}
if (rc)
- return rc;
+ return (rc);
cmd_flags = BNX_NVM_COMMAND_LAST;
rc = bnx_nvram_read_dword(sc, offset32, buf, cmd_flags);
@@ -1531,7 +1529,7 @@ bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
bnx_disable_nvram_access(sc);
bnx_release_nvram_lock(sc);
- return rc;
+ return (rc);
}
#ifdef BNX_NVRAM_WRITE_SUPPORT
@@ -1547,12 +1545,12 @@ bnx_nvram_read(struct bnx_softc *sc, u_int32_t offset, u_int8_t *ret_buf,
/****************************************************************************/
int
bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
- int buf_size)
+ int buf_size)
{
- u_int32_t written, offset32, len32;
- u_int8_t *buf, start[4], end[4];
- int rc = 0;
- int align_start, align_end;
+ u_int32_t written, offset32, len32;
+ u_int8_t *buf, start[4], end[4];
+ int rc = 0;
+ int align_start, align_end;
buf = data_buf;
offset32 = offset;
@@ -1563,7 +1561,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
offset32 &= ~3;
len32 += align_start;
if ((rc = bnx_nvram_read(sc, offset32, start, 4)))
- return rc;
+ return (rc);
}
if (len32 & 3) {
@@ -1571,8 +1569,8 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
align_end = 4 - (len32 & 3);
len32 += align_end;
if ((rc = bnx_nvram_read(sc, offset32 + len32 - 4,
- end, 4))) {
- return rc;
+ end, 4))) {
+ return (rc);
}
}
}
@@ -1580,13 +1578,14 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
if (align_start || align_end) {
buf = malloc(len32, M_DEVBUF, M_NOWAIT);
if (buf == 0)
- return ENOMEM;
- if (align_start) {
+ return (ENOMEM);
+
+ if (align_start)
memcpy(buf, start, 4);
- }
- if (align_end) {
+
+ if (align_end)
memcpy(buf + len32 - 4, end, 4);
- }
+
memcpy(buf + align_start, data_buf, buf_size);
}
@@ -1606,7 +1605,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
data_start = (written == 0) ? offset32 : page_start;
/* Find the data_end addr */
data_end = (page_end > offset32 + len32) ?
- (offset32 + len32) : page_end;
+ (offset32 + len32) : page_end;
/* Request access to the flash interface. */
if ((rc = bnx_acquire_nvram_lock(sc)) != 0)
@@ -1622,9 +1621,9 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
/* Read the whole page into the buffer
* (non-buffer flash only) */
for (j = 0; j < sc->bnx_flash_info->page_size; j += 4) {
- if (j == (sc->bnx_flash_info->page_size - 4)) {
+ if (j == (sc->bnx_flash_info->page_size - 4))
cmd_flags |= BNX_NVM_COMMAND_LAST;
- }
+
rc = bnx_nvram_read_dword(sc,
page_start + j,
&flash_buffer[j],
@@ -1656,7 +1655,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
addr += 4, i += 4) {
rc = bnx_nvram_write_dword(sc, addr,
- &flash_buffer[i], cmd_flags);
+ &flash_buffer[i], cmd_flags);
if (rc != 0)
goto nvram_write_end;
@@ -1668,13 +1667,13 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
/* Loop to write the new data from data_start to data_end */
for (addr = data_start; addr < data_end; addr += 4, i++) {
if ((addr == page_end - 4) ||
- ((sc->bnx_flash_info->buffered) &&
- (addr == data_end - 4))) {
+ ((sc->bnx_flash_info->buffered) &&
+ (addr == data_end - 4))) {
cmd_flags |= BNX_NVM_COMMAND_LAST;
}
- rc = bnx_nvram_write_dword(sc, addr, buf,
- cmd_flags);
+
+ rc = bnx_nvram_write_dword(sc, addr, buf, cmd_flags);
if (rc != 0)
goto nvram_write_end;
@@ -1687,13 +1686,13 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf,
* to page_end */
if (sc->bnx_flash_info->buffered == 0) {
for (addr = data_end; addr < page_end;
- addr += 4, i += 4) {
+ addr += 4, i += 4) {
- if (addr == page_end-4) {
+ if (addr == page_end-4)
cmd_flags = BNX_NVM_COMMAND_LAST;
- }
+
rc = bnx_nvram_write_dword(sc, addr,
- &flash_buffer[i], cmd_flags);
+ &flash_buffer[i], cmd_flags);
if (rc != 0)
goto nvram_write_end;
@@ -1717,7 +1716,7 @@ nvram_write_end:
if (align_start || align_end)
free(buf, M_DEVBUF);
- return rc;
+ return (rc);
}
#endif /* BNX_NVRAM_WRITE_SUPPORT */
@@ -1733,10 +1732,10 @@ nvram_write_end:
int
bnx_nvram_test(struct bnx_softc *sc)
{
- u_int32_t buf[BNX_NVRAM_SIZE / 4];
- u_int8_t *data = (u_int8_t *) buf;
- int rc = 0;
- u_int32_t magic, csum;
+ u_int32_t buf[BNX_NVRAM_SIZE / 4];
+ u_int8_t *data = (u_int8_t *) buf;
+ int rc = 0;
+ u_int32_t magic, csum;
/*
* Check that the device NVRAM is valid by reading
@@ -1748,9 +1747,9 @@ bnx_nvram_test(struct bnx_softc *sc)
magic = bnx_be32toh(buf[0]);
if (magic != BNX_NVRAM_MAGIC) {
rc = ENODEV;
- BNX_PRINTF(sc, "%s(%d): Invalid NVRAM magic value! Expected: 0x%08X, "
- "Found: 0x%08X\n",
- __FILE__, __LINE__, BNX_NVRAM_MAGIC, magic);
+ BNX_PRINTF(sc, "%s(%d): Invalid NVRAM magic value! "
+ "Expected: 0x%08X, Found: 0x%08X\n",
+ __FILE__, __LINE__, BNX_NVRAM_MAGIC, magic);
goto bnx_nvram_test_done;
}
@@ -1764,22 +1763,22 @@ bnx_nvram_test(struct bnx_softc *sc)
csum = ether_crc32_le(data, 0x100);
if (csum != BNX_CRC32_RESIDUAL) {
rc = ENODEV;
- BNX_PRINTF(sc, "%s(%d): Invalid Manufacturing Information NVRAM CRC! "
- "Expected: 0x%08X, Found: 0x%08X\n",
- __FILE__, __LINE__, BNX_CRC32_RESIDUAL, csum);
+ BNX_PRINTF(sc, "%s(%d): Invalid Manufacturing Information "
+ "NVRAM CRC! Expected: 0x%08X, Found: 0x%08X\n",
+ __FILE__, __LINE__, BNX_CRC32_RESIDUAL, csum);
goto bnx_nvram_test_done;
}
csum = ether_crc32_le(data + 0x100, 0x100);
if (csum != BNX_CRC32_RESIDUAL) {
- BNX_PRINTF(sc, "%s(%d): Invalid Feature Configuration Information "
- "NVRAM CRC! Expected: 0x%08X, Found: 08%08X\n",
- __FILE__, __LINE__, BNX_CRC32_RESIDUAL, csum);
+ BNX_PRINTF(sc, "%s(%d): Invalid Feature Configuration "
+ "Information NVRAM CRC! Expected: 0x%08X, Found: 08%08X\n",
+ __FILE__, __LINE__, BNX_CRC32_RESIDUAL, csum);
rc = ENODEV;
}
bnx_nvram_test_done:
- return rc;
+ return (rc);
}
/****************************************************************************/
@@ -1794,7 +1793,7 @@ bnx_nvram_test_done:
void
bnx_dma_free(struct bnx_softc *sc)
{
- int i;
+ int i;
DBPRINT(sc,BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -1826,12 +1825,14 @@ bnx_dma_free(struct bnx_softc *sc)
for (i = 0; i < TX_PAGES; i++ ) {
if (sc->tx_bd_chain[i] != NULL &&
sc->tx_bd_chain_map[i] != NULL) {
- bus_dmamap_unload(sc->bnx_dmatag, sc->tx_bd_chain_map[i]);
+ bus_dmamap_unload(sc->bnx_dmatag,
+ sc->tx_bd_chain_map[i]);
bus_dmamem_unmap(sc->bnx_dmatag,
(caddr_t)sc->tx_bd_chain[i], BNX_TX_CHAIN_PAGE_SZ);
bus_dmamem_free(sc->bnx_dmatag, &sc->tx_bd_chain_seg[i],
sc->tx_bd_chain_rseg[i]);
- bus_dmamap_destroy(sc->bnx_dmatag, sc->tx_bd_chain_map[i]);
+ bus_dmamap_destroy(sc->bnx_dmatag,
+ sc->tx_bd_chain_map[i]);
sc->tx_bd_chain[i] = NULL;
sc->tx_bd_chain_map[i] = NULL;
}
@@ -1849,13 +1850,15 @@ bnx_dma_free(struct bnx_softc *sc)
for (i = 0; i < RX_PAGES; i++ ) {
if (sc->rx_bd_chain[i] != NULL &&
sc->rx_bd_chain_map[i] != NULL) {
- bus_dmamap_unload(sc->bnx_dmatag, sc->rx_bd_chain_map[i]);
+ bus_dmamap_unload(sc->bnx_dmatag,
+ sc->rx_bd_chain_map[i]);
bus_dmamem_unmap(sc->bnx_dmatag,
(caddr_t)sc->rx_bd_chain[i], BNX_RX_CHAIN_PAGE_SZ);
bus_dmamem_free(sc->bnx_dmatag, &sc->rx_bd_chain_seg[i],
sc->rx_bd_chain_rseg[i]);
- bus_dmamap_destroy(sc->bnx_dmatag, sc->rx_bd_chain_map[i]);
+ bus_dmamap_destroy(sc->bnx_dmatag,
+ sc->rx_bd_chain_map[i]);
sc->rx_bd_chain[i] = NULL;
sc->rx_bd_chain_map[i] = NULL;
}
@@ -1884,14 +1887,14 @@ bnx_dma_free(struct bnx_softc *sc)
void
bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
{
- struct bnx_dmamap_arg *map_arg;
- struct bnx_softc *sc;
- struct tx_bd *txbd = NULL;
- int i = 0, nseg;
- u_int16_t prod, chain_prod;
- u_int32_t prod_bseq, addr;
+ struct bnx_dmamap_arg *map_arg;
+ struct bnx_softc *sc;
+ struct tx_bd *txbd = NULL;
+ int i = 0, nseg;
+ u_int16_t prod, chain_prod;
+ u_int32_t prod_bseq, addr;
#ifdef BNX_DEBUG
- u_int16_t debug_prod;
+ u_int16_t debug_prod;
#endif
map_arg = arg;
@@ -1900,28 +1903,26 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
/* Signal error to caller if there's too many segments */
if (nseg > map_arg->maxsegs) {
- DBPRINT(sc, BNX_WARN,
- "%s(): Mapped TX descriptors: max segs = %d, "
- "actual segs = %d\n",
- __FUNCTION__, map_arg->maxsegs, nseg);
+ DBPRINT(sc, BNX_WARN, "%s(): Mapped TX descriptors: max segs "
+ "= %d, " "actual segs = %d\n",
+ __FUNCTION__, map_arg->maxsegs, nseg);
map_arg->maxsegs = 0;
return;
}
/* prod points to an empty tx_bd at this point. */
- prod = map_arg->prod;
+ prod = map_arg->prod;
chain_prod = map_arg->chain_prod;
- prod_bseq = map_arg->prod_bseq;
+ prod_bseq = map_arg->prod_bseq;
#ifdef BNX_DEBUG
debug_prod = chain_prod;
#endif
- DBPRINT(sc, BNX_INFO_SEND,
- "%s(): Start: prod = 0x%04X, chain_prod = %04X, "
- "prod_bseq = 0x%08X\n",
- __FUNCTION__, prod, chain_prod, prod_bseq);
+ DBPRINT(sc, BNX_INFO_SEND, "%s(): Start: prod = 0x%04X, chain_prod "
+ "= %04X, " "prod_bseq = 0x%08X\n",
+ __FUNCTION__, prod, chain_prod, prod_bseq);
/*
* Cycle through each mbuf segment that makes up
@@ -1934,26 +1935,27 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
/* Setup the first tx_bd for the first segment. */
addr = (u_int32_t)(map->dm_segs[i].ds_addr);
- txbd->tx_bd_haddr_lo = htole32(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_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);
+ TX_BD_FLAGS_START);
prod_bseq += map->dm_segs[i].ds_len;
/* Setup any remaing segments. */
for (i = 1; i < nseg; i++) {
- prod = NEXT_TX_BD(prod);
+ prod = NEXT_TX_BD(prod);
chain_prod = TX_CHAIN_IDX(prod);
- txbd = &map_arg->tx_chain[TX_PAGE(chain_prod)][TX_IDX(chain_prod)];
+ txbd =
+ &map_arg->tx_chain[TX_PAGE(chain_prod)][TX_IDX(chain_prod)];
addr = (u_int32_t)(map->dm_segs[i].ds_addr);
- txbd->tx_bd_haddr_lo = htole32(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_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);
prod_bseq += map->dm_segs[i].ds_len;
@@ -1964,16 +1966,15 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
DBRUN(BNX_INFO_SEND, bnx_dump_tx_chain(sc, debug_prod, nseg));
- DBPRINT(sc, BNX_INFO_SEND,
- "%s(): End: prod = 0x%04X, chain_prod = %04X, "
- "prod_bseq = 0x%08X\n",
- __FUNCTION__, prod, chain_prod, prod_bseq);
+ DBPRINT(sc, BNX_INFO_SEND, "%s(): End: prod = 0x%04X, chain_prod "
+ "= %04X, " "prod_bseq = 0x%08X\n",
+ __FUNCTION__, prod, chain_prod, prod_bseq);
/* prod points to the last tx_bd at this point. */
- map_arg->maxsegs = nseg;
- map_arg->prod = prod;
+ map_arg->maxsegs = nseg;
+ map_arg->prod = prod;
map_arg->chain_prod = chain_prod;
- map_arg->prod_bseq = prod_bseq;
+ map_arg->prod_bseq = prod_bseq;
}
/****************************************************************************/
@@ -1988,7 +1989,7 @@ bnx_dma_map_tx_desc(void *arg, bus_dmamap_t map)
int
bnx_dma_alloc(struct bnx_softc *sc)
{
- int i, rc = 0;
+ int i, rc = 0;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -2070,7 +2071,7 @@ bnx_dma_alloc(struct bnx_softc *sc)
/* DRC - Fix for 64 bit address. */
DBPRINT(sc,BNX_INFO, "stats_block_paddr = 0x%08X\n",
- (u_int32_t) sc->stats_block_paddr);
+ (u_int32_t) sc->stats_block_paddr);
/*
* Allocate DMA memory for the TX buffer descriptor chain,
@@ -2088,7 +2089,8 @@ bnx_dma_alloc(struct bnx_softc *sc)
if (bus_dmamem_alloc(sc->bnx_dmatag, BNX_TX_CHAIN_PAGE_SZ,
BCM_PAGE_SIZE, BNX_DMA_BOUNDARY, &sc->tx_bd_chain_seg[i], 1,
&sc->tx_bd_chain_rseg[i], BUS_DMA_NOWAIT)) {
- printf(": Could not allocate TX desc %d DMA memory!\n", i);
+ printf(": Could not allocate TX desc %d DMA memory!\n",
+ i);
rc = ENOMEM;
goto bnx_dma_alloc_exit;
}
@@ -2109,11 +2111,12 @@ bnx_dma_alloc(struct bnx_softc *sc)
goto bnx_dma_alloc_exit;
}
- sc->tx_bd_chain_paddr[i] = sc->tx_bd_chain_map[i]->dm_segs[0].ds_addr;
+ sc->tx_bd_chain_paddr[i] =
+ sc->tx_bd_chain_map[i]->dm_segs[0].ds_addr;
/* DRC - Fix for 64 bit systems. */
DBPRINT(sc, BNX_INFO, "tx_bd_chain_paddr[%d] = 0x%08X\n",
- i, (u_int32_t) sc->tx_bd_chain_paddr[i]);
+ i, (u_int32_t) sc->tx_bd_chain_paddr[i]);
}
/*
@@ -2147,7 +2150,8 @@ bnx_dma_alloc(struct bnx_softc *sc)
if (bus_dmamem_alloc(sc->bnx_dmatag, BNX_RX_CHAIN_PAGE_SZ,
BCM_PAGE_SIZE, BNX_DMA_BOUNDARY, &sc->rx_bd_chain_seg[i], 1,
&sc->rx_bd_chain_rseg[i], BUS_DMA_NOWAIT)) {
- printf(": Could not allocate Rx desc %d DMA memory!\n", i);
+ printf(": Could not allocate Rx desc %d DMA memory!\n",
+ i);
rc = ENOMEM;
goto bnx_dma_alloc_exit;
}
@@ -2169,11 +2173,12 @@ bnx_dma_alloc(struct bnx_softc *sc)
}
bzero(sc->rx_bd_chain[i], BNX_RX_CHAIN_PAGE_SZ);
- sc->rx_bd_chain_paddr[i] = sc->rx_bd_chain_map[i]->dm_segs[0].ds_addr;
+ sc->rx_bd_chain_paddr[i] =
+ sc->rx_bd_chain_map[i]->dm_segs[0].ds_addr;
/* DRC - Fix for 64 bit systems. */
DBPRINT(sc, BNX_INFO, "rx_bd_chain_paddr[%d] = 0x%08X\n",
- i, (u_int32_t) sc->rx_bd_chain_paddr[i]);
+ i, (u_int32_t) sc->rx_bd_chain_paddr[i]);
}
/*
@@ -2207,7 +2212,7 @@ bnx_dma_alloc(struct bnx_softc *sc)
void
bnx_release_resources(struct bnx_softc *sc)
{
- struct pci_attach_args *pa = &(sc->bnx_pa);
+ struct pci_attach_args *pa = &(sc->bnx_pa);
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -2234,8 +2239,8 @@ bnx_release_resources(struct bnx_softc *sc)
int
bnx_fw_sync(struct bnx_softc *sc, u_int32_t msg_data)
{
- int i, rc = 0;
- u_int32_t val;
+ int i, rc = 0;
+ u_int32_t val;
/* Don't waste any time if we've timed out before. */
if (sc->bnx_fw_timed_out) {
@@ -2247,7 +2252,8 @@ bnx_fw_sync(struct bnx_softc *sc, u_int32_t msg_data)
sc->bnx_fw_wr_seq++;
msg_data |= sc->bnx_fw_wr_seq;
- DBPRINT(sc, BNX_VERBOSE, "bnx_fw_sync(): msg_data = 0x%08X\n", msg_data);
+ DBPRINT(sc, BNX_VERBOSE, "bnx_fw_sync(): msg_data = 0x%08X\n",
+ msg_data);
/* Send the message to the bootcode driver mailbox. */
REG_WR_IND(sc, sc->bnx_shmem_base + BNX_DRV_MB, msg_data);
@@ -2264,10 +2270,8 @@ bnx_fw_sync(struct bnx_softc *sc, u_int32_t msg_data)
/* If we've timed out, tell the bootcode that we've stopped waiting. */
if (((val & BNX_FW_MSG_ACK) != (msg_data & BNX_DRV_MSG_SEQ)) &&
((msg_data & BNX_DRV_MSG_DATA) != BNX_DRV_MSG_DATA_WAIT0)) {
-
BNX_PRINTF(sc, "%s(%d): Firmware synchronization timeout! "
- "msg_data = 0x%08X\n",
- __FILE__, __LINE__, msg_data);
+ "msg_data = 0x%08X\n", __FILE__, __LINE__, msg_data);
msg_data &= ~BNX_DRV_MSG_CODE;
msg_data |= BNX_DRV_MSG_CODE_FW_TIMEOUT;
@@ -2290,10 +2294,10 @@ bnx_fw_sync_exit:
/****************************************************************************/
void
bnx_load_rv2p_fw(struct bnx_softc *sc, u_int32_t *rv2p_code,
- u_int32_t rv2p_code_len, u_int32_t rv2p_proc)
+ u_int32_t rv2p_code_len, u_int32_t rv2p_proc)
{
- int i;
- u_int32_t val;
+ int i;
+ u_int32_t val;
for (i = 0; i < rv2p_code_len; i += 8) {
REG_WR(sc, BNX_RV2P_INSTR_HIGH, *rv2p_code);
@@ -2312,12 +2316,10 @@ bnx_load_rv2p_fw(struct bnx_softc *sc, u_int32_t *rv2p_code,
}
/* Reset the processor, un-stall is done later. */
- if (rv2p_proc == RV2P_PROC1) {
+ if (rv2p_proc == RV2P_PROC1)
REG_WR(sc, BNX_RV2P_COMMAND, BNX_RV2P_COMMAND_PROC1_RESET);
- }
- else {
+ else
REG_WR(sc, BNX_RV2P_COMMAND, BNX_RV2P_COMMAND_PROC2_RESET);
- }
}
/****************************************************************************/
@@ -2331,10 +2333,10 @@ bnx_load_rv2p_fw(struct bnx_softc *sc, u_int32_t *rv2p_code,
/****************************************************************************/
void
bnx_load_cpu_fw(struct bnx_softc *sc, struct cpu_reg *cpu_reg,
- struct fw_info *fw)
+ struct fw_info *fw)
{
- u_int32_t offset;
- u_int32_t val;
+ u_int32_t offset;
+ u_int32_t val;
/* Halt the CPU. */
val = REG_RD_IND(sc, cpu_reg->mode);
@@ -2347,9 +2349,8 @@ bnx_load_cpu_fw(struct bnx_softc *sc, struct cpu_reg *cpu_reg,
if (fw->text) {
int j;
- for (j = 0; j < (fw->text_len / 4); j++, offset += 4) {
+ for (j = 0; j < (fw->text_len / 4); j++, offset += 4)
REG_WR_IND(sc, offset, fw->text[j]);
- }
}
/* Load the Data area. */
@@ -2357,9 +2358,8 @@ bnx_load_cpu_fw(struct bnx_softc *sc, struct cpu_reg *cpu_reg,
if (fw->data) {
int j;
- for (j = 0; j < (fw->data_len / 4); j++, offset += 4) {
+ for (j = 0; j < (fw->data_len / 4); j++, offset += 4)
REG_WR_IND(sc, offset, fw->data[j]);
- }
}
/* Load the SBSS area. */
@@ -2367,9 +2367,8 @@ bnx_load_cpu_fw(struct bnx_softc *sc, struct cpu_reg *cpu_reg,
if (fw->sbss) {
int j;
- for (j = 0; j < (fw->sbss_len / 4); j++, offset += 4) {
+ for (j = 0; j < (fw->sbss_len / 4); j++, offset += 4)
REG_WR_IND(sc, offset, fw->sbss[j]);
- }
}
/* Load the BSS area. */
@@ -2377,20 +2376,18 @@ bnx_load_cpu_fw(struct bnx_softc *sc, struct cpu_reg *cpu_reg,
if (fw->bss) {
int j;
- for (j = 0; j < (fw->bss_len/4); j++, offset += 4) {
+ for (j = 0; j < (fw->bss_len/4); j++, offset += 4)
REG_WR_IND(sc, offset, fw->bss[j]);
- }
}
/* Load the Read-Only area. */
offset = cpu_reg->spad_base +
- (fw->rodata_addr - cpu_reg->mips_view_base);
+ (fw->rodata_addr - cpu_reg->mips_view_base);
if (fw->rodata) {
int j;
- for (j = 0; j < (fw->rodata_len / 4); j++, offset += 4) {
+ for (j = 0; j < (fw->rodata_len / 4); j++, offset += 4)
REG_WR_IND(sc, offset, fw->rodata[j]);
- }
}
/* Clear the pre-fetch instruction. */
@@ -2419,8 +2416,10 @@ bnx_init_cpus(struct bnx_softc *sc)
struct fw_info fw;
/* Initialize the RV2P processor. */
- bnx_load_rv2p_fw(sc, bnx_rv2p_proc1, sizeof(bnx_rv2p_proc1), RV2P_PROC1);
- bnx_load_rv2p_fw(sc, bnx_rv2p_proc2, sizeof(bnx_rv2p_proc2), RV2P_PROC2);
+ bnx_load_rv2p_fw(sc, bnx_rv2p_proc1, sizeof(bnx_rv2p_proc1),
+ RV2P_PROC1);
+ bnx_load_rv2p_fw(sc, bnx_rv2p_proc2, sizeof(bnx_rv2p_proc2),
+ RV2P_PROC2);
/* Initialize the RX Processor. */
cpu_reg.mode = BNX_RXP_CPU_MODE;
@@ -2622,7 +2621,7 @@ bnx_init_cpus(struct bnx_softc *sc)
void
bnx_init_context(struct bnx_softc *sc)
{
- u_int32_t vcid;
+ u_int32_t vcid;
vcid = 96;
while (vcid) {
@@ -2637,9 +2636,8 @@ bnx_init_context(struct bnx_softc *sc)
REG_WR(sc, BNX_CTX_PAGE_TBL, pcid_addr);
/* Zero out the context. */
- for (offset = 0; offset < PHY_CTX_SIZE; offset += 4) {
+ for (offset = 0; offset < PHY_CTX_SIZE; offset += 4)
CTX_WR(sc, 0x00, offset, 0);
- }
REG_WR(sc, BNX_CTX_VIRT_ADDR, vcid_addr);
REG_WR(sc, BNX_CTX_PAGE_TBL, pcid_addr);
@@ -2655,7 +2653,7 @@ bnx_init_context(struct bnx_softc *sc)
void
bnx_get_mac_addr(struct bnx_softc *sc)
{
- u_int32_t mac_lo = 0, mac_hi = 0;
+ u_int32_t mac_lo = 0, mac_hi = 0;
/*
* The NetXtreme II bootcode populates various NIC
@@ -2666,14 +2664,12 @@ bnx_get_mac_addr(struct bnx_softc *sc)
* shared memory for speed.
*/
- mac_hi = REG_RD_IND(sc, sc->bnx_shmem_base +
- BNX_PORT_HW_CFG_MAC_UPPER);
- mac_lo = REG_RD_IND(sc, sc->bnx_shmem_base +
- BNX_PORT_HW_CFG_MAC_LOWER);
+ mac_hi = REG_RD_IND(sc, sc->bnx_shmem_base + BNX_PORT_HW_CFG_MAC_UPPER);
+ mac_lo = REG_RD_IND(sc, sc->bnx_shmem_base + BNX_PORT_HW_CFG_MAC_LOWER);
if ((mac_lo == 0) && (mac_hi == 0)) {
BNX_PRINTF(sc, "%s(%d): Invalid Ethernet address!\n",
- __FILE__, __LINE__);
+ __FILE__, __LINE__);
} else {
sc->eaddr[0] = (u_char)(mac_hi >> 8);
sc->eaddr[1] = (u_char)(mac_hi >> 0);
@@ -2683,7 +2679,8 @@ bnx_get_mac_addr(struct bnx_softc *sc)
sc->eaddr[5] = (u_char)(mac_lo >> 0);
}
- DBPRINT(sc, BNX_INFO, "Permanent Ethernet address = %6D\n", sc->eaddr, ":");
+ DBPRINT(sc, BNX_INFO, "Permanent Ethernet address = "
+ "%6D\n", sc->eaddr, ":");
}
/****************************************************************************/
@@ -2695,10 +2692,11 @@ bnx_get_mac_addr(struct bnx_softc *sc)
void
bnx_set_mac_addr(struct bnx_softc *sc)
{
- u_int32_t val;
- u_int8_t *mac_addr = sc->eaddr;
+ u_int32_t val;
+ u_int8_t *mac_addr = sc->eaddr;
- DBPRINT(sc, BNX_INFO, "Setting Ethernet address = %6D\n", sc->eaddr, ":");
+ DBPRINT(sc, BNX_INFO, "Setting Ethernet address = "
+ "%6D\n", sc->eaddr, ":");
val = (mac_addr[0] << 8) | mac_addr[1];
@@ -2719,10 +2717,10 @@ bnx_set_mac_addr(struct bnx_softc *sc)
void
bnx_stop(struct bnx_softc *sc)
{
- struct ifnet *ifp = &sc->arpcom.ac_if;
- struct ifmedia_entry *ifm;
- struct mii_data *mii = NULL;
- int mtmp, itmp;
+ struct ifnet *ifp = &sc->arpcom.ac_if;
+ struct ifmedia_entry *ifm;
+ struct mii_data *mii = NULL;
+ int mtmp, itmp;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -2779,17 +2777,17 @@ bnx_stop(struct bnx_softc *sc)
int
bnx_reset(struct bnx_softc *sc, u_int32_t reset_code)
{
- u_int32_t val;
- int i, rc = 0;
+ u_int32_t val;
+ int i, rc = 0;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
/* Wait for pending PCI transactions to complete. */
REG_WR(sc, BNX_MISC_ENABLE_CLR_BITS,
- BNX_MISC_ENABLE_CLR_BITS_TX_DMA_ENABLE |
- BNX_MISC_ENABLE_CLR_BITS_DMA_ENGINE_ENABLE |
- BNX_MISC_ENABLE_CLR_BITS_RX_DMA_ENABLE |
- BNX_MISC_ENABLE_CLR_BITS_HOST_COALESCE_ENABLE);
+ BNX_MISC_ENABLE_CLR_BITS_TX_DMA_ENABLE |
+ BNX_MISC_ENABLE_CLR_BITS_DMA_ENGINE_ENABLE |
+ BNX_MISC_ENABLE_CLR_BITS_RX_DMA_ENABLE |
+ BNX_MISC_ENABLE_CLR_BITS_HOST_COALESCE_ENABLE);
val = REG_RD(sc, BNX_MISC_ENABLE_CLR_BITS);
DELAY(5);
@@ -2803,32 +2801,31 @@ bnx_reset(struct bnx_softc *sc, u_int32_t reset_code)
/* Set a firmware reminder that this is a soft reset. */
REG_WR_IND(sc, sc->bnx_shmem_base + BNX_DRV_RESET_SIGNATURE,
- BNX_DRV_RESET_SIGNATURE_MAGIC);
+ BNX_DRV_RESET_SIGNATURE_MAGIC);
/* Dummy read to force the chip to complete all current transactions. */
val = REG_RD(sc, BNX_MISC_ID);
/* Chip reset. */
val = BNX_PCICFG_MISC_CONFIG_CORE_RST_REQ |
- BNX_PCICFG_MISC_CONFIG_REG_WINDOW_ENA |
- BNX_PCICFG_MISC_CONFIG_TARGET_MB_WORD_SWAP;
+ BNX_PCICFG_MISC_CONFIG_REG_WINDOW_ENA |
+ BNX_PCICFG_MISC_CONFIG_TARGET_MB_WORD_SWAP;
REG_WR(sc, BNX_PCICFG_MISC_CONFIG, val);
/* Allow up to 30us for reset to complete. */
for (i = 0; i < 10; i++) {
val = REG_RD(sc, BNX_PCICFG_MISC_CONFIG);
if ((val & (BNX_PCICFG_MISC_CONFIG_CORE_RST_REQ |
- BNX_PCICFG_MISC_CONFIG_CORE_RST_BSY)) == 0) {
+ BNX_PCICFG_MISC_CONFIG_CORE_RST_BSY)) == 0)
break;
- }
+
DELAY(10);
}
/* Check that reset completed successfully. */
if (val & (BNX_PCICFG_MISC_CONFIG_CORE_RST_REQ |
- BNX_PCICFG_MISC_CONFIG_CORE_RST_BSY)) {
- BNX_PRINTF(sc, "%s(%d): Reset failed!\n",
- __FILE__, __LINE__);
+ BNX_PCICFG_MISC_CONFIG_CORE_RST_BSY)) {
+ BNX_PRINTF(sc, "%s(%d): Reset failed!\n", __FILE__, __LINE__);
rc = EBUSY;
goto bnx_reset_exit;
}
@@ -2837,7 +2834,7 @@ bnx_reset(struct bnx_softc *sc, u_int32_t reset_code)
val = REG_RD(sc, BNX_PCI_SWAP_DIAG0);
if (val != 0x01020304) {
BNX_PRINTF(sc, "%s(%d): Byte swap is incorrect!\n",
- __FILE__, __LINE__);
+ __FILE__, __LINE__);
rc = ENODEV;
goto bnx_reset_exit;
}
@@ -2848,8 +2845,8 @@ bnx_reset(struct bnx_softc *sc, u_int32_t reset_code)
/* Wait for the firmware to finish its initialization. */
rc = bnx_fw_sync(sc, BNX_DRV_MSG_DATA_WAIT1 | reset_code);
if (rc)
- BNX_PRINTF(sc, "%s(%d): Firmware did not complete initialization!\n",
- __FILE__, __LINE__);
+ BNX_PRINTF(sc, "%s(%d): Firmware did not complete "
+ "initialization!\n", __FILE__, __LINE__);
bnx_reset_exit:
DBPRINT(sc, BNX_VERBOSE_RESET, "Exiting %s()\n", __FUNCTION__);
@@ -2860,9 +2857,9 @@ bnx_reset_exit:
int
bnx_chipinit(struct bnx_softc *sc)
{
- struct pci_attach_args *pa = &(sc->bnx_pa);
- u_int32_t val;
- int rc = 0;
+ struct pci_attach_args *pa = &(sc->bnx_pa);
+ u_int32_t val;
+ int rc = 0;
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__);
@@ -2872,13 +2869,13 @@ bnx_chipinit(struct bnx_softc *sc)
/* Initialize DMA byte/word swapping, configure the number of DMA */
/* channels and PCI clock compensation delay. */
val = BNX_DMA_CONFIG_DATA_BYTE_SWAP |
- BNX_DMA_CONFIG_DATA_WORD_SWAP |
+ BNX_DMA_CONFIG_DATA_WORD_SWAP |
#if BYTE_ORDER == BIG_ENDIAN
- BNX_DMA_CONFIG_CNTL_BYTE_SWAP |
+ BNX_DMA_CONFIG_CNTL_BYTE_SWAP |
#endif
- BNX_DMA_CONFIG_CNTL_WORD_SWAP |
- DMA_READ_CHANS << 12 |
- DMA_WRITE_CHANS << 16;
+ BNX_DMA_CONFIG_CNTL_WORD_SWAP |
+ DMA_READ_CHANS << 12 |
+ DMA_WRITE_CHANS << 16;
val |= (0x2 << 20) | BNX_DMA_CONFIG_CNTL_PCI_COMP_DLY;
@@ -2902,14 +2899,15 @@ bnx_chipinit(struct bnx_softc *sc)
u_int16_t val;
val = pci_conf_read(pa->pa_pc, pa->pa_tag, BNX_PCI_PCIX_CMD);
- pci_conf_write(pa->pa_pc, pa->pa_tag, BNX_PCI_PCIX_CMD, val & ~0x2);
+ pci_conf_write(pa->pa_pc, pa->pa_tag, BNX_PCI_PCIX_CMD,
+ val & ~0x2);
}
/* Enable the RX_V2P and Context state machines before access. */
REG_WR(sc, BNX_MISC_ENABLE_SET_BITS,
- BNX_MISC_ENABLE_SET_BITS_HOST_COALESCE_ENABLE |
- BNX_MISC_ENABLE_STATUS_BITS_RX_V2P_ENABLE |
- BNX_MISC_ENABLE_STATUS_BITS_CONTEXT_ENABLE);
+ BNX_MISC_ENABLE_SET_BITS_HOST_COALESCE_ENABLE |
+ BNX_MISC_ENABLE_STATUS_BITS_RX_V2P_ENABLE |
+ BNX_MISC_ENABLE_STATUS_BITS_CONTEXT_ENABLE);
/* Initialize context mapping and zero out the quick contexts. */
bnx_init_context(sc);