summaryrefslogtreecommitdiffstats
path: root/drivers/mmc/core
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2019-06-05 21:08:27 +0200
committerJens Axboe <axboe@kernel.dk>2019-06-05 21:18:39 +0200
commitcf1db7fc8c2d31222701bd5c01b9cbaf89d8e7ce (patch)
treef44f4db009d754ea70376bf3b8a75f8c7594b3c8 /drivers/mmc/core
parentmtip32xx: also set max_segment_size in the device (diff)
downloadlinux-cf1db7fc8c2d31222701bd5c01b9cbaf89d8e7ce.tar.xz
linux-cf1db7fc8c2d31222701bd5c01b9cbaf89d8e7ce.zip
mmc: also set max_segment_size in the device
If we only set the max_segment_size on the queue an IOMMU merge might create bigger segments again, so limit the IOMMU merges as well. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/mmc/core')
-rw-r--r--drivers/mmc/core/queue.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/mmc/core/queue.c b/drivers/mmc/core/queue.c
index b5b9c6142f08..92900a095796 100644
--- a/drivers/mmc/core/queue.c
+++ b/drivers/mmc/core/queue.c
@@ -377,6 +377,8 @@ static void mmc_setup_queue(struct mmc_queue *mq, struct mmc_card *card)
blk_queue_max_segment_size(mq->queue,
round_down(host->max_seg_size, block_size));
+ dma_set_max_seg_size(mmc_dev(host), queue_max_segment_size(mq->queue));
+
INIT_WORK(&mq->recovery_work, mmc_mq_recovery_handler);
INIT_WORK(&mq->complete_work, mmc_blk_mq_complete_work);