dmaengine: ti: edma: fix OF node reference leaks in edma_driver
authorJoe Hattori <joe@pf.is.s.u-tokyo.ac.jp>
Thu, 19 Dec 2024 02:05:07 +0000 (11:05 +0900)
committerVinod Koul <vkoul@kernel.org>
Tue, 24 Dec 2024 09:53:32 +0000 (15:23 +0530)
The .probe() of edma_driver calls of_parse_phandle_with_fixed_args() but
does not release the obtained OF nodes. Thus add a of_node_put() call.

This bug was found by an experimental verification tool that I am
developing.

Fixes: 1be5336bc7ba ("dmaengine: edma: New device tree binding")
Signed-off-by: Joe Hattori <joe@pf.is.s.u-tokyo.ac.jp>
Reviewed-by: Dan Carpenter <dan.carpenter@linaro.org>
Link: https://lore.kernel.org/r/20241219020507.1983124-3-joe@pf.is.s.u-tokyo.ac.jp
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/ti/edma.c

index 08f6c67d381e6722ae61ac364b40fa92fe7af8ba..4ece125b2ae765741b56223981cb857d5945add3 100644 (file)
@@ -208,7 +208,6 @@ struct edma_desc {
 struct edma_cc;
 
 struct edma_tc {
-       struct device_node              *node;
        u16                             id;
 };
 
@@ -2466,13 +2465,13 @@ static int edma_probe(struct platform_device *pdev)
                        if (ret)
                                break;
 
-                       ecc->tc_list[i].node = tc_args.np;
                        ecc->tc_list[i].id = i;
                        queue_priority_mapping[i][1] = tc_args.args[0];
                        if (queue_priority_mapping[i][1] > lowest_priority) {
                                lowest_priority = queue_priority_mapping[i][1];
                                info->default_queue = i;
                        }
+                       of_node_put(tc_args.np);
                }
 
                /* See if we have optional dma-channel-mask array */