aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorShaohua Li <shli@fb.com>2016-09-30 12:45:40 -0400
committerShaohua Li <shli@fb.com>2016-10-03 13:20:27 -0400
commitbb086a89a406b5d877ee616f1490fcc81f8e1b2b (patch)
treed74a8a87ec39992d499e81a98c3de7a456d62486
parent099b548c429217a8306adbd1552d326615c9b903 (diff)
md: set rotational bit
if all disks in an array are non-rotational, set the array non-rotational. This only works for array with all disks populated at startup. Support for disk hotadd/hotremove could be added later if necessary. Acked-by: Tejun Heo <tj@kernel.org> Signed-off-by: Shaohua Li <shli@fb.com>
-rw-r--r--drivers/md/md.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c
index 457b53863117..eac84d8ff724 100644
--- a/drivers/md/md.c
+++ b/drivers/md/md.c
@@ -5297,6 +5297,21 @@ int md_run(struct mddev *mddev)
5297 return err; 5297 return err;
5298 } 5298 }
5299 if (mddev->queue) { 5299 if (mddev->queue) {
5300 bool nonrot = true;
5301
5302 rdev_for_each(rdev, mddev) {
5303 if (rdev->raid_disk >= 0 &&
5304 !blk_queue_nonrot(bdev_get_queue(rdev->bdev))) {
5305 nonrot = false;
5306 break;
5307 }
5308 }
5309 if (mddev->degraded)
5310 nonrot = false;
5311 if (nonrot)
5312 queue_flag_set_unlocked(QUEUE_FLAG_NONROT, mddev->queue);
5313 else
5314 queue_flag_clear_unlocked(QUEUE_FLAG_NONROT, mddev->queue);
5300 mddev->queue->backing_dev_info.congested_data = mddev; 5315 mddev->queue->backing_dev_info.congested_data = mddev;
5301 mddev->queue->backing_dev_info.congested_fn = md_congested; 5316 mddev->queue->backing_dev_info.congested_fn = md_congested;
5302 } 5317 }