public inbox for linux-mtd@lists.infradead.org
 help / color / mirror / Atom feed
* [PATCH] mtd: Blackfin NFC: fix invalid free in remove()
@ 2010-08-28 20:42 Mike Frysinger
  2010-08-28 20:42 ` Mike Frysinger
  2010-08-30 12:58 ` Artem Bityutskiy
  0 siblings, 2 replies; 8+ messages in thread
From: Mike Frysinger @ 2010-08-28 20:42 UTC (permalink / raw)
  To: linux-mtd, David Woodhouse
  Cc: uclinux-dist-devel, Andrew Morton, linux-kernel

Since info->mtd isn't dynamically allocated, we shouldn't attempt to
kfree() it.  Otherwise we get random fun corruption when unloading
the driver built as a module.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
---
note: this should be merged for 2.6.36 and probably sent to stable trees

 drivers/mtd/nand/bf5xx_nand.c |    7 +------
 1 files changed, 1 insertions(+), 6 deletions(-)

diff --git a/drivers/mtd/nand/bf5xx_nand.c b/drivers/mtd/nand/bf5xx_nand.c
index 162c5ea..6fbeefa 100644
--- a/drivers/mtd/nand/bf5xx_nand.c
+++ b/drivers/mtd/nand/bf5xx_nand.c
@@ -682,7 +682,6 @@ static int __devinit bf5xx_nand_add_partition(struct bf5xx_nand_info *info)
 static int __devexit bf5xx_nand_remove(struct platform_device *pdev)
 {
 	struct bf5xx_nand_info *info = to_nand_info(pdev);
-	struct mtd_info *mtd = NULL;
 
 	platform_set_drvdata(pdev, NULL);
 
@@ -690,11 +689,7 @@ static int __devexit bf5xx_nand_remove(struct platform_device *pdev)
 	 * and their partitions, then go through freeing the
 	 * resources used
 	 */
-	mtd = &info->mtd;
-	if (mtd) {
-		nand_release(mtd);
-		kfree(mtd);
-	}
+	nand_release(&info->mtd);
 
 	peripheral_free_list(bfin_nfc_pin_req);
 	bf5xx_nand_dma_remove(info);
-- 
1.7.2.2

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

end of thread, other threads:[~2010-08-30 15:15 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-08-28 20:42 [PATCH] mtd: Blackfin NFC: fix invalid free in remove() Mike Frysinger
2010-08-28 20:42 ` Mike Frysinger
2010-08-30 12:58 ` Artem Bityutskiy
2010-08-30 12:59   ` Artem Bityutskiy
2010-08-30 13:32     ` [Uclinux-dist-devel] " Mike Frysinger
2010-08-30 15:10       ` Artem Bityutskiy
2010-08-30 15:14         ` Mike Frysinger
2010-08-30 13:31   ` Mike Frysinger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox