Commit 8884b563 authored by Ilpo Järvinen's avatar Ilpo Järvinen Committed by Bjorn Helgaas
Browse files

PCI: Add debug print when releasing resources before retry

PCI resource fitting is somewhat hard to track because it performs many
actions without logging them. In the case inside
__assign_resources_sorted(), the resources are released before resource
assignment is going to be retried in a different order. That is just one
level of retries the resource fitting performs overall so tracking it
through repeated assignments or failures of a resource gets messy rather
quickly.

Simply announce the release explicitly using pci_dbg() so it is clear what
is going on with each resource.

Link: https://lore.kernel.org/r/20241216175632.4175-23-ilpo.jarvinen@linux.intel.com


Signed-off-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Tested-by: default avatarXiaochun Lee <lixc17@lenovo.com>
parent 07854e08
Loading
Loading
Loading
Loading
+12 −2
Original line number Diff line number Diff line
@@ -408,6 +408,9 @@ static void __assign_resources_sorted(struct list_head *head,
	struct pci_dev_resource *save_res;
	struct pci_dev_resource *dev_res, *tmp_res, *dev_res2;
	struct resource *res;
	struct pci_dev *dev;
	const char *res_name;
	int idx;
	unsigned long fail_type;
	resource_size_t add_align, align;

@@ -497,8 +500,15 @@ static void __assign_resources_sorted(struct list_head *head,
	/* Release assigned resource */
	list_for_each_entry(dev_res, head, list) {
		res = dev_res->res;
		dev = dev_res->dev;

		if (!res->parent)
			continue;

		idx = pci_resource_num(dev, res);
		res_name = pci_resource_name(dev, idx);
		pci_dbg(dev, "%s %pR: releasing\n", res_name, res);

		if (res->parent)
		release_resource(res);
	}
	/* Restore start/end/flags from saved list */