powerpc/iommu: Add missing of_node_put in iommu_init_early_dart
[ Upstream commit 57b742a5b8945118022973e6416b71351df512fb ] The device_node pointer is returned by of_find_compatible_node with refcount incremented. We should use of_node_put() to avoid the refcount leak. Signed-off-by: Peng Wu <wupeng58@huawei.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20220425081245.21705-1-wupeng58@huawei.com Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
b4e14e9beb
commit
dfc308d6f2
@@ -403,9 +403,10 @@ void __init iommu_init_early_dart(struct pci_controller_ops *controller_ops)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Initialize the DART HW */
|
/* Initialize the DART HW */
|
||||||
if (dart_init(dn) != 0)
|
if (dart_init(dn) != 0) {
|
||||||
|
of_node_put(dn);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* U4 supports a DART bypass, we use it for 64-bit capable devices to
|
* U4 supports a DART bypass, we use it for 64-bit capable devices to
|
||||||
* improve performance. However, that only works for devices connected
|
* improve performance. However, that only works for devices connected
|
||||||
@@ -418,6 +419,7 @@ void __init iommu_init_early_dart(struct pci_controller_ops *controller_ops)
|
|||||||
|
|
||||||
/* Setup pci_dma ops */
|
/* Setup pci_dma ops */
|
||||||
set_pci_dma_ops(&dma_iommu_ops);
|
set_pci_dma_ops(&dma_iommu_ops);
|
||||||
|
of_node_put(dn);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
|
Reference in New Issue
Block a user