diff options
author | Shaohua Li <shli@fb.com> | 2016-09-30 12:45:40 -0400 |
---|---|---|
committer | Shaohua Li <shli@fb.com> | 2016-10-03 13:20:27 -0400 |
commit | bb086a89a406b5d877ee616f1490fcc81f8e1b2b (patch) | |
tree | d74a8a87ec39992d499e81a98c3de7a456d62486 | |
parent | 099b548c429217a8306adbd1552d326615c9b903 (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.c | 15 |
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 | } |