summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Axboe <axboe@fb.com>2015-07-14 12:42:35 -0600
committerJens Axboe <axboe@fb.com>2015-07-15 10:17:15 -0600
commit9d3e5d88441e427849bc94ee304e8822befc58ac (patch)
tree5edc1fc87d61874a71501d2350997438eacad359
parentd4d58d2fb206c4bef37e5143a3b7be1843d5ec67 (diff)
block: by default, limit maximum discard size to 64MBdiscard-rw
Lots of devices exhibit very high latencies for big discards, hurting reads and writes. By default, limit the max discard we will build to 64MB. This value has shown good results across a number of devices. This will potentially hurt discard throughput, from a provisioning point of view (when the user does mkfs.xfs, for instance, and mkfs issues a full device discard). If that becomes an issue, we could have different behavior for provisioning vs runtime discards. Signed-off-by: Jens Axboe <axboe@fb.com>
-rw-r--r--block/blk-settings.c2
-rw-r--r--include/linux/blkdev.h5
2 files changed, 7 insertions, 0 deletions
diff --git a/block/blk-settings.c b/block/blk-settings.c
index b38d8d723276..b98d26fcbf81 100644
--- a/block/blk-settings.c
+++ b/block/blk-settings.c
@@ -306,6 +306,8 @@ void blk_queue_max_discard_sectors(struct request_queue *q,
{
q->limits.max_hw_discard_sectors = max_discard_sectors;
q->limits.max_discard_sectors = max_discard_sectors;
+ if (q->limits.max_discard_sectors > BLK_DISCARD_MAX_SECTORS)
+ q->limits.max_discard_sectors = BLK_DISCARD_MAX_SECTORS;
}
EXPORT_SYMBOL(blk_queue_max_discard_sectors);
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h
index 243f29e779ec..3a01b16397c4 100644
--- a/include/linux/blkdev.h
+++ b/include/linux/blkdev.h
@@ -1141,6 +1141,11 @@ enum blk_default_limits {
BLK_SAFE_MAX_SECTORS = 255,
BLK_MAX_SEGMENT_SIZE = 65536,
BLK_SEG_BOUNDARY_MASK = 0xFFFFFFFFUL,
+
+ /*
+ * Default to max 64MB of discards, to keep latencies in check
+ */
+ BLK_DISCARD_MAX_SECTORS = (64 * 1024 * 1024UL) >> 9,
};
#define blkdev_entry_to_request(entry) list_entry((entry), struct request, queuelist)