linux-gpio.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] pinctrl: sophgo: fix double free in cv1800_pctrl_dt_node_to_map()
@ 2024-10-10 11:18 Harshit Mogalapalli
  2024-10-10 17:17 ` Christophe JAILLET
  2024-10-10 19:13 ` Linus Walleij
  0 siblings, 2 replies; 6+ messages in thread
From: Harshit Mogalapalli @ 2024-10-10 11:18 UTC (permalink / raw)
  To: Linus Walleij, Chen Wang, Inochi Amaoto, Harshit Mogalapalli,
	linux-gpio, linux-kernel
  Cc: dan.carpenter, kernel-janitors, error27

'map' is allocated using devm_* which takes care of freeing the allocated
data, but in error paths there is a call to pinctrl_utils_free_map()
which also does kfree(map) which leads to a double free.

Use kcalloc() instead of devm_kcalloc() as freeing is manually handled.

Fixes: a29d8e93e710 ("pinctrl: sophgo: add support for CV1800B SoC")
Signed-off-by: Harshit Mogalapalli <harshit.m.mogalapalli@oracle.com>
---
This is based on static analysis with smatch, only compile tested.
---
 drivers/pinctrl/sophgo/pinctrl-cv18xx.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/pinctrl/sophgo/pinctrl-cv18xx.c b/drivers/pinctrl/sophgo/pinctrl-cv18xx.c
index d18fc5aa84f7..57f2674e75d6 100644
--- a/drivers/pinctrl/sophgo/pinctrl-cv18xx.c
+++ b/drivers/pinctrl/sophgo/pinctrl-cv18xx.c
@@ -221,7 +221,7 @@ static int cv1800_pctrl_dt_node_to_map(struct pinctrl_dev *pctldev,
 	if (!grpnames)
 		return -ENOMEM;
 
-	map = devm_kcalloc(dev, ngroups * 2, sizeof(*map), GFP_KERNEL);
+	map = kcalloc(ngroups * 2, sizeof(*map), GFP_KERNEL);
 	if (!map)
 		return -ENOMEM;
 
-- 
2.39.3


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2024-10-10 20:32 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-10 11:18 [PATCH] pinctrl: sophgo: fix double free in cv1800_pctrl_dt_node_to_map() Harshit Mogalapalli
2024-10-10 17:17 ` Christophe JAILLET
2024-10-10 18:33   ` Dan Carpenter
2024-10-10 20:32     ` Christophe JAILLET
2024-10-10 19:11   ` Harshit Mogalapalli
2024-10-10 19:13 ` Linus Walleij

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).