Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm Support building kernels with ACPI and no PCI.
details: https://anonhg.NetBSD.org/src/rev/ae5c4a5f20d0
branches: trunk
changeset: 994534:ae5c4a5f20d0
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Mon Nov 12 12:56:05 2018 +0000
description:
Support building kernels with ACPI and no PCI.
diffstat:
sys/arch/arm/acpi/acpi_machdep.c | 10 ++++++++--
sys/arch/arm/acpi/files.acpi | 4 ++--
sys/arch/arm/acpi/gic_acpi.c | 16 ++++++++++++----
sys/arch/arm/acpi/gicv3_acpi.c | 12 ++++++++++--
sys/arch/arm/cortex/files.cortex | 4 ++--
sys/arch/arm/fdt/acpi_fdt.c | 18 +++++++++++-------
6 files changed, 45 insertions(+), 19 deletions(-)
diffs (252 lines):
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/acpi/acpi_machdep.c
--- a/sys/arch/arm/acpi/acpi_machdep.c Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/acpi/acpi_machdep.c Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.c,v 1.4 2018/10/21 13:34:33 jmcneill Exp $ */
+/* $NetBSD: acpi_machdep.c,v 1.5 2018/11/12 12:56:05 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -29,8 +29,10 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
+#include "pci.h"
+
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.4 2018/10/21 13:34:33 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.5 2018/11/12 12:56:05 jmcneill Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -44,7 +46,9 @@
#include <dev/acpi/acpica.h>
#include <dev/acpi/acpivar.h>
+#if NPCI > 0
#include <dev/acpi/acpi_mcfg.h>
+#endif
#include <arm/pic/picvar.h>
@@ -252,7 +256,9 @@
{
ACPI_TABLE_HEADER *hdrp;
+#if NPCI > 0
acpimcfg_init(&arm_generic_bs_tag, NULL);
+#endif
if (acpi_madt_map() != AE_OK)
panic("Failed to map MADT");
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/acpi/files.acpi
--- a/sys/arch/arm/acpi/files.acpi Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/acpi/files.acpi Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.acpi,v 1.4 2018/10/24 11:01:47 jmcneill Exp $
+# $NetBSD: files.acpi,v 1.5 2018/11/12 12:56:05 jmcneill Exp $
#
# Configuration info for ACPI compliant ARM boards.
#
@@ -11,7 +11,7 @@
include "dev/acpi/files.acpi"
file arch/arm/acpi/acpi_machdep.c acpi
-file arch/arm/acpi/acpi_pci_machdep.c acpi
+file arch/arm/acpi/acpi_pci_machdep.c acpi & pci
file arch/arm/acpi/acpi_platform.c acpi
file arch/arm/acpi/acpi_table.c acpi
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/acpi/gic_acpi.c
--- a/sys/arch/arm/acpi/gic_acpi.c Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/acpi/gic_acpi.c Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gic_acpi.c,v 1.2 2018/10/21 00:42:05 jmcneill Exp $ */
+/* $NetBSD: gic_acpi.c,v 1.3 2018/11/12 12:56:05 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -29,8 +29,10 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
+#include "pci.h"
+
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gic_acpi.c,v 1.2 2018/10/21 00:42:05 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gic_acpi.c,v 1.3 2018/11/12 12:56:05 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -59,7 +61,9 @@
static void gic_acpi_attach(device_t, device_t, void *);
static ACPI_STATUS gic_acpi_find_gicc(ACPI_SUBTABLE_HEADER *, void *);
+#if NPCI > 0
static ACPI_STATUS gic_acpi_find_msi_frame(ACPI_SUBTABLE_HEADER *, void *);
+#endif
CFATTACH_DECL_NEW(gic_acpi, 0, gic_acpi_match, gic_acpi_attach, NULL, NULL);
@@ -122,10 +126,12 @@
};
armgic = config_found(self, &mpcaa, NULL);
+ if (armgic != NULL)
+ arm_fdt_irq_set_handler(armgic_irq_handler);
- arm_fdt_irq_set_handler(armgic_irq_handler);
-
+#if NPCI > 0
acpi_madt_walk(gic_acpi_find_msi_frame, armgic);
+#endif
}
static ACPI_STATUS
@@ -141,6 +147,7 @@
return AE_LIMIT;
}
+#if NPCI > 0
static ACPI_STATUS
gic_acpi_find_msi_frame(ACPI_SUBTABLE_HEADER *hdrp, void *aux)
{
@@ -181,3 +188,4 @@
return AE_OK;
}
+#endif
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/acpi/gicv3_acpi.c
--- a/sys/arch/arm/acpi/gicv3_acpi.c Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/acpi/gicv3_acpi.c Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gicv3_acpi.c,v 1.2 2018/11/09 23:36:58 jmcneill Exp $ */
+/* $NetBSD: gicv3_acpi.c,v 1.3 2018/11/12 12:56:05 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -29,10 +29,12 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
+#include "pci.h"
+
#define _INTR_PRIVATE
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gicv3_acpi.c,v 1.2 2018/11/09 23:36:58 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gicv3_acpi.c,v 1.3 2018/11/12 12:56:05 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -68,7 +70,9 @@
static int gicv3_acpi_map_dist(struct gicv3_acpi_softc *);
static int gicv3_acpi_map_redist(struct gicv3_acpi_softc *);
+#if NPCI > 0
static int gicv3_acpi_map_its(struct gicv3_acpi_softc *);
+#endif
CFATTACH_DECL_NEW(gicv3_acpi, sizeof(struct gicv3_acpi_softc), gicv3_acpi_match, gicv3_acpi_attach, NULL, NULL);
@@ -127,7 +131,9 @@
return;
}
+#if NPCI > 0
gicv3_acpi_map_its(sc);
+#endif
arm_fdt_irq_set_handler(gicv3_irq_handler);
}
@@ -272,6 +278,7 @@
return 0;
}
+#if NPCI > 0
static ACPI_STATUS
gicv3_acpi_map_gits(ACPI_SUBTABLE_HEADER *hdrp, void *aux)
{
@@ -304,3 +311,4 @@
return 0;
}
+#endif
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/cortex/files.cortex
--- a/sys/arch/arm/cortex/files.cortex Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/cortex/files.cortex Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.cortex,v 1.10 2018/11/09 23:36:24 jmcneill Exp $
+# $NetBSD: files.cortex,v 1.11 2018/11/12 12:56:05 jmcneill Exp $
defflag opt_cpu_in_cksum.h NEON_IN_CKSUM
@@ -20,7 +20,7 @@
# ARM Generic Interrupt Controller v3+
device gicvthree: pic, pic_splfuncs
file arch/arm/cortex/gicv3.c gicvthree
-file arch/arm/cortex/gicv3_its.c gicvthree
+file arch/arm/cortex/gicv3_its.c gicvthree & pci & __have_pci_msi_msix
# ARM PL310 L2 Cache Controller(initially on Cortex-A9)
device arml2cc
diff -r 10ae675f3975 -r ae5c4a5f20d0 sys/arch/arm/fdt/acpi_fdt.c
--- a/sys/arch/arm/fdt/acpi_fdt.c Mon Nov 12 12:41:03 2018 +0000
+++ b/sys/arch/arm/fdt/acpi_fdt.c Mon Nov 12 12:56:05 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_fdt.c,v 1.8 2018/10/31 15:42:54 jmcneill Exp $ */
+/* $NetBSD: acpi_fdt.c,v 1.9 2018/11/12 12:56:05 jmcneill Exp $ */
/*-
* Copyright (c) 2015-2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -26,10 +26,11 @@
* SUCH DAMAGE.
*/
+#include "pci.h"
#include "opt_efi.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_fdt.c,v 1.8 2018/10/31 15:42:54 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_fdt.c,v 1.9 2018/11/12 12:56:05 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -69,7 +70,9 @@
static void acpi_fdt_sysctl_init(void);
+#if NPCI > 0
static struct acpi_pci_context acpi_fdt_pci_context;
+#endif
static uint64_t smbios_table = 0;
@@ -115,13 +118,11 @@
if (!acpi_probe())
aprint_error_dev(self, "failed to probe ACPI\n");
+ memset(&aa, 0, sizeof(aa));
+#if NPCI > 0
acpi_fdt_pci_context.ap_pc = arm_acpi_pci_chipset;
acpi_fdt_pci_context.ap_pc.pc_conf_v = &acpi_fdt_pci_context;
acpi_fdt_pci_context.ap_seg = 0;
-
- aa.aa_iot = 0;
- aa.aa_memt = faa->faa_bst;
- aa.aa_pc = &acpi_fdt_pci_context.ap_pc;
aa.aa_pciflags =
/*PCI_FLAGS_IO_OKAY |*/ PCI_FLAGS_MEM_OKAY |
PCI_FLAGS_MRL_OKAY | PCI_FLAGS_MRM_OKAY |
@@ -129,7 +130,10 @@
#ifdef __HAVE_PCI_MSI_MSIX
aa.aa_pciflags |= PCI_FLAGS_MSI_OKAY | PCI_FLAGS_MSIX_OKAY;
#endif
- aa.aa_ic = 0;
+ aa.aa_pc = &acpi_fdt_pci_context.ap_pc;
+#endif
+
+ aa.aa_memt = faa->faa_bst;
aa.aa_dmat = faa->faa_dmat;
#ifdef _PCI_HAVE_DMA64
aa.aa_dmat64 = faa->faa_dmat;
Home |
Main Index |
Thread Index |
Old Index