lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20260107144925.1466-2-qikeyu2017@gmail.com>
Date: Wed,  7 Jan 2026 22:49:26 +0800
From: Kery Qi <qikeyu2017@...il.com>
To: peter.ujfalusi@...il.com
Cc: linux-kernel@...r.kernel.org,
	Kery Qi <qikeyu2017@...il.com>
Subject: [PATCH] ASoC: omap-twl4030: Add missing of_node_put() in omap_twl4030_probe

The omap_twl4030_probe() function calls of_parse_phandle() to acquire
device nodes for the "ti,mcbsp" and "ti,mcbsp-voice" properties.
of_parse_phandle() returns a device node with its reference count
incremented.

If snd_soc_of_parse_audio_routing() or devm_snd_soc_register_card()
fails, the function returns an error without releasing the acquired
device node, which leads to a reference leak.

This patch adds the missing of_node_put() in the error handling paths
to properly decrement the reference count. It also resets the of_node
pointers in the dai_links array to NULL to ensure a clean state upon
failure.

Signed-off-by: Kery Qi <qikeyu2017@...il.com>
---
 sound/soc/ti/omap-twl4030.c | 15 ++++++++++++++-
 1 file changed, 14 insertions(+), 1 deletion(-)

diff --git a/sound/soc/ti/omap-twl4030.c b/sound/soc/ti/omap-twl4030.c
index 4d80f8a7a947..74ec05c915c6 100644
--- a/sound/soc/ti/omap-twl4030.c
+++ b/sound/soc/ti/omap-twl4030.c
@@ -285,8 +285,15 @@ static int omap_twl4030_probe(struct platform_device *pdev)
 		if (prop) {
 			ret = snd_soc_of_parse_audio_routing(card,
 							    "ti,audio-routing");
-			if (ret)
+			if (ret) {
+				omap_twl4030_dai_links[0].cpus->of_node = NULL;
+				omap_twl4030_dai_links[0].platforms->of_node = NULL;
+				omap_twl4030_dai_links[1].cpus->of_node = NULL;
+				omap_twl4030_dai_links[1].platforms->of_node = NULL;
+				if (dai_node)
+					of_node_put(dai_node);
 				return ret;
+			}
 
 			card->fully_routed = 1;
 		}
@@ -310,6 +317,12 @@ static int omap_twl4030_probe(struct platform_device *pdev)
 	if (ret) {
 		dev_err(&pdev->dev, "devm_snd_soc_register_card() failed: %d\n",
 			ret);
+		omap_twl4030_dai_links[0].cpus->of_node = NULL;
+		omap_twl4030_dai_links[0].platforms->of_node = NULL;
+		omap_twl4030_dai_links[1].cpus->of_node = NULL;
+		omap_twl4030_dai_links[1].platforms->of_node = NULL;
+		if (dai_node)
+			of_node_put(dai_node);
 		return ret;
 	}
 
-- 
2.34.1


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ