drm/pl111: pl111_vexpress.c: Add of_node_put() before return
authorNishka Dasgupta <nishkadg.linux@gmail.com>
Sat, 6 Jul 2019 13:27:42 +0000 (18:57 +0530)
committerEric Anholt <eric@anholt.net>
Mon, 15 Jul 2019 23:26:43 +0000 (16:26 -0700)
Each iteration of for_each_available_child_of_node puts the previous
node, but in the case of a break from the middle of the loop there is
no put, thus causing a memory leak. Hence add an of_node_put before the
break.
Issue found with Coccinelle.

Signed-off-by: Nishka Dasgupta <nishkadg.linux@gmail.com>
Signed-off-by: Eric Anholt <eric@anholt.net>
Link: https://patchwork.freedesktop.org/patch/msgid/20190706132742.3250-1-nishkadg.linux@gmail.com
drivers/gpu/drm/pl111/pl111_vexpress.c

index 38c938c9addaf72f86853feb307d2cd62938dd1d..350570fe06b5f39664d8fd38c9f37e1fac051b3e 100644 (file)
@@ -51,6 +51,7 @@ int pl111_vexpress_clcd_init(struct device *dev,
                }
                if (of_device_is_compatible(child, "arm,hdlcd")) {
                        has_coretile_hdlcd = true;
+                       of_node_put(child);
                        break;
                }
        }