summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2021-10-04 19:04:13 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2021-10-04 19:04:13 +0000
commit7f99986f968daa2d55219ff3149d13ecca4b6a20 (patch)
tree203297a5d4d5947ac02d81119e85b3e9182ba077
parent791d50fd7be74738094a10cf7193740e5950b983 (diff)
Allegedly a "Marvell Armada 3700 Functional Errata, Guidelines, and
Restrictions" document exists that discusses an errata #251 in section "3.12 PCIe Completion Timeout" and suggests that setting the DIS_ORD_CHK flag in the Debug Mux Control register is necessary as a workaround: https://lore.kernel.org/linux-pci/20210624222621.4776-6-pali@kernel.org This workaround is still being discussed by the Linux developers, but it does fix an issue I am seeing with athn(4), where an external abort happens under load. So apply this workaround since its potential side effects seem to be significantly less severe than provoking an external abort that hangs the machine. ok patrick@
-rw-r--r--sys/dev/fdt/mvkpcie.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/sys/dev/fdt/mvkpcie.c b/sys/dev/fdt/mvkpcie.c
index 011531af4eb..fd49ef2baff 100644
--- a/sys/dev/fdt/mvkpcie.c
+++ b/sys/dev/fdt/mvkpcie.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mvkpcie.c,v 1.10 2021/05/17 17:25:13 kettenis Exp $ */
+/* $OpenBSD: mvkpcie.c,v 1.11 2021/10/04 19:04:12 kettenis Exp $ */
/*
* Copyright (c) 2018 Mark Kettenis <kettenis@openbsd.org>
* Copyright (c) 2020 Patrick Wildt <patrick@blueri.se>
@@ -113,6 +113,8 @@
#define LMI_CFG 0x6000
#define LMI_CFG_LTSSM_VAL(x) (((x) >> 24) & 0x3f)
#define LMI_CFG_LTSSM_L0 0x10
+#define LMI_DEBUG_CTRL 0x6208
+#define LMI_DEBUG_CTRL_DIS_ORD_CHK (1 << 30)
#define CTRL_CORE_CONFIG 0x18000
#define CTRL_CORE_CONFIG_MODE_DIRECT (0 << 0)
#define CTRL_CORE_CONFIG_MODE_COMMAND (1 << 0)
@@ -392,6 +394,10 @@ mvkpcie_attach(struct device *parent, struct device *self, void *aux)
PCIE_CORE_CTRL2_RESERVED |
PCIE_CORE_CTRL2_TD_ENABLE);
+ reg = HREAD4(sc, LMI_DEBUG_CTRL);
+ reg |= LMI_DEBUG_CTRL_DIS_ORD_CHK;
+ HWRITE4(sc, LMI_DEBUG_CTRL, reg);
+
reg = HREAD4(sc, PCIE_CORE_CTRL0);
reg &= ~PCIE_CORE_CTRL0_GEN_MASK;
reg |= PCIE_CORE_CTRL0_GEN_2;