Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/rockchip fix access to any busses that may appe...



details:   https://anonhg.NetBSD.org/src/rev/a0af2ed03c40
branches:  trunk
changeset: 999798:a0af2ed03c40
user:      mrg <mrg%NetBSD.org@localhost>
date:      Wed Jun 19 05:33:14 2019 +0000

description:
fix access to any busses that may appear beyond the bus the 4x slot see.
only the root bus and the slot's bus are limited to device = 0.

diffstat:

 sys/arch/arm/rockchip/rk3399_pcie.c |  47 ++++++++++++++++++++----------------
 1 files changed, 26 insertions(+), 21 deletions(-)

diffs (97 lines):

diff -r f5d2f09106eb -r a0af2ed03c40 sys/arch/arm/rockchip/rk3399_pcie.c
--- a/sys/arch/arm/rockchip/rk3399_pcie.c       Wed Jun 19 05:31:05 2019 +0000
+++ b/sys/arch/arm/rockchip/rk3399_pcie.c       Wed Jun 19 05:33:14 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk3399_pcie.c,v 1.4 2019/06/15 00:08:25 jmcneill Exp $ */
+/* $NetBSD: rk3399_pcie.c,v 1.5 2019/06/19 05:33:14 mrg Exp $ */
 /*
  * Copyright (c) 2018 Mark Kettenis <kettenis%openbsd.org@localhost>
  *
@@ -17,7 +17,7 @@
 
 #include <sys/cdefs.h>
 
-__KERNEL_RCSID(1, "$NetBSD: rk3399_pcie.c,v 1.4 2019/06/15 00:08:25 jmcneill Exp $");
+__KERNEL_RCSID(1, "$NetBSD: rk3399_pcie.c,v 1.5 2019/06/19 05:33:14 mrg Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -118,9 +118,13 @@
 #define PCIE_ATR_OB_REGION_SIZE                (1 * 1024 * 1024)
 
 #define HREAD4(sc, reg)                                                        \
-       (bus_space_read_4((sc)->sc_iot, (sc)->sc_ioh, (reg)))
+       bus_space_read_4((sc)->sc_iot, (sc)->sc_ioh, (reg))
 #define HWRITE4(sc, reg, val)                                          \
        bus_space_write_4((sc)->sc_iot, (sc)->sc_ioh, (reg), (val))
+#define AXIREAD4(sc, reg)                                              \
+       bus_space_read_4((sc)->sc_iot, (sc)->sc_axi_ioh, (reg))
+#define AXIWRITE4(sc, reg, val)                                                \
+       bus_space_write_4((sc)->sc_iot, (sc)->sc_axi_ioh, (reg), (val))
 
 struct rkpcie_softc {
        struct pcihost_softc    sc_phsc;
@@ -508,6 +512,15 @@
                *fp = (tag >> 12) & 0x7;
 }
 
+/* Only one device on root port and the first subordinate port. */
+static bool
+rkpcie_conf_ok(int bus, int dev, int fn, int bus_min)
+{
+       if (dev != 0 && (bus == bus_min || bus == bus_min + 1))
+               return false;
+       return true;
+}
+
 pcireg_t
 rkpcie_conf_read(void *v, pcitag_t tag, int offset)
 {
@@ -520,18 +533,14 @@
        KASSERT(offset < PCI_EXTCONF_SIZE);
 
        rkpcie_decompose_tag(sc, tag, &bus, &dev, &fn);
+       if (!rkpcie_conf_ok(bus, dev, fn, phsc->sc_bus_min))
+               return 0xffffffff;
        reg = (bus << 20) | (dev << 15) | (fn << 12) | offset;
 
-       if (bus == phsc->sc_bus_min) {
-               KASSERT(dev == 0);
+       if (bus == phsc->sc_bus_min)
                return HREAD4(sc, PCIE_RC_NORMAL_BASE + reg);
-       }
-       if (bus == phsc->sc_bus_min + 1) {
-               KASSERT(dev == 0);
-               return bus_space_read_4(sc->sc_iot, sc->sc_axi_ioh, reg);
-       }
-
-       return 0xffffffff;
+       else
+               return AXIREAD4(sc, reg);
 }
 
 void
@@ -546,18 +555,14 @@
        KASSERT(offset < PCI_EXTCONF_SIZE);
 
        rkpcie_decompose_tag(sc, tag, &bus, &dev, &fn);
+       if (!rkpcie_conf_ok(bus, dev, fn, phsc->sc_bus_min))
+               return;
        reg = (bus << 20) | (dev << 15) | (fn << 12) | offset;
 
-       if (bus == phsc->sc_bus_min) {
-               KASSERT(dev == 0);
+       if (bus == phsc->sc_bus_min)
                HWRITE4(sc, PCIE_RC_NORMAL_BASE + reg, data);
-               return;
-       }
-       if (bus == phsc->sc_bus_min + 1) {
-               KASSERT(dev == 0);
-               bus_space_write_4(sc->sc_iot, sc->sc_axi_ioh, reg, data);
-               return;
-       }
+       else
+               AXIWRITE4(sc, reg, data);
 }
 
 static int



Home | Main Index | Thread Index | Old Index