Module Name: src
Committed By: jmcneill
Date: Sun Dec 29 23:47:56 UTC 2019
Modified Files:
src/sys/arch/arm/acpi: acpi_machdep.c acpipchb.c
src/sys/arch/arm/fdt: acpi_fdt.c
src/sys/dev/acpi: acpi.c acpivar.h
Log Message:
Allow MD code to provide custom bus_dma tags on a per-node basis. On Arm
this is required to return non-coherent bus_dma tags for device nodes with
_CCA=0
To generate a diff of this commit:
cvs rdiff -u -r1.13 -r1.14 src/sys/arch/arm/acpi/acpi_machdep.c
cvs rdiff -u -r1.14 -r1.15 src/sys/arch/arm/acpi/acpipchb.c
cvs rdiff -u -r1.12 -r1.13 src/sys/arch/arm/fdt/acpi_fdt.c
cvs rdiff -u -r1.278 -r1.279 src/sys/dev/acpi/acpi.c
cvs rdiff -u -r1.77 -r1.78 src/sys/dev/acpi/acpivar.h
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/arm/acpi/acpi_machdep.c
diff -u src/sys/arch/arm/acpi/acpi_machdep.c:1.13 src/sys/arch/arm/acpi/acpi_machdep.c:1.14
--- src/sys/arch/arm/acpi/acpi_machdep.c:1.13 Sat Dec 28 17:19:43 2019
+++ src/sys/arch/arm/acpi/acpi_machdep.c Sun Dec 29 23:47:56 2019
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.c,v 1.13 2019/12/28 17:19:43 jmcneill Exp $ */
+/* $NetBSD: acpi_machdep.c,v 1.14 2019/12/29 23:47:56 jmcneill Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
#include "pci.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.13 2019/12/28 17:19:43 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.14 2019/12/29 23:47:56 jmcneill Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -59,6 +59,10 @@ __KERNEL_RCSID(0, "$NetBSD: acpi_machdep
#include <machine/acpi_machdep.h>
extern struct bus_space arm_generic_bs_tag;
+extern struct arm32_bus_dma_tag acpi_coherent_dma_tag;
+extern struct arm32_bus_dma_tag arm_generic_dma_tag;
+
+bus_dma_tag_t arm_acpi_dma_tag(struct acpi_softc *, struct acpi_devnode *);
static int
acpi_md_pmapflags(paddr_t pa)
@@ -362,3 +366,19 @@ acpi_md_callback(struct acpi_softc *sc)
if (ACPI_SUCCESS(AcpiGetTable(ACPI_SIG_GTDT, 0, &hdrp)))
config_found_ia(sc->sc_dev, "acpisdtbus", hdrp, NULL);
}
+
+bus_dma_tag_t
+arm_acpi_dma_tag(struct acpi_softc *sc, struct acpi_devnode *ad)
+{
+ ACPI_INTEGER cca;
+
+ if (ACPI_FAILURE(acpi_eval_integer(ad->ad_handle, "_CCA", &cca)))
+ cca = 1;
+
+ if (cca)
+ return &acpi_coherent_dma_tag;
+ else
+ return &arm_generic_dma_tag;
+}
+__strong_alias(acpi_get_dma_tag,arm_acpi_dma_tag);
+__strong_alias(acpi_get_dma64_tag,arm_acpi_dma_tag);
Index: src/sys/arch/arm/acpi/acpipchb.c
diff -u src/sys/arch/arm/acpi/acpipchb.c:1.14 src/sys/arch/arm/acpi/acpipchb.c:1.15
--- src/sys/arch/arm/acpi/acpipchb.c:1.14 Sat Dec 28 17:19:43 2019
+++ src/sys/arch/arm/acpi/acpipchb.c Sun Dec 29 23:47:56 2019
@@ -1,4 +1,4 @@
-/* $NetBSD: acpipchb.c,v 1.14 2019/12/28 17:19:43 jmcneill Exp $ */
+/* $NetBSD: acpipchb.c,v 1.15 2019/12/29 23:47:56 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.14 2019/12/28 17:19:43 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpipchb.c,v 1.15 2019/12/29 23:47:56 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -242,7 +242,7 @@ acpipchb_attach(device_t parent, device_
struct acpi_attach_args *aa = aux;
struct pcibus_attach_args pba;
const struct acpipchb_quirk *q;
- ACPI_INTEGER cca, seg;
+ ACPI_INTEGER seg;
sc->sc_dev = self;
sc->sc_memt = aa->aa_memt;
@@ -254,15 +254,10 @@ acpipchb_attach(device_t parent, device_
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 = 1;
-
aprint_naive("\n");
aprint_normal(": PCI Express Host Bridge\n");
sc->sc_dmat = *aa->aa_dmat;
- if (cca == 0)
- sc->sc_dmat._nranges = 0;
sc->sc_ap.ap_dev = self;
sc->sc_ap.ap_pc = *aa->aa_pc;
Index: src/sys/arch/arm/fdt/acpi_fdt.c
diff -u src/sys/arch/arm/fdt/acpi_fdt.c:1.12 src/sys/arch/arm/fdt/acpi_fdt.c:1.13
--- src/sys/arch/arm/fdt/acpi_fdt.c:1.12 Sat Jun 22 19:47:27 2019
+++ src/sys/arch/arm/fdt/acpi_fdt.c Sun Dec 29 23:47:56 2019
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_fdt.c,v 1.12 2019/06/22 19:47:27 jmcneill Exp $ */
+/* $NetBSD: acpi_fdt.c,v 1.13 2019/12/29 23:47:56 jmcneill Exp $ */
/*-
* Copyright (c) 2015-2017 Jared McNeill <[email protected]>
@@ -30,7 +30,7 @@
#include "opt_efi.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_fdt.c,v 1.12 2019/06/22 19:47:27 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_fdt.c,v 1.13 2019/12/29 23:47:56 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -136,10 +136,8 @@ acpi_fdt_attach(device_t parent, device_
#endif
aa.aa_memt = faa->faa_bst;
- aa.aa_dmat = &acpi_coherent_dma_tag;
-#ifdef _PCI_HAVE_DMA64
- aa.aa_dmat64 = &acpi_coherent_dma_tag;
-#endif
+ aa.aa_dmat = NULL;
+ aa.aa_dmat64 = NULL;
config_found_ia(self, "acpibus", &aa, 0);
acpi_fdt_sysctl_init();
Index: src/sys/dev/acpi/acpi.c
diff -u src/sys/dev/acpi/acpi.c:1.278 src/sys/dev/acpi/acpi.c:1.279
--- src/sys/dev/acpi/acpi.c:1.278 Sun Oct 21 13:41:15 2018
+++ src/sys/dev/acpi/acpi.c Sun Dec 29 23:47:56 2019
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi.c,v 1.278 2018/10/21 13:41:15 jmcneill Exp $ */
+/* $NetBSD: acpi.c,v 1.279 2019/12/29 23:47:56 jmcneill Exp $ */
/*-
* Copyright (c) 2003, 2007 The NetBSD Foundation, Inc.
@@ -100,7 +100,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.278 2018/10/21 13:41:15 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.279 2019/12/29 23:47:56 jmcneill Exp $");
#include "pci.h"
#include "opt_acpi.h"
@@ -237,6 +237,9 @@ ACPI_STATUS acpi_allocate_resources(ACP
void (*acpi_print_verbose)(struct acpi_softc *) = acpi_print_verbose_stub;
void (*acpi_print_dev)(const char *) = acpi_print_dev_stub;
+bus_dma_tag_t acpi_default_dma_tag(struct acpi_softc *, struct acpi_devnode *);
+bus_dma_tag_t acpi_default_dma64_tag(struct acpi_softc *, struct acpi_devnode *);
+
CFATTACH_DECL2_NEW(acpi, sizeof(struct acpi_softc),
acpi_match, acpi_attach, acpi_detach, NULL, acpi_rescan, acpi_childdet);
@@ -808,6 +811,20 @@ acpi_make_name(struct acpi_devnode *ad,
ad->ad_name[0] = '_';
}
+bus_dma_tag_t
+acpi_default_dma_tag(struct acpi_softc *sc, struct acpi_devnode *ad)
+{
+ return sc->sc_dmat;
+}
+__weak_alias(acpi_get_dma_tag,acpi_default_dma_tag);
+
+bus_dma_tag_t
+acpi_default_dma64_tag(struct acpi_softc *sc, struct acpi_devnode *ad)
+{
+ return sc->sc_dmat64;
+}
+__weak_alias(acpi_get_dma64_tag,acpi_default_dma64_tag);
+
/*
* Device attachment.
*/
@@ -877,8 +894,8 @@ acpi_rescan_early(struct acpi_softc *sc)
aa.aa_pc = sc->sc_pc;
aa.aa_pciflags = sc->sc_pciflags;
aa.aa_ic = sc->sc_ic;
- aa.aa_dmat = sc->sc_dmat;
- aa.aa_dmat64 = sc->sc_dmat64;
+ aa.aa_dmat = acpi_get_dma_tag(sc, ad);
+ aa.aa_dmat64 = acpi_get_dma64_tag(sc, ad);
ad->ad_device = config_found_ia(sc->sc_dev,
"acpinodebus", &aa, acpi_print);
@@ -939,8 +956,8 @@ acpi_rescan_nodes(struct acpi_softc *sc)
aa.aa_pc = sc->sc_pc;
aa.aa_pciflags = sc->sc_pciflags;
aa.aa_ic = sc->sc_ic;
- aa.aa_dmat = sc->sc_dmat;
- aa.aa_dmat64 = sc->sc_dmat64;
+ aa.aa_dmat = acpi_get_dma_tag(sc, ad);
+ aa.aa_dmat64 = acpi_get_dma64_tag(sc, ad);
ad->ad_device = config_found_ia(sc->sc_dev,
"acpinodebus", &aa, acpi_print);
Index: src/sys/dev/acpi/acpivar.h
diff -u src/sys/dev/acpi/acpivar.h:1.77 src/sys/dev/acpi/acpivar.h:1.78
--- src/sys/dev/acpi/acpivar.h:1.77 Thu Oct 25 10:38:57 2018
+++ src/sys/dev/acpi/acpivar.h Sun Dec 29 23:47:56 2019
@@ -1,4 +1,4 @@
-/* $NetBSD: acpivar.h,v 1.77 2018/10/25 10:38:57 jmcneill Exp $ */
+/* $NetBSD: acpivar.h,v 1.78 2019/12/29 23:47:56 jmcneill Exp $ */
/*
* Copyright 2001 Wasabi Systems, Inc.
@@ -384,6 +384,9 @@ int acpi_quirks_osi_del(const char *);
void acpi_debug_init(void);
#endif
+bus_dma_tag_t acpi_get_dma_tag(struct acpi_softc *, struct acpi_devnode *);
+bus_dma_tag_t acpi_get_dma64_tag(struct acpi_softc *, struct acpi_devnode *);
+
/*
* Misc routines with vectors updated by acpiverbose module.
*/