summaryrefslogtreecommitdiffstats
path: root/drivers/s390/block/dasd_genhd.c
diff options
context:
space:
mode:
authorStefan Weinhuber <wein@de.ibm.com>2013-11-29 15:37:20 +0100
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2013-12-02 15:31:06 +0100
commitb2b0154e49e2b9470ae0d082128b5549cbe71152 (patch)
tree6259d0944460c1597ed0406436d5aea88a38a84f /drivers/s390/block/dasd_genhd.c
parentima: store address of template_fmt_copy in a pointer before calling strsep (diff)
downloadlinux-b2b0154e49e2b9470ae0d082128b5549cbe71152.tar.xz
linux-b2b0154e49e2b9470ae0d082128b5549cbe71152.zip
s390/dasd: fix memory leak caused by dangling references to request_queue
After the call to del_gendisk, the gendisk still holds a reference to its request_queue. We must not modify the gendisks queue pointer before the put_disk call, or the gendisk_release function cannot release the reference and the memory for the request_queue structure is lost. Signed-off-by: Stefan Weinhuber <wein@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390/block/dasd_genhd.c')
-rw-r--r--drivers/s390/block/dasd_genhd.c1
1 files changed, 0 insertions, 1 deletions
diff --git a/drivers/s390/block/dasd_genhd.c b/drivers/s390/block/dasd_genhd.c
index f64921756ad6..f224d59c4b6b 100644
--- a/drivers/s390/block/dasd_genhd.c
+++ b/drivers/s390/block/dasd_genhd.c
@@ -87,7 +87,6 @@ void dasd_gendisk_free(struct dasd_block *block)
{
if (block->gdp) {
del_gendisk(block->gdp);
- block->gdp->queue = NULL;
block->gdp->private_data = NULL;
put_disk(block->gdp);
block->gdp = NULL;