From: Alison Schofield Date: Thu, 7 Oct 2021 21:34:26 +0000 (-0700) Subject: cxl/acpi: Do not fail cxl_acpi_probe() based on a missing CHBS X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=91a45b12d49e2b43d86caba25ed59fae43344ab8;p=linux.git cxl/acpi: Do not fail cxl_acpi_probe() based on a missing CHBS When an ACPI0016 Host Bridge device is present yet no corresponding CEDT Host Bridge Structure (CHBS) exists, the ACPI probe method fails. Rather than fail, emit this warning and continue: cxl_acpi ACPI0017:00: No CHBS found for Host Bridge: ACPI0016:02 This error may occur on systems that are not compliant with the ACPI specification. Compliant systems include a CHBS entry for every CXL host bridge that is present at boot. Suggested-by: Ira Weiny Signed-off-by: Alison Schofield Tested-by: Vishal Verma Reviewed-by: Ira Weiny Link: https://lore.kernel.org/r/20211007213426.392644-1-alison.schofield@intel.com Signed-off-by: Dan Williams --- diff --git a/drivers/cxl/acpi.c b/drivers/cxl/acpi.c index af1c6c1875ac4..dadc7f64b9ff8 100644 --- a/drivers/cxl/acpi.c +++ b/drivers/cxl/acpi.c @@ -288,7 +288,7 @@ static int add_host_bridge_uport(struct device *match, void *arg) dport = find_dport_by_dev(root_port, match); if (!dport) { dev_dbg(host, "host bridge expected and not found\n"); - return -ENODEV; + return 0; } port = devm_cxl_add_port(host, match, dport->component_reg_phys, @@ -377,9 +377,11 @@ static int add_host_bridge_dport(struct device *match, void *arg) } chbs = cxl_acpi_match_chbs(host, uid); - if (IS_ERR(chbs)) - dev_dbg(host, "No CHBS found for Host Bridge: %s\n", - dev_name(match)); + if (IS_ERR(chbs)) { + dev_warn(host, "No CHBS found for Host Bridge: %s\n", + dev_name(match)); + return 0; + } rc = cxl_add_dport(root_port, match, uid, get_chbcr(chbs)); if (rc) {