git: 22a6678b627b - main - acpi_pcib: Trust decoded bus range from _CRS over _BBN

From: John Baldwin <jhb_at_FreeBSD.org>
Date: Mon, 16 Oct 2023 22:43:20 UTC
The branch main has been updated by jhb:

URL: https://cgit.FreeBSD.org/src/commit/?id=22a6678b627b39ceb94f7323be1010e928d92494

commit 22a6678b627b39ceb94f7323be1010e928d92494
Author:     John Baldwin <jhb@FreeBSD.org>
AuthorDate: 2023-10-16 22:19:07 +0000
Commit:     John Baldwin <jhb@FreeBSD.org>
CommitDate: 2023-10-16 22:33:10 +0000

    acpi_pcib: Trust decoded bus range from _CRS over _BBN
    
    Currently if _BBN doesn't match the first bus in the decoded bus range
    from _CRS for a Host to PCI bridge, the driver fails to attach as a
    defensive measure.
    
    There is now firmware in the field where these do not match, and the
    _BBN values are clearly wrong, so rather than failing attach, trust
    the range from _CRS over _BBN.
    
    Co-authored-by: Justin Gibbs <gibbs@FreeBSD.org>
    Reported by:    gibbs
    Reviewed by:    imp (earlier version)
    Differential Revision:  https://reviews.freebsd.org/D42231
---
 sys/dev/acpica/acpi_pcib_acpi.c | 30 +++++++++++++++++++-----------
 1 file changed, 19 insertions(+), 11 deletions(-)

diff --git a/sys/dev/acpica/acpi_pcib_acpi.c b/sys/dev/acpica/acpi_pcib_acpi.c
index 0575b1d83bb1..02e3a0be5956 100644
--- a/sys/dev/acpica/acpi_pcib_acpi.c
+++ b/sys/dev/acpica/acpi_pcib_acpi.c
@@ -289,7 +289,8 @@ acpi_pcib_producer_handler(ACPI_RESOURCE *res, void *context)
 
 #if defined(NEW_PCIB) && defined(PCI_RES_BUS)
 static int
-first_decoded_bus(struct acpi_hpcib_softc *sc, rman_res_t *startp)
+decoded_bus_range(struct acpi_hpcib_softc *sc, rman_res_t *startp,
+    rman_res_t *endp)
 {
 	struct resource_list_entry *rle;
 
@@ -297,6 +298,7 @@ first_decoded_bus(struct acpi_hpcib_softc *sc, rman_res_t *startp)
 	if (rle == NULL)
 		return (ENXIO);
 	*startp = rle->start;
+	*endp = rle->end;
 	return (0);
 }
 #endif
@@ -366,7 +368,7 @@ acpi_pcib_acpi_attach(device_t dev)
     u_int slot, func, busok;
 #if defined(NEW_PCIB) && defined(PCI_RES_BUS)
     struct resource *bus_res;
-    rman_res_t start;
+    rman_res_t end, start;
     int rid;
 #endif
     int error, domain;
@@ -495,7 +497,7 @@ acpi_pcib_acpi_attach(device_t dev)
 	     * If we have a region of bus numbers, use the first
 	     * number for our bus.
 	     */
-	    if (first_decoded_bus(sc, &start) == 0)
+	    if (decoded_bus_range(sc, &start, &end) == 0)
 		    sc->ap_bus = start;
 	    else {
 		    rid = 0;
@@ -512,15 +514,21 @@ acpi_pcib_acpi_attach(device_t dev)
 	    }
     } else {
 	    /*
-	     * Require the bus number from _BBN to match the start of any
-	     * decoded range.
+	     * If there is a decoded bus range, assume the bus number is
+	     * the first value in the range.  Warn if _BBN doesn't match.
 	     */
-	    if (first_decoded_bus(sc, &start) == 0 && sc->ap_bus != start) {
-		    device_printf(dev,
-		"bus number %d does not match start of decoded range %ju\n",
-			sc->ap_bus, (uintmax_t)start);
-		    pcib_host_res_free(dev, &sc->ap_host_res);
-		    return (ENXIO);
+	    if (decoded_bus_range(sc, &start, &end) == 0) {
+		    if (sc->ap_bus != start) {
+			    device_printf(dev,
+				"WARNING: BIOS configured bus number (%d) is "
+				"not within decoded bus number range "
+				"(%ju - %ju).\n",
+				sc->ap_bus, (uintmax_t)start, (uintmax_t)end);
+			    device_printf(dev,
+				"Using range start (%ju) as bus number.\n",
+				(uintmax_t)start);
+			    sc->ap_bus = start;
+		    }
 	    }
     }
 #else