Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/acpi Add support for PCI Segment Groups.
details: https://anonhg.NetBSD.org/src/rev/812ed54d6a1a
branches: trunk
changeset: 994096:812ed54d6a1a
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Fri Oct 19 11:40:27 2018 +0000
description:
Add support for PCI Segment Groups.
diffstat:
sys/arch/arm/acpi/acpi_pci_machdep.c | 16 +++++++++++-----
sys/arch/arm/acpi/acpi_pci_machdep.h | 7 ++++++-
sys/arch/arm/acpi/acpipchb.c | 28 +++++++++++++++++++---------
3 files changed, 36 insertions(+), 15 deletions(-)
diffs (178 lines):
diff -r 3ecb97c918a8 -r 812ed54d6a1a sys/arch/arm/acpi/acpi_pci_machdep.c
--- a/sys/arch/arm/acpi/acpi_pci_machdep.c Fri Oct 19 11:11:03 2018 +0000
+++ b/sys/arch/arm/acpi/acpi_pci_machdep.c Fri Oct 19 11:40:27 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_pci_machdep.c,v 1.1 2018/10/15 11:35:03 jmcneill Exp $ */
+/* $NetBSD: acpi_pci_machdep.c,v 1.2 2018/10/19 11:40:27 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_pci_machdep.c,v 1.1 2018/10/15 11:35:03 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_pci_machdep.c,v 1.2 2018/10/19 11:40:27 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -55,6 +55,8 @@
#include <dev/acpi/acpi_mcfg.h>
#include <dev/acpi/acpi_pci.h>
+#include <arm/acpi/acpi_pci_machdep.h>
+
#define IH_INDEX_MASK 0x0000ffff
#define IH_MPSAFE 0x80000000
@@ -150,12 +152,13 @@
acpi_pci_md_attach_hook(device_t parent, device_t self,
struct pcibus_attach_args *pba)
{
+ struct acpi_pci_context *ap = pba->pba_pc->pc_conf_v;
struct acpi_pci_prt *prt, *prtp;
struct acpi_devnode *ad;
ACPI_HANDLE handle;
int seg, bus, dev, func;
- seg = 0; /* XXX segment */
+ seg = ap->ap_seg;
handle = NULL;
if (pba->pba_bridgetag) {
@@ -228,12 +231,13 @@
static pcireg_t
acpi_pci_md_conf_read(void *v, pcitag_t tag, int offset)
{
+ struct acpi_pci_context * const ap = v;
pcireg_t val;
if (offset < 0 || offset >= PCI_EXTCONF_SIZE)
return (pcireg_t) -1;
- acpimcfg_conf_read(&arm_acpi_pci_chipset, tag, offset, &val);
+ acpimcfg_conf_read(&ap->ap_pc, tag, offset, &val);
return val;
}
@@ -241,10 +245,12 @@
static void
acpi_pci_md_conf_write(void *v, pcitag_t tag, int offset, pcireg_t val)
{
+ struct acpi_pci_context * const ap = v;
+
if (offset < 0 || offset >= PCI_EXTCONF_SIZE)
return;
- acpimcfg_conf_write(&arm_acpi_pci_chipset, tag, offset, val);
+ acpimcfg_conf_write(&ap->ap_pc, tag, offset, val);
}
static int
diff -r 3ecb97c918a8 -r 812ed54d6a1a sys/arch/arm/acpi/acpi_pci_machdep.h
--- a/sys/arch/arm/acpi/acpi_pci_machdep.h Fri Oct 19 11:11:03 2018 +0000
+++ b/sys/arch/arm/acpi/acpi_pci_machdep.h Fri Oct 19 11:40:27 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_pci_machdep.h,v 1.1 2018/10/15 11:35:03 jmcneill Exp $ */
+/* $NetBSD: acpi_pci_machdep.h,v 1.2 2018/10/19 11:40:27 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -34,4 +34,9 @@
extern struct arm32_pci_chipset arm_acpi_pci_chipset;
+struct acpi_pci_context {
+ struct arm32_pci_chipset ap_pc;
+ u_int ap_seg;
+};
+
#endif /* !_ARM_ACPI_PCI_MACHDEP_H */
diff -r 3ecb97c918a8 -r 812ed54d6a1a sys/arch/arm/acpi/acpipchb.c
--- a/sys/arch/arm/acpi/acpipchb.c Fri Oct 19 11:11:03 2018 +0000
+++ b/sys/arch/arm/acpi/acpipchb.c Fri Oct 19 11:40:27 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpipchb.c,v 1.1 2018/10/15 11:35:03 jmcneill Exp $ */
+/* $NetBSD: acpipchb.c,v 1.2 2018/10/19 11:40:27 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpipchb.c,v 1.1 2018/10/15 11:35:03 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpipchb.c,v 1.2 2018/10/19 11:40:27 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -54,12 +54,15 @@
#include <dev/acpi/acpivar.h>
#include <dev/acpi/acpi_mcfg.h>
+#include <arm/acpi/acpi_pci_machdep.h>
+
#define PCIHOST_CACHELINE_SIZE arm_dcache_align
struct acpipchb_softc {
device_t sc_dev;
struct arm32_bus_dma_tag sc_dmat;
+ struct acpi_pci_context sc_ap;
ACPI_HANDLE sc_handle;
ACPI_INTEGER sc_bus;
@@ -102,7 +105,7 @@
struct acpipchb_softc * const sc = device_private(self);
struct acpi_attach_args *aa = aux;
struct pcibus_attach_args pba;
- ACPI_INTEGER cca;
+ ACPI_INTEGER cca, seg;
sc->sc_dev = self;
sc->sc_handle = aa->aa_node->ad_handle;
@@ -110,23 +113,30 @@
if (ACPI_FAILURE(acpi_eval_integer(sc->sc_handle, "_BBN", &sc->sc_bus)))
sc->sc_bus = 0;
+ if (ACPI_FAILURE(acpi_eval_integer(sc->sc_handle, "_SEG", &seg)))
+ seg = 0;
+
if (ACPI_FAILURE(acpi_eval_integer(sc->sc_handle, "_CCA", &cca)))
cca = 0;
aprint_naive("\n");
aprint_normal(": PCI Express Host Bridge\n");
- if (acpimcfg_configure_bus(self, aa->aa_pc, sc->sc_handle, sc->sc_bus, PCIHOST_CACHELINE_SIZE) != 0) {
- aprint_error_dev(self, "failed to configure PCI bus\n");
- return;
- }
-
sc->sc_dmat = *aa->aa_dmat;
if (cca) {
sc->sc_dmat._ranges = ahcipchb_coherent_ranges;
sc->sc_dmat._nranges = __arraycount(ahcipchb_coherent_ranges);
}
+ sc->sc_ap.ap_pc = *aa->aa_pc;
+ sc->sc_ap.ap_pc.pc_conf_v = &sc->sc_ap;
+ sc->sc_ap.ap_seg = seg;
+
+ if (acpimcfg_configure_bus(self, &sc->sc_ap.ap_pc, sc->sc_handle, sc->sc_bus, PCIHOST_CACHELINE_SIZE) != 0) {
+ aprint_error_dev(self, "failed to configure PCI bus\n");
+ return;
+ }
+
memset(&pba, 0, sizeof(pba));
pba.pba_flags = aa->aa_pciflags;
pba.pba_iot = aa->aa_iot;
@@ -135,7 +145,7 @@
#ifdef _PCI_HAVE_DMA64
pba.pba_dmat64 = &sc->sc_dmat;
#endif
- pba.pba_pc = aa->aa_pc;
+ pba.pba_pc = &sc->sc_ap.ap_pc;
pba.pba_bus = sc->sc_bus;
config_found_ia(self, "pcibus", &pba, pcibusprint);
Home |
Main Index |
Thread Index |
Old Index