diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2009-07-03 04:54:06 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2009-07-03 04:54:06 +0000 |
commit | 7fe1646c6b076ad7d055b4ffe99eadf477a66378 (patch) | |
tree | d53549ea11cb48d9c6cf629872e73a80a06e63ca /sys | |
parent | 29b6d8ef9c678cab6cf7ac1c0ca74bba2e39f994 (diff) |
this is a rather large change to add support for the BCM5709.
the 5709s use a the b09 firmwares, which is different to the b06 used by
all the other chips supported by bnx. the majority of the diff comes from
special handling for some indirect reads and writes, and because it needs
more host memory to operate with.
ive tried to keep the cosmetic changes to a minimum.
"go for it" deraadt@
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/mii/brgphy.c | 35 | ||||
-rw-r--r-- | sys/dev/pci/if_bnx.c | 639 | ||||
-rw-r--r-- | sys/dev/pci/if_bnxreg.h | 207 |
3 files changed, 736 insertions, 145 deletions
diff --git a/sys/dev/mii/brgphy.c b/sys/dev/mii/brgphy.c index 9c02c6657c1..7d83398d5db 100644 --- a/sys/dev/mii/brgphy.c +++ b/sys/dev/mii/brgphy.c @@ -1,4 +1,4 @@ -/* $OpenBSD: brgphy.c,v 1.86 2009/06/04 00:59:21 naddy Exp $ */ +/* $OpenBSD: brgphy.c,v 1.87 2009/07/03 04:54:05 dlg Exp $ */ /* * Copyright (c) 2000 @@ -92,6 +92,7 @@ void brgphy_adc_bug(struct mii_softc *); void brgphy_5704_a0_bug(struct mii_softc *); void brgphy_ber_bug(struct mii_softc *); void brgphy_crc_bug(struct mii_softc *); +void brgphy_disable_early_dac(struct mii_softc *sc); void brgphy_jumbo_settings(struct mii_softc *); void brgphy_eth_wirespeed(struct mii_softc *); @@ -150,6 +151,10 @@ static const struct mii_phydesc brgphys[] = { MII_STR_xxBROADCOM_BCM5708C }, { MII_OUI_xxBROADCOM2, MII_MODEL_xxBROADCOM2_BCM5708S, MII_STR_xxBROADCOM2_BCM5708S }, + { MII_OUI_xxBROADCOM2, MII_MODEL_xxBROADCOM2_BCM5709C, + MII_STR_xxBROADCOM2_BCM5709C }, + { MII_OUI_xxBROADCOM2, MII_MODEL_xxBROADCOM2_BCM5709CAX, + MII_STR_xxBROADCOM2_BCM5709CAX }, { MII_OUI_BROADCOM2, MII_MODEL_BROADCOM2_BCM5906, MII_STR_BROADCOM2_BCM5906 }, @@ -288,8 +293,8 @@ setit: } PHY_WRITE(sc, BRGPHY_MII_1000CTL, 0); - PHY_WRITE(sc, BRGPHY_MII_BMCR, speed); PHY_WRITE(sc, BRGPHY_MII_ANAR, BRGPHY_SEL_TYPE); + PHY_WRITE(sc, BRGPHY_MII_BMCR, speed); if ((IFM_SUBTYPE(ife->ifm_media) != IFM_1000_T) && (IFM_SUBTYPE(ife->ifm_media) != IFM_1000_SX) && @@ -688,7 +693,9 @@ brgphy_reset(struct mii_softc *sc) } else if (strcmp(devname, "bnx") == 0) { bnx_sc = sc->mii_pdata->mii_ifp->if_softc; - if (sc->mii_model == MII_MODEL_xxBROADCOM2_BCM5708S) { + if (BNX_CHIP_NUM(bnx_sc) == BNX_CHIP_NUM_5708 && + ISSET(BNX_CHIP_BOND_ID(bnx_sc), + BNX_CHIP_BOND_ID_SERDES_BIT)) { /* Store autoneg capabilities/results in digital block (Page 0) */ PHY_WRITE(sc, BRGPHY_5708S_BLOCK_ADDR, BRGPHY_5708S_DIG3_PG2); PHY_WRITE(sc, BRGPHY_5708S_PG2_DIGCTL_3_0, @@ -736,6 +743,16 @@ brgphy_reset(struct mii_softc *sc) PHY_WRITE(sc, BRGPHY_5708S_BLOCK_ADDR, BRGPHY_5708S_DIG_PG0); } + } else if (BNX_CHIP_NUM(bnx_sc) == BNX_CHIP_NUM_5709) { + if (BNX_CHIP_REV(bnx_sc) == BNX_CHIP_REV_Ax || + BNX_CHIP_REV(bnx_sc) == BNX_CHIP_REV_Bx) + brgphy_disable_early_dac(sc); + + /* Set Jumbo frame settings in the PHY. */ + brgphy_jumbo_settings(sc); + + /* Enable Ethernet@Wirespeed */ + brgphy_eth_wirespeed(sc); } else { if (!(sc->mii_flags & MIIF_HAVEFIBER)) { brgphy_ber_bug(sc); @@ -915,6 +932,18 @@ brgphy_crc_bug(struct mii_softc *sc) } void +brgphy_disable_early_dac(struct mii_softc *sc) +{ + uint32_t val; + + PHY_WRITE(sc, BRGPHY_MII_DSP_ADDR_REG, 0x0f08); + val = PHY_READ(sc, BRGPHY_MII_DSP_RW_PORT); + val &= ~(1 << 8); + PHY_WRITE(sc, BRGPHY_MII_DSP_RW_PORT, val); + +} + +void brgphy_jumbo_settings(struct mii_softc *sc) { u_int32_t val; diff --git a/sys/dev/pci/if_bnx.c b/sys/dev/pci/if_bnx.c index 94706ed317c..6c418b6a976 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.80 2009/07/03 04:34:51 dlg Exp $ */ +/* $OpenBSD: if_bnx.c,v 1.81 2009/07/03 04:54:05 dlg Exp $ */ /*- * Copyright (c) 2006 Broadcom Corporation @@ -41,12 +41,16 @@ __FBSDID("$FreeBSD: src/sys/dev/bce/if_bce.c,v 1.3 2006/04/13 14:12:26 ru Exp $" * BCM5706S A2, A3 * BCM5708C B1, B2 * BCM5708S B1, B2 + * BCM5709C A1, C0 + * BCM5716 C0 * * The following controllers are not supported by this driver: * BCM5706C A0, A1 * BCM5706S A0, A1 * BCM5708C A0, B0 * BCM5708S A0, B0 + * BCM5709C A0 B0, B1, B2 (pre-production) + * BCM5709S A0, A1, B0, B1, B2, C0 (pre-production) */ #include <dev/pci/if_bnxreg.h> @@ -153,11 +157,12 @@ const struct pci_matchid bnx_devices[] = { { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5706 }, { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5706S }, { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5708 }, - { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5708S } -#if 0 + { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5708S }, + { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5709 }, - { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5709S } -#endif + { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5709S }, + { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_BCM5716 } + }; /****************************************************************************/ @@ -165,14 +170,17 @@ const struct pci_matchid bnx_devices[] = { /****************************************************************************/ static struct flash_spec flash_table[] = { +#define BUFFERED_FLAGS (BNX_NV_BUFFERED | BNX_NV_TRANSLATE) +#define NONBUFFERED_FLAGS (BNX_NV_WREN) + /* Slow EEPROM */ {0x00000000, 0x40830380, 0x009f0081, 0xa184a053, 0xaf000400, - 1, SEEPROM_PAGE_BITS, SEEPROM_PAGE_SIZE, + BUFFERED_FLAGS, SEEPROM_PAGE_BITS, SEEPROM_PAGE_SIZE, SEEPROM_BYTE_ADDR_MASK, SEEPROM_TOTAL_SIZE, "EEPROM - slow"}, /* Expansion entry 0001 */ {0x08000002, 0x4b808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 0001"}, /* Saifun SA25F010 (non-buffered flash) */ @@ -184,72 +192,88 @@ static struct flash_spec flash_table[] = /* Saifun SA25F020 (non-buffered flash) */ /* strap, cfg1, & write1 need updates */ {0x0c000003, 0x4f808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, SAIFUN_FLASH_BASE_TOTAL_SIZE*4, "Non-buffered flash (256kB)"}, /* Expansion entry 0100 */ {0x11000000, 0x53808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 0100"}, /* Entry 0101: ST M45PE10 (non-buffered flash, TetonII B0) */ {0x19000002, 0x5b808201, 0x000500db, 0x03840253, 0xaf020406, - 0, ST_MICRO_FLASH_PAGE_BITS, ST_MICRO_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, ST_MICRO_FLASH_PAGE_BITS, ST_MICRO_FLASH_PAGE_SIZE, ST_MICRO_FLASH_BYTE_ADDR_MASK, ST_MICRO_FLASH_BASE_TOTAL_SIZE*2, "Entry 0101: ST M45PE10 (128kB non-bufferred)"}, /* Entry 0110: ST M45PE20 (non-buffered flash)*/ {0x15000001, 0x57808201, 0x000500db, 0x03840253, 0xaf020406, - 0, ST_MICRO_FLASH_PAGE_BITS, ST_MICRO_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, ST_MICRO_FLASH_PAGE_BITS, ST_MICRO_FLASH_PAGE_SIZE, ST_MICRO_FLASH_BYTE_ADDR_MASK, ST_MICRO_FLASH_BASE_TOTAL_SIZE*4, "Entry 0110: ST M45PE20 (256kB non-bufferred)"}, /* Saifun SA25F005 (non-buffered flash) */ /* strap, cfg1, & write1 need updates */ {0x1d000003, 0x5f808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, SAIFUN_FLASH_BASE_TOTAL_SIZE, "Non-buffered flash (64kB)"}, /* Fast EEPROM */ {0x22000000, 0x62808380, 0x009f0081, 0xa184a053, 0xaf000400, - 1, SEEPROM_PAGE_BITS, SEEPROM_PAGE_SIZE, + BUFFERED_FLAGS, SEEPROM_PAGE_BITS, SEEPROM_PAGE_SIZE, SEEPROM_BYTE_ADDR_MASK, SEEPROM_TOTAL_SIZE, "EEPROM - fast"}, /* Expansion entry 1001 */ {0x2a000002, 0x6b808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 1001"}, /* Expansion entry 1010 */ {0x26000001, 0x67808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 1010"}, /* ATMEL AT45DB011B (buffered flash) */ {0x2e000003, 0x6e808273, 0x00570081, 0x68848353, 0xaf000400, - 1, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, + BUFFERED_FLAGS, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, BUFFERED_FLASH_BYTE_ADDR_MASK, BUFFERED_FLASH_TOTAL_SIZE, "Buffered flash (128kB)"}, /* Expansion entry 1100 */ {0x33000000, 0x73808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 1100"}, /* Expansion entry 1101 */ {0x3b000002, 0x7b808201, 0x00050081, 0x03840253, 0xaf020406, - 0, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, + NONBUFFERED_FLAGS, SAIFUN_FLASH_PAGE_BITS, SAIFUN_FLASH_PAGE_SIZE, SAIFUN_FLASH_BYTE_ADDR_MASK, 0, "Entry 1101"}, /* Ateml Expansion entry 1110 */ {0x37000001, 0x76808273, 0x00570081, 0x68848353, 0xaf000400, - 1, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, + BUFFERED_FLAGS, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, BUFFERED_FLASH_BYTE_ADDR_MASK, 0, "Entry 1110 (Atmel)"}, /* ATMEL AT45DB021B (buffered flash) */ {0x3f000003, 0x7e808273, 0x00570081, 0x68848353, 0xaf000400, - 1, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, + BUFFERED_FLAGS, BUFFERED_FLASH_PAGE_BITS, BUFFERED_FLASH_PAGE_SIZE, BUFFERED_FLASH_BYTE_ADDR_MASK, BUFFERED_FLASH_TOTAL_SIZE*2, "Buffered flash (256kB)"}, }; +/* + * The BCM5709 controllers transparently handle the + * differences between Atmel 264 byte pages and all + * flash devices which use 256 byte pages, so no + * logical-to-physical mapping is required in the + * driver. + */ +static struct flash_spec flash_5709 = { + .flags = BNX_NV_BUFFERED, + .page_bits = BCM5709_FLASH_PAGE_BITS, + .page_size = BCM5709_FLASH_PAGE_SIZE, + .addr_mask = BCM5709_FLASH_BYTE_ADDR_MASK, + .total_size = BUFFERED_FLASH_TOTAL_SIZE * 2, + .name = "5709 buffered flash (256kB)", +}; + /****************************************************************************/ /* OpenBSD device entry points. */ /****************************************************************************/ @@ -316,6 +340,7 @@ int bnx_nvram_write(struct bnx_softc *, u_int32_t, u_int8_t *, int); /****************************************************************************/ /* */ /****************************************************************************/ +void bnx_get_media(struct bnx_softc *); int bnx_dma_alloc(struct bnx_softc *); void bnx_dma_free(struct bnx_softc *); void bnx_release_resources(struct bnx_softc *); @@ -337,7 +362,9 @@ int bnx_blockinit(struct bnx_softc *); int bnx_get_buf(struct bnx_softc *, u_int16_t *, u_int16_t *, u_int32_t *); int bnx_init_tx_chain(struct bnx_softc *); +void bnx_init_tx_context(struct bnx_softc *); void bnx_fill_rx_chain(struct bnx_softc *); +void bnx_init_rx_context(struct bnx_softc *); int bnx_init_rx_chain(struct bnx_softc *); void bnx_free_rx_chain(struct bnx_softc *); void bnx_free_tx_chain(struct bnx_softc *); @@ -667,7 +694,8 @@ bnx_attach(struct device *parent, struct device *self, void *aux) */ val = REG_RD_IND(sc, BNX_SHM_HDR_SIGNATURE); if ((val & BNX_SHM_HDR_SIGNATURE_SIG_MASK) == BNX_SHM_HDR_SIGNATURE_SIG) - sc->bnx_shmem_base = REG_RD_IND(sc, BNX_SHM_HDR_ADDR_0); + sc->bnx_shmem_base = REG_RD_IND(sc, BNX_SHM_HDR_ADDR_0 + + (sc->bnx_pa.pa_function << 2)); else sc->bnx_shmem_base = HOST_VIEW_SHMEM_BASE; @@ -745,16 +773,25 @@ bnx_attachhook(void *xsc) struct bnx_softc *sc = xsc; struct pci_attach_args *pa = &sc->bnx_pa; struct ifnet *ifp; - u_int32_t val; int error, mii_flags = 0; + int fw = BNX_FW_B06; + int rv2p = BNX_RV2P; + + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + fw = BNX_FW_B09; + if ((BNX_CHIP_REV(sc) == BNX_CHIP_REV_Ax)) + rv2p = BNX_XI90_RV2P; + else + rv2p = BNX_XI_RV2P; + } - if ((error = bnx_read_firmware(sc, BNX_FW_B06)) != 0) { + if ((error = bnx_read_firmware(sc, fw)) != 0) { printf("%s: error %d, could not read firmware\n", sc->bnx_dev.dv_xname, error); return; } - if ((error = bnx_read_rv2p(sc, BNX_RV2P)) != 0) { + if ((error = bnx_read_rv2p(sc, rv2p)) != 0) { printf("%s: error %d, could not read rv2p\n", sc->bnx_dev.dv_xname, error); return; @@ -816,27 +853,8 @@ bnx_attachhook(void *xsc) /* Update statistics once every second. */ sc->bnx_stats_ticks = 1000000 & 0xffff00; - /* - * The SerDes based NetXtreme II controllers - * that support 2.5Gb operation (currently - * 5708S) use a PHY at address 2, otherwise - * the PHY is present at address 1. - */ - sc->bnx_phy_addr = 1; - - if (BNX_CHIP_BOND_ID(sc) & BNX_CHIP_BOND_ID_SERDES_BIT) { - sc->bnx_phy_flags |= BNX_PHY_SERDES_FLAG; - sc->bnx_flags |= BNX_NO_WOL_FLAG; - if (BNX_CHIP_NUM(sc) != BNX_CHIP_NUM_5706) { - sc->bnx_phy_addr = 2; - val = REG_RD_IND(sc, sc->bnx_shmem_base + - BNX_SHARED_HW_CFG_CONFIG); - if (val & BNX_SHARED_HW_CFG_PHY_2_5G) { - sc->bnx_phy_flags |= BNX_PHY_2_5G_CAPABLE_FLAG; - DBPRINT(sc, BNX_WARN, "Found 2.5Gb capable adapter\n"); - } - } - } + /* Find the media type for the adapter. */ + bnx_get_media(sc); /* * Store config data needed by the PHY driver for @@ -1050,16 +1068,35 @@ bnx_reg_wr_ind(struct bnx_softc *sc, u_int32_t offset, u_int32_t val) /* Nothing. */ /****************************************************************************/ void -bnx_ctx_wr(struct bnx_softc *sc, u_int32_t cid_addr, u_int32_t offset, - u_int32_t val) +bnx_ctx_wr(struct bnx_softc *sc, u_int32_t cid_addr, u_int32_t ctx_offset, + u_int32_t ctx_val) { + u_int32_t idx, offset = ctx_offset + cid_addr; + u_int32_t val, retry_cnt = 5; - DBPRINT(sc, BNX_EXCESSIVE, "%s(); cid_addr = 0x%08X, offset = 0x%08X, " - "val = 0x%08X\n", __FUNCTION__, cid_addr, offset, val); + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + REG_WR(sc, BNX_CTX_CTX_DATA, ctx_val); + REG_WR(sc, BNX_CTX_CTX_CTRL, + (offset | BNX_CTX_CTX_CTRL_WRITE_REQ)); - offset += cid_addr; - REG_WR(sc, BNX_CTX_DATA_ADR, offset); - REG_WR(sc, BNX_CTX_DATA, val); + for (idx = 0; idx < retry_cnt; idx++) { + val = REG_RD(sc, BNX_CTX_CTX_CTRL); + if ((val & BNX_CTX_CTX_CTRL_WRITE_REQ) == 0) + break; + DELAY(5); + } + +#if 0 + if (val & BNX_CTX_CTX_CTRL_WRITE_REQ) + BNX_PRINTF("%s(%d); Unable to write CTX memory: " + "cid_addr = 0x%08X, offset = 0x%08X!\n", + __FILE__, __LINE__, cid_addr, ctx_offset); +#endif + + } else { + REG_WR(sc, BNX_CTX_DATA_ADR, offset); + REG_WR(sc, BNX_CTX_DATA, ctx_val); + } } /****************************************************************************/ @@ -1358,7 +1395,7 @@ bnx_enable_nvram_write(struct bnx_softc *sc) val = REG_RD(sc, BNX_MISC_CFG); REG_WR(sc, BNX_MISC_CFG, val | BNX_MISC_CFG_NVM_WR_EN_PCI); - if (!sc->bnx_flash_info->buffered) { + if (!ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED)) { int j; REG_WR(sc, BNX_NVM_COMMAND, BNX_NVM_COMMAND_DONE); @@ -1464,7 +1501,7 @@ bnx_nvram_erase_page(struct bnx_softc *sc, u_int32_t offset) int j; /* Buffered flash doesn't require an erase. */ - if (sc->bnx_flash_info->buffered) + if (ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED)) return (0); DBPRINT(sc, BNX_VERBOSE, "Erasing NVRAM page.\n"); @@ -1520,11 +1557,12 @@ bnx_nvram_read_dword(struct bnx_softc *sc, u_int32_t offset, /* Build the command word. */ cmd = BNX_NVM_COMMAND_DOIT | cmd_flags; - /* Calculate the offset for buffered flash. */ - if (sc->bnx_flash_info->buffered) + /* Calculate the offset for buffered flash if translation is used. */ + if (ISSET(sc->bnx_flash_info->flags, BNX_NV_TRANSLATE)) { offset = ((offset / sc->bnx_flash_info->page_size) << sc->bnx_flash_info->page_bits) + (offset % sc->bnx_flash_info->page_size); + } /* * Clear the DONE bit separately, set the address to read, @@ -1581,11 +1619,12 @@ bnx_nvram_write_dword(struct bnx_softc *sc, u_int32_t offset, u_int8_t *val, /* Build the command word. */ cmd = BNX_NVM_COMMAND_DOIT | BNX_NVM_COMMAND_WR | cmd_flags; - /* Calculate the offset for buffered flash. */ - if (sc->bnx_flash_info->buffered) + /* Calculate the offset for buffered flash if translation is used. */ + if (ISSET(sc->bnx_flash_info->flags, BNX_NV_TRANSLATE)) { offset = ((offset / sc->bnx_flash_info->page_size) << sc->bnx_flash_info->page_bits) + (offset % sc->bnx_flash_info->page_size); + } /* * Clear the DONE bit separately, convert NVRAM data to big-endian, @@ -1628,18 +1667,21 @@ int bnx_init_nvram(struct bnx_softc *sc) { u_int32_t val; - int j, entry_count, rc; + int j, entry_count, rc = 0; struct flash_spec *flash; DBPRINT(sc,BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__); + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + sc->bnx_flash_info = &flash_5709; + goto bnx_init_nvram_get_flash_size; + } + /* Determine the selected interface. */ val = REG_RD(sc, BNX_NVM_CFG1); entry_count = sizeof(flash_table) / sizeof(struct flash_spec); - rc = 0; - /* * Flash reconfiguration is required to support additional * NVRAM devices not directly supported in hardware. @@ -1707,6 +1749,7 @@ bnx_init_nvram(struct bnx_softc *sc) rc = ENODEV; } +bnx_init_nvram_get_flash_size: /* Write the flash config data to the shared memory interface. */ val = REG_RD_IND(sc, sc->bnx_shmem_base + BNX_SHARED_HW_CFG_CONFIG2); val &= BNX_SHARED_HW_CFG2_NVM_SIZE_MASK; @@ -1922,7 +1965,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf, bnx_enable_nvram_access(sc); cmd_flags = BNX_NVM_COMMAND_FIRST; - if (sc->bnx_flash_info->buffered == 0) { + if (!ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED)) { int j; /* Read the whole page into the buffer @@ -1957,7 +2000,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf, /* Loop to write back the buffer data from page_start to * data_start */ i = 0; - if (sc->bnx_flash_info->buffered == 0) { + if (!ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED)) { for (addr = page_start; addr < data_start; addr += 4, i += 4) { @@ -1974,8 +2017,8 @@ 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))) { + (ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED) + && (addr == data_end - 4))) { cmd_flags |= BNX_NVM_COMMAND_LAST; } @@ -1991,7 +2034,7 @@ bnx_nvram_write(struct bnx_softc *sc, u_int32_t offset, u_int8_t *data_buf, /* Loop to write back the buffer data from data_end * to page_end */ - if (sc->bnx_flash_info->buffered == 0) { + if (!ISSET(sc->bnx_flash_info->flags, BNX_NV_BUFFERED)) { for (addr = data_end; addr < page_end; addr += 4, i += 4) { @@ -2089,6 +2132,97 @@ bnx_nvram_test_done: } /****************************************************************************/ +/* Identifies the current media type of the controller and sets the PHY */ +/* address. */ +/* */ +/* Returns: */ +/* Nothing. */ +/****************************************************************************/ +void +bnx_get_media(struct bnx_softc *sc) +{ + u_int32_t val; + + sc->bnx_phy_addr = 1; + + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + u_int32_t val = REG_RD(sc, BNX_MISC_DUAL_MEDIA_CTRL); + u_int32_t bond_id = val & BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID; + u_int32_t strap; + + /* + * The BCM5709S is software configurable + * for Copper or SerDes operation. + */ + if (bond_id == BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID_C) { + DBPRINT(sc, BNX_INFO_LOAD, + "5709 bonded for copper.\n"); + goto bnx_get_media_exit; + } else if (bond_id == BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID_S) { + DBPRINT(sc, BNX_INFO_LOAD, + "5709 bonded for dual media.\n"); + sc->bnx_phy_flags |= BNX_PHY_SERDES_FLAG; + goto bnx_get_media_exit; + } + + if (val & BNX_MISC_DUAL_MEDIA_CTRL_STRAP_OVERRIDE) + strap = (val & BNX_MISC_DUAL_MEDIA_CTRL_PHY_CTRL) >> 21; + else { + strap = (val & BNX_MISC_DUAL_MEDIA_CTRL_PHY_CTRL_STRAP) + >> 8; + } + + if (sc->bnx_pa.pa_function == 0) { + switch (strap) { + case 0x4: + case 0x5: + case 0x6: + DBPRINT(sc, BNX_INFO_LOAD, + "BCM5709 s/w configured for SerDes.\n"); + sc->bnx_phy_flags |= BNX_PHY_SERDES_FLAG; + default: + DBPRINT(sc, BNX_INFO_LOAD, + "BCM5709 s/w configured for Copper.\n"); + } + } else { + switch (strap) { + case 0x1: + case 0x2: + case 0x4: + DBPRINT(sc, BNX_INFO_LOAD, + "BCM5709 s/w configured for SerDes.\n"); + sc->bnx_phy_flags |= BNX_PHY_SERDES_FLAG; + default: + DBPRINT(sc, BNX_INFO_LOAD, + "BCM5709 s/w configured for Copper.\n"); + } + } + + } else if (BNX_CHIP_BOND_ID(sc) & BNX_CHIP_BOND_ID_SERDES_BIT) + sc->bnx_phy_flags |= BNX_PHY_SERDES_FLAG; + + if (sc->bnx_phy_flags && BNX_PHY_SERDES_FLAG) { + sc->bnx_flags |= BNX_NO_WOL_FLAG; + if (BNX_CHIP_NUM(sc) != BNX_CHIP_NUM_5706) { + sc->bnx_phy_addr = 2; + val = REG_RD_IND(sc, sc->bnx_shmem_base + + BNX_SHARED_HW_CFG_CONFIG); + if (val & BNX_SHARED_HW_CFG_PHY_2_5G) { + sc->bnx_phy_flags |= BNX_PHY_2_5G_CAPABLE_FLAG; + DBPRINT(sc, BNX_INFO_LOAD, + "Found 2.5Gb capable adapter\n"); + } + } + } else if ((BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5706) || + (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5708)) + sc->bnx_phy_flags |= BNX_PHY_CRC_FIX_FLAG; + +bnx_get_media_exit: + DBPRINT(sc, (BNX_INFO_LOAD | BNX_INFO_PHY), + "Using PHY address %d.\n", sc->bnx_phy_addr); +} + +/****************************************************************************/ /* Free any DMA memory owned by the driver. */ /* */ /* Scans through each data structre that requires DMA memory and frees */ @@ -2128,6 +2262,24 @@ bnx_dma_free(struct bnx_softc *sc) sc->stats_map = NULL; } + /* Free, unmap and destroy all context memory pages. */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + for (i = 0; i < sc->ctx_pages; i++) { + if (sc->ctx_block[i] != NULL) { + bus_dmamap_unload(sc->bnx_dmatag, + sc->ctx_map[i]); + bus_dmamem_unmap(sc->bnx_dmatag, + (caddr_t)sc->ctx_block[i], + BCM_PAGE_SIZE); + bus_dmamem_free(sc->bnx_dmatag, + &sc->ctx_segs[i], sc->ctx_rsegs[i]); + bus_dmamap_destroy(sc->bnx_dmatag, + sc->ctx_map[i]); + sc->ctx_block[i] = NULL; + } + } + } + /* Free, unmap and destroy all TX buffer descriptor chain pages. */ for (i = 0; i < TX_PAGES; i++ ) { if (sc->tx_bd_chain[i] != NULL && @@ -2233,6 +2385,54 @@ bnx_dma_alloc(struct bnx_softc *sc) DBPRINT(sc, BNX_INFO, "status_block_paddr = 0x%08X\n", (u_int32_t) sc->status_block_paddr); + /* BCM5709 uses host memory as cache for context memory. */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + sc->ctx_pages = 0x2000 / BCM_PAGE_SIZE; + if (sc->ctx_pages == 0) + sc->ctx_pages = 1; + if (sc->ctx_pages > 4) /* XXX */ + sc->ctx_pages = 4; + + DBRUNIF((sc->ctx_pages > 512), + BCE_PRINTF("%s(%d): Too many CTX pages! %d > 512\n", + __FILE__, __LINE__, sc->ctx_pages)); + + + for (i = 0; i < sc->ctx_pages; i++) { + if (bus_dmamap_create(sc->bnx_dmatag, BCM_PAGE_SIZE, + 1, BCM_PAGE_SIZE, BNX_DMA_BOUNDARY, + BUS_DMA_NOWAIT | BUS_DMA_ALLOCNOW, + &sc->ctx_map[i]) != 0) { + rc = ENOMEM; + goto bnx_dma_alloc_exit; + } + + if (bus_dmamem_alloc(sc->bnx_dmatag, BCM_PAGE_SIZE, + BCM_PAGE_SIZE, BNX_DMA_BOUNDARY, &sc->ctx_segs[i], + 1, &sc->ctx_rsegs[i], BUS_DMA_NOWAIT) != 0) { + rc = ENOMEM; + goto bnx_dma_alloc_exit; + } + + if (bus_dmamem_map(sc->bnx_dmatag, &sc->ctx_segs[i], + sc->ctx_rsegs[i], BCM_PAGE_SIZE, + (caddr_t *)&sc->ctx_block[i], + BUS_DMA_NOWAIT) != 0) { + rc = ENOMEM; + goto bnx_dma_alloc_exit; + } + + if (bus_dmamap_load(sc->bnx_dmatag, sc->ctx_map[i], + sc->ctx_block[i], BCM_PAGE_SIZE, NULL, + BUS_DMA_NOWAIT) != 0) { + rc = ENOMEM; + goto bnx_dma_alloc_exit; + } + + bzero(sc->ctx_block[i], BCM_PAGE_SIZE); + } + } + /* * Allocate DMA memory for the statistics block, map the memory into * DMA space, and fetch the physical address of the block. @@ -2492,6 +2692,12 @@ bnx_load_rv2p_fw(struct bnx_softc *sc, u_int32_t *rv2p_code, int i; u_int32_t val; + /* Set the page size used by RV2P. */ + if (rv2p_proc == RV2P_PROC2) { + BNX_RV2P_PROC2_CHG_MAX_BD_PAGE(rv2p_code, + USABLE_RX_BD_PER_PAGE); + } + for (i = 0; i < rv2p_code_len; i += 8) { REG_WR(sc, BNX_RV2P_INSTR_HIGH, *rv2p_code); rv2p_code++; @@ -2501,8 +2707,7 @@ bnx_load_rv2p_fw(struct bnx_softc *sc, u_int32_t *rv2p_code, if (rv2p_proc == RV2P_PROC1) { val = (i / 8) | BNX_RV2P_PROC1_ADDR_CMD_RDWR; REG_WR(sc, BNX_RV2P_PROC1_ADDR_CMD, val); - } - else { + } else { val = (i / 8) | BNX_RV2P_PROC2_ADDR_CMD_RDWR; REG_WR(sc, BNX_RV2P_PROC2_ADDR_CMD, val); } @@ -2610,6 +2815,14 @@ bnx_init_cpus(struct bnx_softc *sc) struct cpu_reg cpu_reg; struct fw_info fw; + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + bfw = &bnx_firmwares[BNX_FW_B09]; + if ((BNX_CHIP_REV(sc) == BNX_CHIP_REV_Ax)) + rv2p = &bnx_rv2ps[BNX_XI90_RV2P]; + else + rv2p = &bnx_rv2ps[BNX_XI_RV2P]; + } + /* Initialize the RV2P processor. */ bnx_load_rv2p_fw(sc, rv2p->bnx_rv2p_proc1, rv2p->fw->bnx_rv2p_proc1len, RV2P_PROC1); @@ -2816,27 +3029,79 @@ bnx_init_cpus(struct bnx_softc *sc) void bnx_init_context(struct bnx_softc *sc) { - u_int32_t vcid; + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + /* DRC: Replace this constant value with a #define. */ + int i, retry_cnt = 10; + u_int32_t val; + + /* + * BCM5709 context memory may be cached + * in host memory so prepare the host memory + * for access. + */ + val = BNX_CTX_COMMAND_ENABLED | BNX_CTX_COMMAND_MEM_INIT + | (1 << 12); + val |= (BCM_PAGE_BITS - 8) << 16; + REG_WR(sc, BNX_CTX_COMMAND, val); + + /* Wait for mem init command to complete. */ + for (i = 0; i < retry_cnt; i++) { + val = REG_RD(sc, BNX_CTX_COMMAND); + if (!(val & BNX_CTX_COMMAND_MEM_INIT)) + break; + DELAY(2); + } - vcid = 96; - while (vcid) { - u_int32_t vcid_addr, pcid_addr, offset; + /* ToDo: Consider returning an error here. */ + + for (i = 0; i < sc->ctx_pages; i++) { + int j; - vcid--; + /* Set the physaddr of the context memory cache. */ + val = (u_int32_t)(sc->ctx_segs[i].ds_addr); + REG_WR(sc, BNX_CTX_HOST_PAGE_TBL_DATA0, val | + BNX_CTX_HOST_PAGE_TBL_DATA0_VALID); + val = (u_int32_t) + ((u_int64_t)sc->ctx_segs[i].ds_addr >> 32); + REG_WR(sc, BNX_CTX_HOST_PAGE_TBL_DATA1, val); + REG_WR(sc, BNX_CTX_HOST_PAGE_TBL_CTRL, i | + BNX_CTX_HOST_PAGE_TBL_CTRL_WRITE_REQ); + + /* Verify that the context memory write was successful. */ + for (j = 0; j < retry_cnt; j++) { + val = REG_RD(sc, BNX_CTX_HOST_PAGE_TBL_CTRL); + if ((val & BNX_CTX_HOST_PAGE_TBL_CTRL_WRITE_REQ) == 0) + break; + DELAY(5); + } - vcid_addr = GET_CID_ADDR(vcid); - pcid_addr = vcid_addr; + /* ToDo: Consider returning an error here. */ + } + } else { + u_int32_t vcid_addr, offset; - REG_WR(sc, BNX_CTX_VIRT_ADDR, 0x00); - REG_WR(sc, BNX_CTX_PAGE_TBL, pcid_addr); + /* + * For the 5706/5708, context memory is local to + * the controller, so initialize the controller + * context memory. + */ - /* Zero out the context. */ - for (offset = 0; offset < PHY_CTX_SIZE; offset += 4) - CTX_WR(sc, 0x00, offset, 0); + vcid_addr = GET_CID_ADDR(96); + while (vcid_addr) { - REG_WR(sc, BNX_CTX_VIRT_ADDR, vcid_addr); - REG_WR(sc, BNX_CTX_PAGE_TBL, pcid_addr); - } + vcid_addr -= PHY_CTX_SIZE; + + REG_WR(sc, BNX_CTX_VIRT_ADDR, 0); + REG_WR(sc, BNX_CTX_PAGE_TBL, vcid_addr); + + 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, vcid_addr); + } + } } /****************************************************************************/ @@ -2966,6 +3231,7 @@ bnx_stop(struct bnx_softc *sc) int bnx_reset(struct bnx_softc *sc, u_int32_t reset_code) { + struct pci_attach_args *pa = &(sc->bnx_pa); u_int32_t val; int i, rc = 0; @@ -2980,6 +3246,13 @@ bnx_reset(struct bnx_softc *sc, u_int32_t reset_code) val = REG_RD(sc, BNX_MISC_ENABLE_CLR_BITS); DELAY(5); + /* Disable DMA */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + val = REG_RD(sc, BNX_MISC_NEW_CORE_CTL); + val &= ~BNX_MISC_NEW_CORE_CTL_DMA_ENABLE; + REG_WR(sc, BNX_MISC_NEW_CORE_CTL, val); + } + /* Assume bootcode is running. */ sc->bnx_fw_timed_out = 0; @@ -2996,27 +3269,40 @@ bnx_reset(struct bnx_softc *sc, u_int32_t reset_code) 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; - 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) - break; + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + REG_WR(sc, BNX_MISC_COMMAND, BNX_MISC_COMMAND_SW_RESET); + REG_RD(sc, BNX_MISC_COMMAND); + DELAY(5); - DELAY(10); - } + val = BNX_PCICFG_MISC_CONFIG_REG_WINDOW_ENA | + BNX_PCICFG_MISC_CONFIG_TARGET_MB_WORD_SWAP; - /* 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__); - rc = EBUSY; - goto bnx_reset_exit; + pci_conf_write(pa->pa_pc, pa->pa_tag, BNX_PCICFG_MISC_CONFIG, + val); + } else { + val = BNX_PCICFG_MISC_CONFIG_CORE_RST_REQ | + 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) { + 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__); + rc = EBUSY; + goto bnx_reset_exit; + } } /* Make sure byte swapping is properly configured. */ @@ -3083,12 +3369,14 @@ bnx_chipinit(struct bnx_softc *sc) REG_WR(sc, BNX_DMA_CONFIG, val); +#if 1 /* Clear the PCI-X relaxed ordering bit. See errata E3_5708CA0_570. */ if (sc->bnx_flags & BNX_PCIX_FLAG) { 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 & ~0x20000); } +#endif /* Enable the RX_V2P and Context state machines before access. */ REG_WR(sc, BNX_MISC_ENABLE_SET_BITS, @@ -3112,6 +3400,14 @@ bnx_chipinit(struct bnx_softc *sc) val = REG_RD(sc, BNX_MQ_CONFIG); val &= ~BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE; val |= BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_256; + + /* Enable bins used on the 5709. */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + val |= BNX_MQ_CONFIG_BIN_MQ_MODE; + if (BNX_CHIP_ID(sc) == BNX_CHIP_ID_5709_A1) + val |= BNX_MQ_CONFIG_HALT_DIS; + } + REG_WR(sc, BNX_MQ_CONFIG, val); val = 0x10000 + (MAX_CID_CNT * MB_KERNEL_CTX_SIZE); @@ -3127,6 +3423,11 @@ bnx_chipinit(struct bnx_softc *sc) val |= (BCM_PAGE_BITS - 8) << 24 | 0x40; REG_WR(sc, BNX_TBDR_CONFIG, val); +#if 0 + /* Set the perfect match control register to default. */ + REG_WR_IND(sc, BNX_RXP_PM_CTRL, 0); +#endif + bnx_chipinit_exit: DBPRINT(sc, BNX_VERBOSE_RESET, "Exiting %s()\n", __FUNCTION__); @@ -3226,11 +3527,22 @@ bnx_blockinit(struct bnx_softc *sc) DBPRINT(sc, BNX_INFO, "bootcode rev = 0x%08X\n", sc->bnx_fw_ver); + /* Enable DMA */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + val = REG_RD(sc, BNX_MISC_NEW_CORE_CTL); + val |= BNX_MISC_NEW_CORE_CTL_DMA_ENABLE; + REG_WR(sc, BNX_MISC_NEW_CORE_CTL, val); + } + /* Allow bootcode to apply any additional fixes before enabling MAC. */ rc = bnx_fw_sync(sc, BNX_DRV_MSG_DATA_WAIT2 | BNX_DRV_MSG_CODE_RESET); /* Enable link state change interrupt generation. */ - REG_WR(sc, BNX_HC_ATTN_BITS_ENABLE, STATUS_ATTN_BITS_LINK_STATE); + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + REG_WR(sc, BNX_MISC_ENABLE_SET_BITS, + BNX_MISC_ENABLE_DEFAULT_XI); + } else + REG_WR(sc, BNX_MISC_ENABLE_SET_BITS, BNX_MISC_ENABLE_DEFAULT); /* Enable all remaining blocks in the MAC. */ REG_WR(sc, BNX_MISC_ENABLE_SET_BITS, 0x5ffffff); @@ -3410,6 +3722,47 @@ put: } /****************************************************************************/ +/* Initialize the TX context memory. */ +/* */ +/* Returns: */ +/* Nothing */ +/****************************************************************************/ +void +bnx_init_tx_context(struct bnx_softc *sc) +{ + u_int32_t val; + + /* Initialize the context ID for an L2 TX chain. */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + /* Set the CID type to support an L2 connection. */ + val = BNX_L2CTX_TYPE_TYPE_L2 | BNX_L2CTX_TYPE_SIZE_L2; + CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TYPE_XI, val); + val = BNX_L2CTX_CMD_TYPE_TYPE_L2 | (8 << 16); + CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_CMD_TYPE_XI, val); + + /* Point the hardware to the first page in the chain. */ + 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_XI, val); + val = (u_int32_t)(sc->tx_bd_chain_paddr[0]); + CTX_WR(sc, GET_CID_ADDR(TX_CID), + BNX_L2CTX_TBDR_BHADDR_LO_XI, val); + } else { + /* Set the CID type to support an L2 connection. */ + val = BNX_L2CTX_TYPE_TYPE_L2 | BNX_L2CTX_TYPE_SIZE_L2; + CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TYPE, val); + val = BNX_L2CTX_CMD_TYPE_TYPE_L2 | (8 << 16); + CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_CMD_TYPE, val); + + /* Point the hardware to the first page in the chain. */ + 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 = (u_int32_t)(sc->tx_bd_chain_paddr[0]); + CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TBDR_BHADDR_LO, val); + } +} + +/****************************************************************************/ /* Allocate memory and initialize the TX data structures. */ /* */ /* Returns: */ @@ -3419,7 +3772,7 @@ int bnx_init_tx_chain(struct bnx_softc *sc) { struct tx_bd *txbd; - u_int32_t val, addr; + u_int32_t addr; int i, rc = 0; DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__); @@ -3467,20 +3820,7 @@ bnx_init_tx_chain(struct bnx_softc *sc) /* * Initialize the context ID for an L2 TX chain. */ - val = BNX_L2CTX_TYPE_TYPE_L2; - val |= BNX_L2CTX_TYPE_SIZE_L2; - CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_TYPE, val); - - val = BNX_L2CTX_CMD_TYPE_TYPE_L2 | (8 << 16); - CTX_WR(sc, GET_CID_ADDR(TX_CID), BNX_L2CTX_CMD_TYPE, val); - - /* Point the hardware to the first page in the chain. */ - 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 = (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)); + bnx_init_tx_context(sc); DBPRINT(sc, BNX_VERBOSE_RESET, "Exiting %s()\n", __FUNCTION__); @@ -3545,6 +3885,53 @@ bnx_free_tx_chain(struct bnx_softc *sc) } /****************************************************************************/ +/* Initialize the RX context memory. */ +/* */ +/* Returns: */ +/* Nothing */ +/****************************************************************************/ +void +bnx_init_rx_context(struct bnx_softc *sc) +{ + u_int32_t val; + + /* Initialize the context ID for an L2 RX chain. */ + val = BNX_L2CTX_CTX_TYPE_CTX_BD_CHN_TYPE_VALUE | + BNX_L2CTX_CTX_TYPE_SIZE_L2 | (0x02 << 8); + + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + u_int32_t lo_water, hi_water; + + lo_water = BNX_L2CTX_RX_LO_WATER_MARK_DEFAULT; + hi_water = USABLE_RX_BD / 4; + + lo_water /= BNX_L2CTX_RX_LO_WATER_MARK_SCALE; + hi_water /= BNX_L2CTX_RX_HI_WATER_MARK_SCALE; + + if (hi_water > 0xf) + hi_water = 0xf; + else if (hi_water == 0) + lo_water = 0; + val |= lo_water | + (hi_water << BNX_L2CTX_RX_HI_WATER_MARK_SHIFT); + } + + CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_CTX_TYPE, val); + + /* Setup the MQ BIN mapping for l2_ctx_host_bseq. */ + if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) { + val = REG_RD(sc, BNX_MQ_MAP_L2_5); + REG_WR(sc, BNX_MQ_MAP_L2_5, val | BNX_MQ_MAP_L2_5_ARM); + } + + /* Point the hardware to the first page in the chain. */ + 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 = (u_int32_t)(sc->rx_bd_chain_paddr[0]); + CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_NX_BDHADDR_LO, val); +} + +/****************************************************************************/ /* Add mbufs to the RX chain until its full or an mbuf allocation error */ /* occurs. */ /* */ @@ -3609,7 +3996,7 @@ bnx_init_rx_chain(struct bnx_softc *sc) { struct rx_bd *rxbd; int i, rc = 0; - u_int32_t val, addr; + u_int32_t addr; DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __FUNCTION__); @@ -3641,18 +4028,6 @@ bnx_init_rx_chain(struct bnx_softc *sc) rxbd->rx_bd_haddr_lo = htole32(addr); } - /* Initialize the context ID for an L2 RX chain. */ - val = BNX_L2CTX_CTX_TYPE_CTX_BD_CHN_TYPE_VALUE; - val |= BNX_L2CTX_CTX_TYPE_SIZE_L2; - val |= 0x02 << 8; - CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_CTX_TYPE, val); - - /* Point the hardware to the first page in the chain. */ - 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 = (u_int32_t)(sc->rx_bd_chain_paddr[0]); - CTX_WR(sc, GET_CID_ADDR(RX_CID), BNX_L2CTX_NX_BDHADDR_LO, val); - /* Fill up the RX chain. */ bnx_fill_rx_chain(sc); @@ -3661,6 +4036,8 @@ bnx_init_rx_chain(struct bnx_softc *sc) sc->rx_bd_chain_map[i]->dm_mapsize, BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); + bnx_init_rx_context(sc); + DBRUN(BNX_VERBOSE_RECV, bnx_dump_rx_chain(sc, 0, TOTAL_RX_BD)); DBPRINT(sc, BNX_VERBOSE_RESET, "Exiting %s()\n", __FUNCTION__); diff --git a/sys/dev/pci/if_bnxreg.h b/sys/dev/pci/if_bnxreg.h index 2d9b64461b2..c89f253e783 100644 --- a/sys/dev/pci/if_bnxreg.h +++ b/sys/dev/pci/if_bnxreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_bnxreg.h,v 1.30 2009/07/03 04:34:51 dlg Exp $ */ +/* $OpenBSD: if_bnxreg.h,v 1.31 2009/07/03 04:54:05 dlg Exp $ */ /*- * Copyright (c) 2006 Broadcom Corporation @@ -212,7 +212,7 @@ #define BRCM_DEVICEID_BCM5706 0x164A #define BRCM_DEVICEID_BCM5706S 0x16AA #define BRCM_DEVICEID_BCM5708 0x164C -#define BRCM_DEVICEID_BCM5708S 0x16AC +#define BRCM_DEVICEID_BCMj708S 0x16AC #define HP_VENDORID 0x103C @@ -223,6 +223,8 @@ #define BNX_CHIP_NUM(sc) (((sc)->bnx_chipid) & 0xffff0000) #define BNX_CHIP_NUM_5706 0x57060000 #define BNX_CHIP_NUM_5708 0x57080000 +#define BNX_CHIP_NUM_5709 0x57090000 +#define BNX_CHIP_NUM_5716 0x57160000 #define BNX_CHIP_REV(sc) (((sc)->bnx_chipid) & 0x0000f000) #define BNX_CHIP_REV_Ax 0x00000000 @@ -241,6 +243,13 @@ #define BNX_CHIP_ID_5708_B0 0x57081000 #define BNX_CHIP_ID_5708_B1 0x57081010 #define BNX_CHIP_ID_5708_B2 0x57081020 +#define BNX_CHIP_ID_5709_A0 0x57090000 +#define BNX_CHIP_ID_5709_A1 0x57090010 +#define BNX_CHIP_ID_5709_B0 0x57091000 +#define BNX_CHIP_ID_5709_B1 0x57091010 +#define BNX_CHIP_ID_5709_B2 0x57091020 +#define BNX_CHIP_ID_5709_C0 0x57092000 +#define BNX_CHIP_ID_5716_C0 0x57162000 #define BNX_CHIP_BOND_ID(sc) (((sc)->bnx_chipid) & 0xf) @@ -314,6 +323,11 @@ struct bnx_type { #define ST_MICRO_FLASH_PAGE_SIZE 256 #define ST_MICRO_FLASH_BASE_TOTAL_SIZE 65536 +#define BCM5709_FLASH_PAGE_BITS 8 +#define BCM5709_FLASH_PHY_PAGE_SIZE (1 << BCM5709_FLASH_PAGE_BITS) +#define BCM5709_FLASH_BYTE_ADDR_MASK (BCM5709_FLASH_PHY_PAGE_SIZE-1) +#define BCM5709_FLASH_PAGE_SIZE 256 + #define NVRAM_TIMEOUT_COUNT 30000 #define BNX_FLASHDESC_MAX 64 @@ -330,7 +344,10 @@ struct flash_spec { u_int32_t config2; u_int32_t config3; u_int32_t write1; - u_int32_t buffered; +#define BNX_NV_BUFFERED 0x00000001 +#define BNX_NV_TRANSLATE 0x00000002 +#define BNX_NV_WREN 0x00000004 + u_int32_t flags; u_int32_t page_bits; u_int32_t page_size; u_int32_t addr_mask; @@ -359,7 +376,7 @@ struct flash_spec { * running and there won't be any firmware-driver synchronization during a * driver reset. */ -#define FW_ACK_TIME_OUT_MS 100 +#define FW_ACK_TIME_OUT_MS 1000 #define BNX_DRV_RESET_SIGNATURE 0x00000000 @@ -959,6 +976,7 @@ struct l2_fhdr { #define BNX_L2CTX_TYPE_TYPE_EMPTY (0<<28) #define BNX_L2CTX_TYPE_TYPE_L2 (1<<28) +#define BNX_L2CTX_TYPE_XI 0x00000080 #define BNX_L2CTX_TX_HOST_BIDX 0x00000088 #define BNX_L2CTX_EST_NBD 0x00000088 #define BNX_L2CTX_CMD_TYPE 0x00000088 @@ -977,6 +995,9 @@ struct l2_fhdr { #define BNX_L2CTX_TXP_BIDX 0x000000a8 #define BNX_L2CTX_TXP_BSEQ 0x000000ac +#define BNX_L2CTX_CMD_TYPE_XI 0x00000240 +#define BNX_L2CTX_TBDR_BHADDR_HI_XI 0x00000258 +#define BNX_L2CTX_TBDR_BHADDR_LO_XI 0x0000025c /* * l2_bd_chain_context definition @@ -996,6 +1017,47 @@ struct l2_fhdr { #define BNX_L2CTX_NX_BDHADDR_LO 0x00000014 #define BNX_L2CTX_NX_BDIDX 0x00000018 +/* + * l2_rx_context definition (5706, 5708, 5709, and 5716) + */ +#define BNX_L2CTX_RX_WATER_MARK 0x00000000 +#define BNX_L2CTX_RX_LO_WATER_MARK_SHIFT 0 +#define BNX_L2CTX_RX_LO_WATER_MARK_DEFAULT 32 +#define BNX_L2CTX_RX_LO_WATER_MARK_SCALE 4 +#define BNX_L2CTX_RX_LO_WATER_MARK_DIS 0 +#define BNX_L2CTX_RX_HI_WATER_MARK_SHIFT 4 +#define BNX_L2CTX_RX_HI_WATER_MARK_SCALE 16 +#define BNX_L2CTX_RX_WATER_MARKS_MSK 0x000000ff + +#define BNX_L2CTX_RX_BD_PRE_READ 0x00000000 +#define BNX_L2CTX_RX_BD_PRE_READ_SHIFT 8 + +#define BNX_L2CTX_RX_CTX_SIZE 0x00000000 +#define BNX_L2CTX_RX_CTX_SIZE_SHIFT 16 +#define BNX_L2CTX_RX_CTX_TYPE_SIZE_L2 ((0x20/20)<<BNX_L2CTX_RX_CTX_SIZE_SHIFT) + +#define BNX_L2CTX_RX_CTX_TYPE 0x00000000 +#define BNX_L2CTX_RX_CTX_TYPE_SHIFT 24 + +#define BNX_L2CTX_RX_CTX_TYPE_CTX_BD_CHN_TYPE (0xf<<28) +#define BNX_L2CTX_RX_CTX_TYPE_CTX_BD_CHN_TYPE_UNDEFINED (0<<28) +#define BNX_L2CTX_RX_CTX_TYPE_CTX_BD_CHN_TYPE_VALUE (1<<28) + +#define BNX_L2CTX_RX_HOST_BDIDX 0x00000004 +#define BNX_L2CTX_RX_HOST_BSEQ 0x00000008 +#define BNX_L2CTX_RX_NX_BSEQ 0x0000000c +#define BNX_L2CTX_RX_NX_BDHADDR_HI 0x00000010 +#define BNX_L2CTX_RX_NX_BDHADDR_LO 0x00000014 +#define BNX_L2CTX_RX_NX_BDIDX 0x00000018 + +#define BNX_L2CTX_RX_HOST_PG_BDIDX 0x00000044 +#define BNX_L2CTX_RX_PG_BUF_SIZE 0x00000048 +#define BNX_L2CTX_RX_RBDC_KEY 0x0000004c +#define BNX_L2CTX_RX_RBDC_JUMBO_KEY 0x3ffe +#define BNX_L2CTX_RX_NX_PG_BDHADDR_HI 0x00000050 +#define BNX_L2CTX_RX_NX_PG_BDHADDR_LO 0x00000054 +#define BNX_L2CTX_RX_NX_PG_BDIDX 0x00000058 + /* * pci_config_l definition @@ -1259,10 +1321,20 @@ struct l2_fhdr { #define BNX_MISC_COMMAND 0x00000800 #define BNX_MISC_COMMAND_ENABLE_ALL (1L<<0) #define BNX_MISC_COMMAND_DISABLE_ALL (1L<<1) -#define BNX_MISC_COMMAND_CORE_RESET (1L<<4) -#define BNX_MISC_COMMAND_HARD_RESET (1L<<5) +#define BNX_MISC_COMMAND_SW_RESET (1L<<4) +#define BNX_MISC_COMMAND_POR_RESET (1L<<5) +#define BNX_MISC_COMMAND_HD_RESET (1L<<6) +#define BNX_MISC_COMMAND_CMN_SW_RESET (1L<<7) #define BNX_MISC_COMMAND_PAR_ERROR (1L<<8) +#define BNX_MISC_COMMAND_CS16_ERR (1L<<9) +#define BNX_MISC_COMMAND_CS16_ERR_LOC (0xfL<<12) #define BNX_MISC_COMMAND_PAR_ERR_RAM (0x7fL<<16) +#define BNX_MISC_COMMAND_POWERDOWN_EVENT (1L<<23) +#define BNX_MISC_COMMAND_SW_SHUTDOWN (1L<<24) +#define BNX_MISC_COMMAND_SHUTDOWN_EN (1L<<25) +#define BNX_MISC_COMMAND_DINTEG_ATTN_EN (1L<<26) +#define BNX_MISC_COMMAND_PCIE_LINK_IN_L23 (1L<<27) +#define BNX_MISC_COMMAND_PCIE_DIS (1L<<28) #define BNX_MISC_CFG 0x00000804 #define BNX_MISC_CFG_PCI_GRC_TMOUT (1L<<0) @@ -1347,6 +1419,9 @@ struct l2_fhdr { #define BNX_MISC_ENABLE_SET_BITS_DMA_ENGINE_ENABLE (1L<<26) #define BNX_MISC_ENABLE_SET_BITS_UMP_ENABLE (1L<<27) +#define BNX_MISC_ENABLE_DEFAULT 0x05ffffff +#define BNX_MISC_ENABLE_DEFAULT_XI 0x17ffffff + #define BNX_MISC_ENABLE_CLR_BITS 0x00000814 #define BNX_MISC_ENABLE_CLR_BITS_TX_SCHEDULER_ENABLE (1L<<0) #define BNX_MISC_ENABLE_CLR_BITS_TX_BD_READ_ENABLE (1L<<1) @@ -1689,6 +1764,38 @@ struct l2_fhdr { #define BNX_MISC_FINAL_CLK_CTL_VAL 0x000008b8 #define BNX_MISC_FINAL_CLK_CTL_VAL_MISC_FINAL_CLK_CTL_VAL (0x3ffffffL<<6) +#define BNX_MISC_NEW_CORE_CTL 0x000008c8 +#define BNX_MISC_NEW_CORE_CTL_LINK_HOLDOFF_SUCCESS (1L<<0) +#define BNX_MISC_NEW_CORE_CTL_LINK_HOLDOFF_REQ (1L<<1) +#define BNX_MISC_NEW_CORE_CTL_DMA_ENABLE (1L<<16) +#define BNX_MISC_NEW_CORE_CTL_RESERVED_CMN (0x3fffL<<2) +#define BNX_MISC_NEW_CORE_CTL_RESERVED_TC (0xffffL<<16) + +#define BNX_MISC_DUAL_MEDIA_CTRL 0x000008ec +#define BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID (0xffL<<0) +#define BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID_X (0L<<0) +#define BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID_C (3L<<0) +#define BNX_MISC_DUAL_MEDIA_CTRL_BOND_ID_S (12L<<0) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_CTRL_STRAP (0x7L<<8) +#define BNX_MISC_DUAL_MEDIA_CTRL_PORT_SWAP_PIN (1L<<11) +#define BNX_MISC_DUAL_MEDIA_CTRL_SERDES1_SIGDET (1L<<12) +#define BNX_MISC_DUAL_MEDIA_CTRL_SERDES0_SIGDET (1L<<13) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY1_SIGDET (1L<<14) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY0_SIGDET (1L<<15) +#define BNX_MISC_DUAL_MEDIA_CTRL_LCPLL_RST (1L<<16) +#define BNX_MISC_DUAL_MEDIA_CTRL_SERDES1_RST (1L<<17) +#define BNX_MISC_DUAL_MEDIA_CTRL_SERDES0_RST (1L<<18) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY1_RST (1L<<19) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY0_RST (1L<<20) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_CTRL (0x7L<<21) +#define BNX_MISC_DUAL_MEDIA_CTRL_PORT_SWAP (1L<<24) +#define BNX_MISC_DUAL_MEDIA_CTRL_STRAP_OVERRIDE (1L<<25) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_SERDES_IDDQ (0xfL<<26) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_SERDES_IDDQ_SER1_IDDQ (1L<<26) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_SERDES_IDDQ_SER0_IDDQ (2L<<26) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_SERDES_IDDQ_PHY1_IDDQ (4L<<26) +#define BNX_MISC_DUAL_MEDIA_CTRL_PHY_SERDES_IDDQ_PHY0_IDDQ (8L<<26) + #define BNX_MISC_UNUSED0 0x000008bc @@ -2011,8 +2118,27 @@ struct l2_fhdr { * context_reg definition * offset: 0x1000 */ -#define BNX_CTX_COMMAND 0x00001000 -#define BNX_CTX_COMMAND_ENABLED (1L<<0) +#define BNX_CTX_COMMAND 0x00001000 +#define BNX_CTX_COMMAND_ENABLED (1L<<0) +#define BNX_CTX_COMMAND_DISABLE_USAGE_CNT (1L<<1) +#define BNX_CTX_COMMAND_DISABLE_PLRU (1L<<2) +#define BNX_CTX_COMMAND_DISABLE_COMBINE_READ (1L<<3) +#define BNX_CTX_COMMAND_FLUSH_AHEAD (0x1fL<<8) +#define BNX_CTX_COMMAND_MEM_INIT (1L<<13) +#define BNX_CTX_COMMAND_PAGE_SIZE (0xfL<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_256 (0L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_512 (1L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_1K (2L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_2K (3L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_4K (4L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_8K (5L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_16K (6L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_32K (7L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_64K (8L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_128K (9L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_256K (10L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_512K (11L<<16) +#define BNX_CTX_COMMAND_PAGE_SIZE_1M (12L<<16) #define BNX_CTX_STATUS 0x00001004 #define BNX_CTX_STATUS_LOCK_WAIT (1L<<0) @@ -2047,12 +2173,26 @@ struct l2_fhdr { #define BNX_CTX_LOCK_STATUS (1L<<30) #define BNX_CTX_LOCK_REQ (1L<<31) +#define BNX_CTX_CTX_CTRL 0x0000101c +#define BNX_CTX_CTX_CTRL_CTX_ADDR (0x7ffffL<<2) +#define BNX_CTX_CTX_CTRL_MOD_USAGE_CNT (0x3L<<21) +#define BNX_CTX_CTX_CTRL_NO_RAM_ACC (1L<<23) +#define BNX_CTX_CTX_CTRL_PREFETCH_SIZE (0x3L<<24) +#define BNX_CTX_CTX_CTRL_ATTR (1L<<26) +#define BNX_CTX_CTX_CTRL_WRITE_REQ (1L<<30) +#define BNX_CTX_CTX_CTRL_READ_REQ (1L<<31) + +#define BNX_CTX_CTX_DATA 0x00001020 + #define BNX_CTX_ACCESS_STATUS 0x00001040 #define BNX_CTX_ACCESS_STATUS_MASTERENCODED (0xfL<<0) #define BNX_CTX_ACCESS_STATUS_ACCESSMEMORYSM (0x3L<<10) #define BNX_CTX_ACCESS_STATUS_PAGETABLEINITSM (0x3L<<12) #define BNX_CTX_ACCESS_STATUS_ACCESSMEMORYINITSM (0x3L<<14) -#define BNX_CTX_ACCESS_STATUS_QUALIFIED_REQUEST (0x7ffL<<17) +#define BNX_CTX_ACCESS_STATUS_QUALIFIED_REQUEST (0x7ffL<<17) +#define BNX_CTX_ACCESS_STATUS_CAMMASTERENCODED_XI (0x1fL<<0) +#define BNX_CTX_ACCESS_STATUS_CACHEMASTERENCODED_XI (0x1fL<<5) +#define BNX_CTX_ACCESS_STATUS_REQUEST_XI (0x3fffffL<<10) #define BNX_CTX_DBG_LOCK_STATUS 0x00001044 #define BNX_CTX_DBG_LOCK_STATUS_SM (0x3ffL<<0) @@ -2072,6 +2212,17 @@ struct l2_fhdr { #define BNX_CTX_CHNL_LOCK_STATUS_7 0x0000109c #define BNX_CTX_CHNL_LOCK_STATUS_8 0x000010a0 +#define BNX_CTX_CACHE_DATA 0x000010c4 +#define BNX_CTX_HOST_PAGE_TBL_CTRL 0x000010c8 +#define BNX_CTX_HOST_PAGE_TBL_CTRL_PAGE_TBL_ADDR (0x1ffL<<0) +#define BNX_CTX_HOST_PAGE_TBL_CTRL_WRITE_REQ (1L<<30) +#define BNX_CTX_HOST_PAGE_TBL_CTRL_READ_REQ (1L<<31) + +#define BNX_CTX_HOST_PAGE_TBL_DATA0 0x000010cc +#define BNX_CTX_HOST_PAGE_TBL_DATA0_VALID (1L<<0) +#define BNX_CTX_HOST_PAGE_TBL_DATA0_VALUE (0xffffffL<<8) + +#define BNX_CTX_HOST_PAGE_TBL_DATA1 0x000010d0 /* * emac_reg definition @@ -3155,14 +3306,16 @@ struct l2_fhdr { #define BNX_MQ_CONFIG 0x00003c08 #define BNX_MQ_CONFIG_TX_HIGH_PRI (1L<<0) #define BNX_MQ_CONFIG_HALT_DIS (1L<<1) +#define BNX_MQ_CONFIG_BIN_MQ_MODE (1L<<2) +#define BNX_MQ_CONFIG_DIS_IDB_DROP (1L<<3) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE (0x7L<<4) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_256 (0L<<4) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_512 (1L<<4) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_1K (2L<<4) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_2K (3L<<4) #define BNX_MQ_CONFIG_KNL_BYP_BLK_SIZE_4K (4L<<4) -#define BNX_MQ_CONFIG_MAX_DEPTH (0x7fL<<8) -#define BNX_MQ_CONFIG_CUR_DEPTH (0x7fL<<20) +#define BNX_MQ_CONFIG_MAX_DEPTH (0x7fL<<8) +#define BNX_MQ_CONFIG_CUR_DEPTH (0x7fL<<20) #define BNX_MQ_ENQUEUE1 0x00003c0c #define BNX_MQ_ENQUEUE1_OFFSET (0x3fL<<2) @@ -3223,6 +3376,14 @@ struct l2_fhdr { #define BNX_MQ_MEM_RD_DATA2 0x00003c90 #define BNX_MQ_MEM_RD_DATA2_VALUE (0x3fffffffL<<0) +#define BNX_MQ_MAP_L2_5 0x00003d34 +#define BNX_MQ_MAP_L2_5_MQ_OFFSET (0xffL<<0) +#define BNX_MQ_MAP_L2_5_SZ (0x3L<<8) +#define BNX_MQ_MAP_L2_5_CTX_OFFSET (0x2ffL<<10) +#define BNX_MQ_MAP_L2_5_BIN_OFFSET (0x7L<<23) +#define BNX_MQ_MAP_L2_5_ARM (0x3L<<26) +#define BNX_MQ_MAP_L2_5_ENA (0x1L<<31) +#define BNX_MQ_MAP_L2_5_DEFAULT 0x83000b08 /* @@ -4735,6 +4896,14 @@ struct bnx_softc { struct status_block *status_block; /* virtual address */ bus_addr_t status_block_paddr; /* Physical address */ + /* H/W maintained context block */ + int ctx_pages; + bus_dma_segment_t ctx_segs[4]; + int ctx_rsegs[4]; + bus_dmamap_t ctx_map[4]; + void *ctx_block[4]; + + /* Driver maintained status block values. */ u_int16_t last_status_idx; u_int16_t hw_rx_cons; @@ -4947,4 +5116,20 @@ struct bnx_rv2p_header { */ }; +/* + * The RV2P block must be configured for the system + * page size, or more specifically, the number of + * usable rx_bd's per page, and should be called + * as follows prior to loading the RV2P firmware: + * + * BNX_RV2P_PROC2_CHG_MAX_BD_PAGE(USABLE_RX_BD_PER_PAGE) + * + * The default value is 0xFF. + */ +#define BNX_RV2P_PROC2_MAX_BD_PAGE_LOC 5 +#define BNX_RV2P_PROC2_CHG_MAX_BD_PAGE(_rv2p, _v) { \ + _rv2p[BNX_RV2P_PROC2_MAX_BD_PAGE_LOC] = \ + (_rv2p[BNX_RV2P_PROC2_MAX_BD_PAGE_LOC] & ~0xFFFF) | (_v); \ +} + #endif /* #ifndef _BNX_H_DEFINED */ |