svn commit: r347440 - head/sys/dev/ahci
Emmanuel Vadot
manu at FreeBSD.org
Fri May 10 16:43:56 UTC 2019
Author: manu
Date: Fri May 10 16:43:53 2019
New Revision: 347440
URL: https://svnweb.freebsd.org/changeset/base/347440
Log:
ahci: Check if bus is cache-coherent
We do this for FDT systems but not for ACPI ones.
Check the presence of the _CCA attribute.
Sponsored by: Ampere Computing, LLC
Reviewed by: andrew
Differential Revision: https://reviews.freebsd.org/D20144
Modified:
head/sys/dev/ahci/ahci_generic.c
Modified: head/sys/dev/ahci/ahci_generic.c
==============================================================================
--- head/sys/dev/ahci/ahci_generic.c Fri May 10 16:43:47 2019 (r347439)
+++ head/sys/dev/ahci/ahci_generic.c Fri May 10 16:43:53 2019 (r347440)
@@ -89,6 +89,7 @@ ahci_fdt_probe(device_t dev)
static int
ahci_acpi_probe(device_t dev)
{
+ struct ahci_controller *ctlr = device_get_softc(dev);
ACPI_HANDLE h;
if ((h = acpi_get_handle(dev)) == NULL)
@@ -98,6 +99,12 @@ ahci_acpi_probe(device_t dev)
pci_get_subclass(dev) == PCIS_STORAGE_SATA &&
pci_get_progif(dev) == PCIP_STORAGE_SATA_AHCI_1_0) {
device_set_desc_copy(dev, "AHCI SATA controller");
+ if (ACPI_FAILURE(acpi_GetInteger(h, "_CCA",
+ &ctlr->dma_coherent)))
+ ctlr->dma_coherent = 0;
+ if (bootverbose)
+ device_printf(dev, "Bus is%s cache-coherent\n",
+ ctlr->dma_coherent ? "" : " not");
return (BUS_PROBE_DEFAULT);
}
More information about the svn-src-head
mailing list