* [PATCH v2] arm/mach-omap2: Fix refcount leak bugs
@ 2022-06-20 15:54 Liang He
2022-06-22 8:53 ` Krzysztof Kozlowski
2022-06-28 4:05 ` Tony Lindgren
0 siblings, 2 replies; 3+ messages in thread
From: Liang He @ 2022-06-20 15:54 UTC (permalink / raw)
To: tony, linux; +Cc: windhl, linux-arm-kernel, linux-omap
We need to add of_node_put() to keep refcount balance for of_find_xxx()
which will return a node pointer with refcount incremented.
Signed-off-by: Liang He <windhl@126.com>
---
changelog:
v2:(1) we find several new leak bugs
(2) we merge all mach-omap2 related bugs in to one commit
v1: we send a patch for each missing of_node_put bug
arch/arm/mach-omap2/display.c | 1 +
arch/arm/mach-omap2/omap4-common.c | 1 +
arch/arm/mach-omap2/omap_hwmod.c | 6 ++++++
arch/arm/mach-omap2/pdata-quirks.c | 2 ++
4 files changed, 10 insertions(+)
diff --git a/arch/arm/mach-omap2/display.c b/arch/arm/mach-omap2/display.c
index 21413a9b7b6c..eb09a25e3b45 100644
--- a/arch/arm/mach-omap2/display.c
+++ b/arch/arm/mach-omap2/display.c
@@ -211,6 +211,7 @@ static int __init omapdss_init_fbdev(void)
node = of_find_node_by_name(NULL, "omap4_padconf_global");
if (node)
omap4_dsi_mux_syscon = syscon_node_to_regmap(node);
+ of_node_put(node);
return 0;
}
diff --git a/arch/arm/mach-omap2/omap4-common.c b/arch/arm/mach-omap2/omap4-common.c
index 6d1eb4eefefe..e981bf57e64f 100644
--- a/arch/arm/mach-omap2/omap4-common.c
+++ b/arch/arm/mach-omap2/omap4-common.c
@@ -135,6 +135,7 @@ static int __init omap4_sram_init(void)
pr_warn("%s:Unable to allocate sram needed to handle errata I688\n",
__func__);
sram_pool = of_gen_pool_get(np, "sram", 0);
+ of_node_put(np);
if (!sram_pool)
pr_warn("%s:Unable to get sram pool needed to handle errata I688\n",
__func__);
diff --git a/arch/arm/mach-omap2/omap_hwmod.c b/arch/arm/mach-omap2/omap_hwmod.c
index 31d1a21f6041..814546c10bb8 100644
--- a/arch/arm/mach-omap2/omap_hwmod.c
+++ b/arch/arm/mach-omap2/omap_hwmod.c
@@ -2365,6 +2365,7 @@ static int __init _init(struct omap_hwmod *oh, void *data)
r = _init_mpu_rt_base(oh, NULL, index, np);
if (r < 0) {
+ of_node_put(bus);
WARN(1, "omap_hwmod: %s: doesn't have mpu register target base\n",
oh->name);
return 0;
@@ -2372,6 +2373,7 @@ static int __init _init(struct omap_hwmod *oh, void *data)
r = _init_clocks(oh, np);
if (r < 0) {
+ of_node_put(bus);
WARN(1, "omap_hwmod: %s: couldn't init clocks\n", oh->name);
return -EINVAL;
}
@@ -2385,6 +2387,8 @@ static int __init _init(struct omap_hwmod *oh, void *data)
parse_module_flags(oh, child);
}
+ of_node_put(bus);
+
oh->_state = _HWMOD_STATE_INITIALIZED;
return 0;
@@ -3648,6 +3652,7 @@ static void __init omap_hwmod_setup_earlycon_flags(void)
np = of_find_node_by_path("/chosen");
if (np) {
uart = of_get_property(np, "stdout-path", NULL);
+ of_node_put(np);
if (uart) {
np = of_find_node_by_path(uart);
if (np) {
@@ -3661,6 +3666,7 @@ static void __init omap_hwmod_setup_earlycon_flags(void)
}
if (oh)
oh->flags |= DEBUG_OMAPUART_FLAGS;
+ of_node_put(np);
}
}
}
diff --git a/arch/arm/mach-omap2/pdata-quirks.c b/arch/arm/mach-omap2/pdata-quirks.c
index 13f1b89f74b8..5b99d602c87b 100644
--- a/arch/arm/mach-omap2/pdata-quirks.c
+++ b/arch/arm/mach-omap2/pdata-quirks.c
@@ -540,6 +540,8 @@ pdata_quirks_init_clocks(const struct of_device_id *omap_dt_match_table)
of_platform_populate(np, omap_dt_match_table,
omap_auxdata_lookup, NULL);
+
+ of_node_put(np);
}
}
--
2.25.1
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH v2] arm/mach-omap2: Fix refcount leak bugs
2022-06-20 15:54 [PATCH v2] arm/mach-omap2: Fix refcount leak bugs Liang He
@ 2022-06-22 8:53 ` Krzysztof Kozlowski
2022-06-28 4:05 ` Tony Lindgren
1 sibling, 0 replies; 3+ messages in thread
From: Krzysztof Kozlowski @ 2022-06-22 8:53 UTC (permalink / raw)
To: Liang He, tony, linux; +Cc: linux-arm-kernel, linux-omap
On 20/06/2022 17:54, Liang He wrote:
> We need to add of_node_put() to keep refcount balance for of_find_xxx()
> which will return a node pointer with refcount incremented.
>
> Signed-off-by: Liang He <windhl@126.com>
> ---
> changelog:
>
> v2:(1) we find several new leak bugs
> (2) we merge all mach-omap2 related bugs in to one commit
>
> v1: we send a patch for each missing of_node_put bug
>
>
>
> arch/arm/mach-omap2/display.c | 1 +
> arch/arm/mach-omap2/omap4-common.c | 1 +
> arch/arm/mach-omap2/omap_hwmod.c | 6 ++++++
> arch/arm/mach-omap2/pdata-quirks.c | 2 ++
> 4 files changed, 10 insertions(+)
Before applying the patch please check it carefully. Previous evidence
[1] suggests that not it was not even compiled.
[1] https://lore.kernel.org/all/202206221602.odN70SHs-lkp@intel.com/
Best regards,
Krzysztof
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v2] arm/mach-omap2: Fix refcount leak bugs
2022-06-20 15:54 [PATCH v2] arm/mach-omap2: Fix refcount leak bugs Liang He
2022-06-22 8:53 ` Krzysztof Kozlowski
@ 2022-06-28 4:05 ` Tony Lindgren
1 sibling, 0 replies; 3+ messages in thread
From: Tony Lindgren @ 2022-06-28 4:05 UTC (permalink / raw)
To: Liang He; +Cc: linux, linux-arm-kernel, linux-omap, Krzysztof Kozlowski
* Liang He <windhl@126.com> [220620 15:49]:
> --- a/arch/arm/mach-omap2/omap4-common.c
> +++ b/arch/arm/mach-omap2/omap4-common.c
> @@ -135,6 +135,7 @@ static int __init omap4_sram_init(void)
> pr_warn("%s:Unable to allocate sram needed to handle errata I688\n",
> __func__);
> sram_pool = of_gen_pool_get(np, "sram", 0);
> + of_node_put(np);
> if (!sram_pool)
> pr_warn("%s:Unable to get sram pool needed to handle errata I688\n",
> __func__);
Here sram_pool is used after of_node_put() on it. Don't we want to do the
put only after no users?
Regards,
Tony
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2022-06-28 4:06 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-06-20 15:54 [PATCH v2] arm/mach-omap2: Fix refcount leak bugs Liang He
2022-06-22 8:53 ` Krzysztof Kozlowski
2022-06-28 4:05 ` Tony Lindgren
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).