Commit 9f6caa39 authored by Javier Carrasco's avatar Javier Carrasco Committed by Vinod Koul
Browse files

dmaengine: mv_xor: switch to for_each_child_of_node_scoped()



Introduce the scoped variant of the loop to automatically release the
child node when it goes out of scope, which is more robust than the
non-scoped variant, and accounts for new early exits that could be added
in the future.

Signed-off-by: default avatarJavier Carrasco <javier.carrasco.cruz@gmail.com>
Link: https://lore.kernel.org/r/20241011-dma_mv_xor_of_node_put-v1-2-3c2de819f463@gmail.com


Signed-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 36d8cbd6
Loading
Loading
Loading
Loading
+1 −4
Original line number Diff line number Diff line
@@ -1369,10 +1369,9 @@ static int mv_xor_probe(struct platform_device *pdev)
		return 0;

	if (pdev->dev.of_node) {
		struct device_node *np;
		int i = 0;

		for_each_child_of_node(pdev->dev.of_node, np) {
		for_each_child_of_node_scoped(pdev->dev.of_node, np) {
			struct mv_xor_chan *chan;
			dma_cap_mask_t cap_mask;
			int irq;
@@ -1388,7 +1387,6 @@ static int mv_xor_probe(struct platform_device *pdev)
			irq = irq_of_parse_and_map(np, 0);
			if (!irq) {
				ret = -ENODEV;
				of_node_put(np);
				goto err_channel_add;
			}

@@ -1397,7 +1395,6 @@ static int mv_xor_probe(struct platform_device *pdev)
			if (IS_ERR(chan)) {
				ret = PTR_ERR(chan);
				irq_dispose_mapping(irq);
				of_node_put(np);
				goto err_channel_add;
			}