mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-12-27 13:30:45 -05:00
PCI/pwrctrl: Fix device and OF node leak at bus scan
Make sure to drop the references to the pwrctrl OF node and device taken by
of_pci_find_child_device() and of_find_device_by_node() respectively when
scanning the bus.
Fixes: 957f40d039 ("PCI/pwrctrl: Move creation of pwrctrl devices to pci_scan_device()")
Signed-off-by: Johan Hovold <johan+linaro@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Manivannan Sadhasivam <mani@kernel.org>
Cc: stable@vger.kernel.org # v6.15
Link: https://patch.msgid.link/20250721153609.8611-3-johan+linaro@kernel.org
This commit is contained in:
committed by
Bjorn Helgaas
parent
39f9be6aba
commit
e24bbbe078
@@ -2516,9 +2516,15 @@ static struct platform_device *pci_pwrctrl_create_device(struct pci_bus *bus, in
|
||||
struct device_node *np;
|
||||
|
||||
np = of_pci_find_child_device(dev_of_node(&bus->dev), devfn);
|
||||
if (!np || of_find_device_by_node(np))
|
||||
if (!np)
|
||||
return NULL;
|
||||
|
||||
pdev = of_find_device_by_node(np);
|
||||
if (pdev) {
|
||||
put_device(&pdev->dev);
|
||||
goto err_put_of_node;
|
||||
}
|
||||
|
||||
/*
|
||||
* First check whether the pwrctrl device really needs to be created or
|
||||
* not. This is decided based on at least one of the power supplies
|
||||
@@ -2526,17 +2532,24 @@ static struct platform_device *pci_pwrctrl_create_device(struct pci_bus *bus, in
|
||||
*/
|
||||
if (!of_pci_supply_present(np)) {
|
||||
pr_debug("PCI/pwrctrl: Skipping OF node: %s\n", np->name);
|
||||
return NULL;
|
||||
goto err_put_of_node;
|
||||
}
|
||||
|
||||
/* Now create the pwrctrl device */
|
||||
pdev = of_platform_device_create(np, NULL, &host->dev);
|
||||
if (!pdev) {
|
||||
pr_err("PCI/pwrctrl: Failed to create pwrctrl device for node: %s\n", np->name);
|
||||
return NULL;
|
||||
goto err_put_of_node;
|
||||
}
|
||||
|
||||
of_node_put(np);
|
||||
|
||||
return pdev;
|
||||
|
||||
err_put_of_node:
|
||||
of_node_put(np);
|
||||
|
||||
return NULL;
|
||||
}
|
||||
#else
|
||||
static struct platform_device *pci_pwrctrl_create_device(struct pci_bus *bus, int devfn)
|
||||
|
||||
Reference in New Issue
Block a user