cxl: Add a dev_dbg() when a decoder was added to a port
authorRobert Richter <rrichter@amd.com>
Fri, 9 May 2025 15:06:59 +0000 (17:06 +0200)
committerDave Jiang <dave.jiang@intel.com>
Fri, 9 May 2025 16:57:43 +0000 (09:57 -0700)
Improve debugging by adding and unifying messages whenever a decoder
was added to a port. It is especially useful to get the decoder
mapping of the involved CXL host bridge or PCI device. This avoids a
complex lookup of the decoder/port/device mappings in sysfs.

Example log messages:

  cxl_acpi ACPI0017:00: decoder0.0 added to root0
  cxl_acpi ACPI0017:00: decoder0.1 added to root0
  ...
   pci0000:e0: decoder1.0 added to port1
   pci0000:e0: decoder1.1 added to port1
  ...
  cxl_mem mem0: decoder5.0 added to endpoint5
  cxl_mem mem0: decoder5.1 added to endpoint5

Signed-off-by: Robert Richter <rrichter@amd.com>
Reviewed-by: Gregory Price <gourry@gourry.net>
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Reviewed-by: Dave Jiang <dave.jiang@intel.com>
Reviewed-by: Alison Schofield <alison.schofield@intel.com>
Tested-by: Gregory Price <gourry@gourry.net>
Acked-by: Dan Williams <dan.j.williams@intel.com>
Link: https://patch.msgid.link/20250509150700.2817697-15-rrichter@amd.com
Signed-off-by: Dave Jiang <dave.jiang@intel.com>
drivers/cxl/acpi.c
drivers/cxl/core/hdm.c

index cb14829bb9be4b479ff215f9fe813833774cbc54..3e75e612cbc4a812b987a17bcf6c860ca54c9f91 100644 (file)
@@ -421,7 +421,15 @@ static int __cxl_parse_cfmws(struct acpi_cedt_cfmws *cfmws,
        rc = cxl_decoder_add(cxld, target_map);
        if (rc)
                return rc;
-       return cxl_root_decoder_autoremove(dev, no_free_ptr(cxlrd));
+
+       rc = cxl_root_decoder_autoremove(dev, no_free_ptr(cxlrd));
+       if (rc)
+               return rc;
+
+       dev_dbg(root_port->dev.parent, "%s added to %s\n",
+               dev_name(&cxld->dev), dev_name(&root_port->dev));
+
+       return 0;
 }
 
 static int cxl_parse_cfmws(union acpi_subtable_headers *header, void *arg,
index 70cae4ebf8a4bd1b2d5e05d5030a660625f1a20d..00c2de629a34d78a4c69401385c7d6046deef3ad 100644 (file)
@@ -34,7 +34,8 @@ static int add_hdm_decoder(struct cxl_port *port, struct cxl_decoder *cxld,
        if (rc)
                return rc;
 
-       dev_dbg(&cxld->dev, "Added to port %s\n", dev_name(&port->dev));
+       dev_dbg(port->uport_dev, "%s added to %s\n",
+               dev_name(&cxld->dev), dev_name(&port->dev));
 
        return 0;
 }