Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci BCM5709 is PCIe based. To wait for pending PCI t...
details: https://anonhg.NetBSD.org/src/rev/4a6a70e5c482
branches: trunk
changeset: 455516:4a6a70e5c482
user: msaitoh <msaitoh%NetBSD.org@localhost>
date: Fri Apr 05 07:25:06 2019 +0000
description:
BCM5709 is PCIe based. To wait for pending PCI transactions to complete,
wait until PCIe's transaction pending bit is cleared.
diffstat:
sys/dev/pci/if_bnx.c | 33 +++++++++++++++++++++------------
1 files changed, 21 insertions(+), 12 deletions(-)
diffs (57 lines):
diff -r 4e2e135ad1c3 -r 4a6a70e5c482 sys/dev/pci/if_bnx.c
--- a/sys/dev/pci/if_bnx.c Fri Apr 05 07:15:26 2019 +0000
+++ b/sys/dev/pci/if_bnx.c Fri Apr 05 07:25:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_bnx.c,v 1.78 2019/04/05 07:15:26 msaitoh Exp $ */
+/* $NetBSD: if_bnx.c,v 1.79 2019/04/05 07:25:06 msaitoh Exp $ */
/* $OpenBSD: if_bnx.c,v 1.101 2013/03/28 17:21:44 brad Exp $ */
/*-
@@ -35,7 +35,7 @@
#if 0
__FBSDID("$FreeBSD: src/sys/dev/bce/if_bce.c,v 1.3 2006/04/13 14:12:26 ru Exp $");
#endif
-__KERNEL_RCSID(0, "$NetBSD: if_bnx.c,v 1.78 2019/04/05 07:15:26 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_bnx.c,v 1.79 2019/04/05 07:25:06 msaitoh Exp $");
/*
* The following controllers are supported by this driver:
@@ -3525,19 +3525,28 @@
DBPRINT(sc, BNX_VERBOSE_RESET, "Entering %s()\n", __func__);
/* 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);
- val = REG_RD(sc, BNX_MISC_ENABLE_CLR_BITS);
- DELAY(5);
-
- /* Disable DMA */
- if (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5709) {
+ if ((BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5706) ||
+ (BNX_CHIP_NUM(sc) == BNX_CHIP_NUM_5708)) {
+ 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);
+ val = REG_RD(sc, BNX_MISC_ENABLE_CLR_BITS);
+ DELAY(5);
+ } else {
+ /* Disable DMA */
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);
+ REG_RD(sc, BNX_MISC_NEW_CORE_CTL); /* barrier */
+
+ for (i = 0; i < 100; i++) {
+ delay(1 * 1000);
+ val = REG_RD(sc, BNX_PCICFG_DEVICE_CONTROL);
+ if ((val & PCIE_DCSR_TRANSACTION_PND) == 0)
+ break;
+ }
}
/* Assume bootcode is running. */
Home |
Main Index |
Thread Index |
Old Index