aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2016-02-23 19:03:43 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2016-02-23 19:03:43 -0800
commit84e54c46b2f440a365a5224f1e5f173a462b7cca (patch)
tree09668bb0e36ce76575c5d52e1eca399b7235d64c
parentMerge tag 'mmc-v4.5-rc4' of git://git.linaro.org/people/ulf.hansson/mmc (diff)
parentdm: fix dm_rq_target_io leak on faults with .request_fn DM w/ blk-mq paths (diff)
downloadlinux-dev-84e54c46b2f440a365a5224f1e5f173a462b7cca.tar.xz
linux-dev-84e54c46b2f440a365a5224f1e5f173a462b7cca.zip
Merge tag 'dm-4.5-fix' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm
Pull device mapper fix from Mike Snitzer: "Fix a 112 byte leak for each IO request that is requeued while DM multipath is handling faults due to path failures. This leak does not happen if blk-mq DM multipath is used. It only occurs if .request_fn DM multipath is stacked ontop of blk-mq paths (e.g. scsi-mq devices)" * tag 'dm-4.5-fix' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm: dm: fix dm_rq_target_io leak on faults with .request_fn DM w/ blk-mq paths
-rw-r--r--drivers/md/dm.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/md/dm.c b/drivers/md/dm.c
index 5df40480228b..dd834927bc66 100644
--- a/drivers/md/dm.c
+++ b/drivers/md/dm.c
@@ -1191,6 +1191,8 @@ static void dm_unprep_request(struct request *rq)
if (clone)
free_rq_clone(clone);
+ else if (!tio->md->queue->mq_ops)
+ free_rq_tio(tio);
}
/*