firmware: psci: Fix refcount leak in psci_dt_init
[ Upstream commit 7ff37d29fd5c27617b9767e1b8946d115cf93a1e ]
Fix a reference counter leak in psci_dt_init() where of_node_put(np) was
missing after of_find_matching_node_and_match() when np is unavailable.
Fixes: d09a0011ec ("drivers: psci: Allow PSCI node to be disabled")
Signed-off-by: Miaoqian Lin <linmq006@gmail.com>
Reviewed-by: Gavin Shan <gshan@redhat.com>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Link: https://lore.kernel.org/r/20250318151712.28763-1-linmq006@gmail.com
Signed-off-by: Will Deacon <will@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
7ccf0c4070
commit
0860d48b70
@@ -759,8 +759,10 @@ int __init psci_dt_init(void)
|
|||||||
|
|
||||||
np = of_find_matching_node_and_match(NULL, psci_of_match, &matched_np);
|
np = of_find_matching_node_and_match(NULL, psci_of_match, &matched_np);
|
||||||
|
|
||||||
if (!np || !of_device_is_available(np))
|
if (!np || !of_device_is_available(np)) {
|
||||||
|
of_node_put(np);
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
init_fn = (psci_initcall_t)matched_np->data;
|
init_fn = (psci_initcall_t)matched_np->data;
|
||||||
ret = init_fn(np);
|
ret = init_fn(np);
|
||||||
|
|||||||
Reference in New Issue
Block a user