public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] DMA: Fix broken device refcounting
@ 2007-10-26 16:12 Haavard Skinnemoen
  2007-10-26 16:36 ` Dan Williams
                   ` (2 more replies)
  0 siblings, 3 replies; 9+ messages in thread
From: Haavard Skinnemoen @ 2007-10-26 16:12 UTC (permalink / raw)
  To: Shannon Nelson; +Cc: Dan Williams, linux-kernel, akpm, Haavard Skinnemoen

When a DMA device is unregistered, its reference count is decremented
twice for each channel: Once dma_class_dev_release() and once in
dma_chan_cleanup(). This may result in the DMA device driver's
remove() function completing before all channels have been cleaned
up, causing lots of use-after-free fun.

Fix it by incrementing the device's reference count twice for each
channel during registration.

Signed-off-by: Haavard Skinnemoen <hskinnemoen@atmel.com>
---
I'm not sure if this is the correct way to solve it, but it seems to
work. The remove() function does not hang, which indicates that the
device's reference count does drop all the way to zero on
unregistration, which in turn indicates that it did actually drop
_below_ zero before.

 drivers/dma/dmaengine.c |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)

diff --git a/drivers/dma/dmaengine.c b/drivers/dma/dmaengine.c
index 8248992..302eded 100644
--- a/drivers/dma/dmaengine.c
+++ b/drivers/dma/dmaengine.c
@@ -397,6 +397,8 @@ int dma_async_device_register(struct dma_device *device)
 			goto err_out;
 		}
 
+		/* One for the channel, one of the class device */
+		kref_get(&device->refcount);
 		kref_get(&device->refcount);
 		kref_init(&chan->refcount);
 		chan->slow_ref = 0;
-- 
1.5.2.5


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

end of thread, other threads:[~2007-10-29 16:11 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-10-26 16:12 [PATCH] DMA: Fix broken device refcounting Haavard Skinnemoen
2007-10-26 16:36 ` Dan Williams
2007-10-27 13:49   ` Haavard Skinnemoen
2007-10-27 19:12     ` Dan Williams
2007-10-28 19:17       ` Shannon Nelson
2007-10-29 16:02       ` Nelson, Shannon
2007-10-29 16:11         ` Haavard Skinnemoen
2007-10-26 16:59 ` Nelson, Shannon
2007-10-26 17:10 ` Nelson, Shannon

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