]> git.itanic.dy.fi Git - linux-stable/commitdiff
drm:pl111: Add of_node_put() when breaking out of for_each_available_child_of_node()
authorLiang He <windhl@126.com>
Mon, 11 Jul 2022 13:15:50 +0000 (21:15 +0800)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Thu, 11 Aug 2022 16:13:31 +0000 (18:13 +0200)
The reference 'child' in the iteration of for_each_available_child_of_node()
is only escaped out into a local variable which is only used to check
its value. So we still need to the of_node_put() when breaking of the
for_each_available_child_of_node() which will automatically increase
and decrease the refcount.

Fixes: ca454bd42dc2 ("drm/pl111: Support the Versatile Express")
Signed-off-by: Liang He <windhl@126.com>
Reviewed-by: Rob Herring <robh@kernel.org>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20220711131550.361350-1-windhl@126.com
drivers/gpu/drm/pl111/pl111_versatile.c

index efb01a5545740f52367f1b9b376e6fc01a7e76e9..1b436b75fd396f2bf71ab067a873873ccd484fd5 100644 (file)
@@ -404,6 +404,7 @@ static int pl111_vexpress_clcd_init(struct device *dev, struct device_node *np,
                if (of_device_is_compatible(child, "arm,pl111")) {
                        has_coretile_clcd = true;
                        ct_clcd = child;
+                       of_node_put(child);
                        break;
                }
                if (of_device_is_compatible(child, "arm,hdlcd")) {