• M
    dm mpath: fix leak of dm_mpath_io structure in blk-mq .queue_rq error path · 4c6dd53d
    Mike Snitzer 提交于
    Otherwise kmemleak reported:
    
    unreferenced object 0xffff88009b14e2b0 (size 16):
      comm "fio", pid 4274, jiffies 4294978034 (age 1253.210s)
      hex dump (first 16 bytes):
        40 12 f3 99 01 88 ff ff 00 10 00 00 00 00 00 00  @...............
      backtrace:
        [<ffffffff81600029>] kmemleak_alloc+0x49/0xb0
        [<ffffffff811679a8>] kmem_cache_alloc+0xf8/0x160
        [<ffffffff8111c950>] mempool_alloc_slab+0x10/0x20
        [<ffffffff8111cb37>] mempool_alloc+0x57/0x150
        [<ffffffffa04d2b61>] __multipath_map.isra.17+0xe1/0x220 [dm_multipath]
        [<ffffffffa04d2cb5>] multipath_clone_and_map+0x15/0x20 [dm_multipath]
        [<ffffffffa02889b5>] map_request.isra.39+0xd5/0x220 [dm_mod]
        [<ffffffffa028b0e4>] dm_mq_queue_rq+0x134/0x240 [dm_mod]
        [<ffffffff812cccb5>] __blk_mq_run_hw_queue+0x1d5/0x380
        [<ffffffff812ccaa5>] blk_mq_run_hw_queue+0xc5/0x100
        [<ffffffff812ce350>] blk_sq_make_request+0x240/0x300
        [<ffffffff812c0f30>] generic_make_request+0xc0/0x110
        [<ffffffff812c0ff2>] submit_bio+0x72/0x150
        [<ffffffff811c07cb>] do_blockdev_direct_IO+0x1f3b/0x2da0
        [<ffffffff811c166e>] __blockdev_direct_IO+0x3e/0x40
        [<ffffffff8120aa1a>] ext4_direct_IO+0x1aa/0x390
    
    Fixes: e5863d9a ("dm: allocate requests in target when stacking on blk-mq devices")
    Reported-by: NBart Van Assche <bart.vanassche@sandisk.com>
    Signed-off-by: NMike Snitzer <snitzer@redhat.com>
    Cc: stable@vger.kernel.org # 4.0+
    4c6dd53d
dm-mpath.c 41.0 KB