From: Zijun Hu <quic_zijuhu@xxxxxxxxxxx> commit 5d009e024056ded20c5bb1583146b833b23bbd5a upstream. __of_get_dma_parent() returns OF device node @args.np, but the node's refcount is increased twice, by both of_parse_phandle_with_args() and of_node_get(), so causes refcount leakage for the node. Fix by directly returning the node got by of_parse_phandle_with_args(). Fixes: f83a6e5dea6c ("of: address: Add support for the parent DMA bus") Cc: stable@xxxxxxxxxxxxxxx Signed-off-by: Zijun Hu <quic_zijuhu@xxxxxxxxxxx> Link: https://lore.kernel.org/r/20241206-of_core_fix-v1-4-dc28ed56bec3@xxxxxxxxxxx Signed-off-by: Rob Herring (Arm) <robh@xxxxxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- drivers/of/address.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/of/address.c +++ b/drivers/of/address.c @@ -616,7 +616,7 @@ struct device_node *__of_get_dma_parent( if (ret < 0) return of_get_parent(np); - return of_node_get(args.np); + return args.np; } #endif Patches currently in stable-queue which might be from quic_zijuhu@xxxxxxxxxxx are queue-6.12/of-irq-fix-using-uninitialized-variable-addr_len-in-api-of_irq_parse_one.patch queue-6.12/of-fix-refcount-leakage-for-of-node-returned-by-__of_get_dma_parent.patch queue-6.12/of-irq-fix-interrupt-map-cell-length-check-in-of_irq_parse_imap_parent.patch