* [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths
@ 2025-04-21 15:00 Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe() Christophe JAILLET
` (3 more replies)
0 siblings, 4 replies; 6+ messages in thread
From: Christophe JAILLET @ 2025-04-21 15:00 UTC (permalink / raw)
To: lee, krzk, alim.akhtar, s.nawrocki, m.szyprowski, ideal.song,
beomho.seo
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors, Christophe JAILLET
This serie fixes several issues related to error handling paths in
drivers/mfd/exynos-lpass.c.
I've split it in 3 patches to ease review, but it could be merge in only
1 patch if preferred.
Patch 1: Fix a leak in the error handling path of the probe. It should
be straighforward. This patch is already R-b.
Patch 2: Slighly unsure of the order of the code. In the probe, we
enable pm, then lpass, so should we disable lpass, then pm?
This patch is already R-b.
Patch 3: Fix a leak in the error handling path of the probe. It should
be straighforward. This replaces patch 3 and 4 of the v1.
All these patches are compile tested only.
Christophe JAILLET (3):
mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe()
mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in
exynos_lpass_remove()
mfd: exynos-lpass: Fix another error handling path in
exynos_lpass_probe()
drivers/mfd/exynos-lpass.c | 31 +++++++++++++++++--------------
1 file changed, 17 insertions(+), 14 deletions(-)
--
2.49.0
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2 1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe()
2025-04-21 15:00 [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Christophe JAILLET
@ 2025-04-21 15:00 ` Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 2/3] mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in exynos_lpass_remove() Christophe JAILLET
` (2 subsequent siblings)
3 siblings, 0 replies; 6+ messages in thread
From: Christophe JAILLET @ 2025-04-21 15:00 UTC (permalink / raw)
To: lee, krzk, alim.akhtar, s.nawrocki, m.szyprowski, ideal.song,
beomho.seo
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors, Christophe JAILLET, Krzysztof Kozlowski
If an error occurs after a successful regmap_init_mmio(), regmap_exit()
should be called as already done in the .remove() function.
Switch to devm_regmap_init_mmio() to avoid the leak and simplify the
.remove() function.
Fixes: c414df12bdf7 ("mfd: exynos-lpass: Add missing remove() function")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
---
Compile tested only.
Changes in v2:
- Add R-b tag
- Change the commit ID in Fixes
v1: https://lore.kernel.org/all/d125cbc479f1fa838ed0ff25f0e11d25f382e9d4.1743231856.git.christophe.jaillet@wanadoo.fr/
---
drivers/mfd/exynos-lpass.c | 5 ++---
1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/drivers/mfd/exynos-lpass.c b/drivers/mfd/exynos-lpass.c
index 6a585173230b..6b95927e99be 100644
--- a/drivers/mfd/exynos-lpass.c
+++ b/drivers/mfd/exynos-lpass.c
@@ -122,8 +122,8 @@ static int exynos_lpass_probe(struct platform_device *pdev)
if (IS_ERR(lpass->sfr0_clk))
return PTR_ERR(lpass->sfr0_clk);
- lpass->top = regmap_init_mmio(dev, base_top,
- &exynos_lpass_reg_conf);
+ lpass->top = devm_regmap_init_mmio(dev, base_top,
+ &exynos_lpass_reg_conf);
if (IS_ERR(lpass->top)) {
dev_err(dev, "LPASS top regmap initialization failed\n");
return PTR_ERR(lpass->top);
@@ -145,7 +145,6 @@ static void exynos_lpass_remove(struct platform_device *pdev)
pm_runtime_disable(&pdev->dev);
if (!pm_runtime_status_suspended(&pdev->dev))
exynos_lpass_disable(lpass);
- regmap_exit(lpass->top);
}
static int __maybe_unused exynos_lpass_suspend(struct device *dev)
--
2.49.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH v2 2/3] mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in exynos_lpass_remove()
2025-04-21 15:00 [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe() Christophe JAILLET
@ 2025-04-21 15:00 ` Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe() Christophe JAILLET
2025-05-01 11:18 ` [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Lee Jones
3 siblings, 0 replies; 6+ messages in thread
From: Christophe JAILLET @ 2025-04-21 15:00 UTC (permalink / raw)
To: lee, krzk, alim.akhtar, s.nawrocki, m.szyprowski, ideal.song,
beomho.seo
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors, Christophe JAILLET, Krzysztof Kozlowski
exynos_lpass_disable() is called twice in the remove function. Remove
one of these calls.
Fixes: 90f447170c6f ("mfd: exynos-lpass: Add runtime PM support")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
---
Compile tested only.
Changes in v2:
- Add R-b tag
v1: https://lore.kernel.org/all/ee6241d024c4cb68622dde9d65d8712016f4205e.1743231856.git.christophe.jaillet@wanadoo.fr/
---
drivers/mfd/exynos-lpass.c | 1 -
1 file changed, 1 deletion(-)
diff --git a/drivers/mfd/exynos-lpass.c b/drivers/mfd/exynos-lpass.c
index 6b95927e99be..a2785ceea8bf 100644
--- a/drivers/mfd/exynos-lpass.c
+++ b/drivers/mfd/exynos-lpass.c
@@ -141,7 +141,6 @@ static void exynos_lpass_remove(struct platform_device *pdev)
{
struct exynos_lpass *lpass = platform_get_drvdata(pdev);
- exynos_lpass_disable(lpass);
pm_runtime_disable(&pdev->dev);
if (!pm_runtime_status_suspended(&pdev->dev))
exynos_lpass_disable(lpass);
--
2.49.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe()
2025-04-21 15:00 [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe() Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 2/3] mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in exynos_lpass_remove() Christophe JAILLET
@ 2025-04-21 15:00 ` Christophe JAILLET
2025-04-23 16:33 ` Krzysztof Kozlowski
2025-05-01 11:18 ` [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Lee Jones
3 siblings, 1 reply; 6+ messages in thread
From: Christophe JAILLET @ 2025-04-21 15:00 UTC (permalink / raw)
To: lee, krzk, alim.akhtar, s.nawrocki, m.szyprowski, ideal.song,
beomho.seo
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors, Christophe JAILLET
If devm_of_platform_populate() fails, some clean-up needs to be done, as
already done in the remove function.
Add a new devm_add_action_or_reset() to fix the leak in the probe and
remove the need of a remove function.
Fixes: c695abab2429 ("mfd: Add Samsung Exynos Low Power Audio Subsystem driver")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
---
Compile tested only.
Changes in v2:
- Use a new devm_add_action_or_reset() to fix the leak in the probe
and remove the need of a remove function.
- Update the commit description accordingly
v1: https://lore.kernel.org/all/d224865a16b50498279b044a819e1e187d01bb28.1743231856.git.christophe.jaillet@wanadoo.fr/
---
drivers/mfd/exynos-lpass.c | 25 +++++++++++++++----------
1 file changed, 15 insertions(+), 10 deletions(-)
diff --git a/drivers/mfd/exynos-lpass.c b/drivers/mfd/exynos-lpass.c
index a2785ceea8bf..44797001a432 100644
--- a/drivers/mfd/exynos-lpass.c
+++ b/drivers/mfd/exynos-lpass.c
@@ -104,11 +104,22 @@ static const struct regmap_config exynos_lpass_reg_conf = {
.fast_io = true,
};
+static void exynos_lpass_disable_lpass(void *data)
+{
+ struct platform_device *pdev = data;
+ struct exynos_lpass *lpass = platform_get_drvdata(pdev);
+
+ pm_runtime_disable(&pdev->dev);
+ if (!pm_runtime_status_suspended(&pdev->dev))
+ exynos_lpass_disable(lpass);
+}
+
static int exynos_lpass_probe(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
struct exynos_lpass *lpass;
void __iomem *base_top;
+ int ret;
lpass = devm_kzalloc(dev, sizeof(*lpass), GFP_KERNEL);
if (!lpass)
@@ -134,16 +145,11 @@ static int exynos_lpass_probe(struct platform_device *pdev)
pm_runtime_enable(dev);
exynos_lpass_enable(lpass);
- return devm_of_platform_populate(dev);
-}
-
-static void exynos_lpass_remove(struct platform_device *pdev)
-{
- struct exynos_lpass *lpass = platform_get_drvdata(pdev);
+ ret = devm_add_action_or_reset(dev, exynos_lpass_disable_lpass, pdev);
+ if (ret)
+ return ret;
- pm_runtime_disable(&pdev->dev);
- if (!pm_runtime_status_suspended(&pdev->dev))
- exynos_lpass_disable(lpass);
+ return devm_of_platform_populate(dev);
}
static int __maybe_unused exynos_lpass_suspend(struct device *dev)
@@ -183,7 +189,6 @@ static struct platform_driver exynos_lpass_driver = {
.of_match_table = exynos_lpass_of_match,
},
.probe = exynos_lpass_probe,
- .remove = exynos_lpass_remove,
};
module_platform_driver(exynos_lpass_driver);
--
2.49.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe()
2025-04-21 15:00 ` [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe() Christophe JAILLET
@ 2025-04-23 16:33 ` Krzysztof Kozlowski
0 siblings, 0 replies; 6+ messages in thread
From: Krzysztof Kozlowski @ 2025-04-23 16:33 UTC (permalink / raw)
To: Christophe JAILLET, lee, alim.akhtar, s.nawrocki, m.szyprowski,
ideal.song, beomho.seo
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors
On 21/04/2025 17:00, Christophe JAILLET wrote:
> If devm_of_platform_populate() fails, some clean-up needs to be done, as
> already done in the remove function.
>
> Add a new devm_add_action_or_reset() to fix the leak in the probe and
> remove the need of a remove function.
>
> Fixes: c695abab2429 ("mfd: Add Samsung Exynos Low Power Audio Subsystem driver")
> Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
> ---
> Compile tested only.
>
> Changes in v2:
> - Use a new devm_add_action_or_reset() to fix the leak in the probe
> and remove the need of a remove function.
> - Update the commit description accordingly
Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Best regards,
Krzysztof
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths
2025-04-21 15:00 [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Christophe JAILLET
` (2 preceding siblings ...)
2025-04-21 15:00 ` [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe() Christophe JAILLET
@ 2025-05-01 11:18 ` Lee Jones
3 siblings, 0 replies; 6+ messages in thread
From: Lee Jones @ 2025-05-01 11:18 UTC (permalink / raw)
To: lee, krzk, alim.akhtar, s.nawrocki, m.szyprowski, ideal.song,
beomho.seo, Christophe JAILLET
Cc: linux-arm-kernel, linux-samsung-soc, linux-kernel,
kernel-janitors
On Mon, 21 Apr 2025 17:00:32 +0200, Christophe JAILLET wrote:
> This serie fixes several issues related to error handling paths in
> drivers/mfd/exynos-lpass.c.
>
> I've split it in 3 patches to ease review, but it could be merge in only
> 1 patch if preferred.
>
> Patch 1: Fix a leak in the error handling path of the probe. It should
> be straighforward. This patch is already R-b.
>
> [...]
Applied, thanks!
[1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe()
commit: 8cc4952d1e8618eff474dc7154c6537db88178df
[2/3] mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in exynos_lpass_remove()
commit: cb931849ec1e71900eb54d0a377ae30e0bcfcffa
[3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe()
commit: f408e20757afa3d8c719a8a804cd2c83262514dd
--
Lee Jones [李琼斯]
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2025-05-01 11:21 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-04-21 15:00 [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 1/3] mfd: exynos-lpass: Fix an error handling path in exynos_lpass_probe() Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 2/3] mfd: exynos-lpass: Avoid calling exynos_lpass_disable() twice in exynos_lpass_remove() Christophe JAILLET
2025-04-21 15:00 ` [PATCH v2 3/3] mfd: exynos-lpass: Fix another error handling path in exynos_lpass_probe() Christophe JAILLET
2025-04-23 16:33 ` Krzysztof Kozlowski
2025-05-01 11:18 ` [PATCH v2 0/3] mfd: exynos-lpass: Fix some error handling paths Lee Jones
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).