diff options
author | Jens Axboe <jens.axboe@oracle.com> | 2008-09-24 07:03:33 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2008-10-09 02:56:19 -0400 |
commit | a68bbddba486020c9c74825ce90c4c1ec463e0e8 (patch) | |
tree | ce0acea1e609185968310316d3d1ac6f730db983 /block | |
parent | 9e49184c82e9ec3ab4d45f9ea5a17ccaf43869f0 (diff) |
block: add queue flag for SSD/non-rotational devices
We don't want to idle in AS/CFQ if the device doesn't have a seek
penalty. So add a QUEUE_FLAG_NONROT to indicate a non-rotational
device, low level drivers should set this flag upon discovery of
an SSD or similar device type.
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
Diffstat (limited to 'block')
-rw-r--r-- | block/as-iosched.c | 6 | ||||
-rw-r--r-- | block/cfq-iosched.c | 6 |
2 files changed, 12 insertions, 0 deletions
diff --git a/block/as-iosched.c b/block/as-iosched.c index 80af9257e64a..4c6fafbba933 100644 --- a/block/as-iosched.c +++ b/block/as-iosched.c | |||
@@ -745,6 +745,12 @@ static int as_can_break_anticipation(struct as_data *ad, struct request *rq) | |||
745 | */ | 745 | */ |
746 | static int as_can_anticipate(struct as_data *ad, struct request *rq) | 746 | static int as_can_anticipate(struct as_data *ad, struct request *rq) |
747 | { | 747 | { |
748 | /* | ||
749 | * SSD device without seek penalty, disable idling | ||
750 | */ | ||
751 | if (blk_queue_nonrot(ad->q)) | ||
752 | return 0; | ||
753 | |||
748 | if (!ad->io_context) | 754 | if (!ad->io_context) |
749 | /* | 755 | /* |
750 | * Last request submitted was a write | 756 | * Last request submitted was a write |
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 494b6fdcb183..03a5953bb5df 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
@@ -878,6 +878,12 @@ static void cfq_arm_slice_timer(struct cfq_data *cfqd) | |||
878 | struct cfq_io_context *cic; | 878 | struct cfq_io_context *cic; |
879 | unsigned long sl; | 879 | unsigned long sl; |
880 | 880 | ||
881 | /* | ||
882 | * SSD device without seek penalty, disable idling | ||
883 | */ | ||
884 | if (blk_queue_nonrot(cfqd->queue)) | ||
885 | return; | ||
886 | |||
881 | WARN_ON(!RB_EMPTY_ROOT(&cfqq->sort_list)); | 887 | WARN_ON(!RB_EMPTY_ROOT(&cfqq->sort_list)); |
882 | WARN_ON(cfq_cfqq_slice_new(cfqq)); | 888 | WARN_ON(cfq_cfqq_slice_new(cfqq)); |
883 | 889 | ||