diff options
author | Jens Axboe <axboe@kernel.dk> | 2012-05-01 08:29:55 -0400 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2012-05-01 08:29:55 -0400 |
commit | 0b7877d4eea3f93e3dd941999522bbd8c538cb53 (patch) | |
tree | ade6d4e411b9b9b569c802e3b2179826162c934c /block/cfq-iosched.c | |
parent | bd1a68b59c8e3bce45fb76632c64e1e063c3962d (diff) | |
parent | 69964ea4c7b68c9399f7977aa5b9aa6539a6a98a (diff) |
Merge tag 'v3.4-rc5' into for-3.5/core
The core branch is behind driver commits that we want to build
on for 3.5, hence I'm pulling in a later -rc.
Linux 3.4-rc5
Conflicts:
Documentation/feature-removal-schedule.txt
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'block/cfq-iosched.c')
-rw-r--r-- | block/cfq-iosched.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 832b2ac8cb8d..673c977cc2bf 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
@@ -343,6 +343,7 @@ struct cfq_data { | |||
343 | unsigned int cfq_slice_idle; | 343 | unsigned int cfq_slice_idle; |
344 | unsigned int cfq_group_idle; | 344 | unsigned int cfq_group_idle; |
345 | unsigned int cfq_latency; | 345 | unsigned int cfq_latency; |
346 | unsigned int cfq_target_latency; | ||
346 | 347 | ||
347 | /* | 348 | /* |
348 | * Fallback dummy cfqq for extreme OOM conditions | 349 | * Fallback dummy cfqq for extreme OOM conditions |
@@ -910,7 +911,7 @@ cfq_group_slice(struct cfq_data *cfqd, struct cfq_group *cfqg) | |||
910 | { | 911 | { |
911 | struct cfq_rb_root *st = &cfqd->grp_service_tree; | 912 | struct cfq_rb_root *st = &cfqd->grp_service_tree; |
912 | 913 | ||
913 | return cfq_target_latency * cfqg->weight / st->total_weight; | 914 | return cfqd->cfq_target_latency * cfqg->weight / st->total_weight; |
914 | } | 915 | } |
915 | 916 | ||
916 | static inline unsigned | 917 | static inline unsigned |
@@ -2579,7 +2580,8 @@ new_workload: | |||
2579 | * to have higher weight. A more accurate thing would be to | 2580 | * to have higher weight. A more accurate thing would be to |
2580 | * calculate system wide asnc/sync ratio. | 2581 | * calculate system wide asnc/sync ratio. |
2581 | */ | 2582 | */ |
2582 | tmp = cfq_target_latency * cfqg_busy_async_queues(cfqd, cfqg); | 2583 | tmp = cfqd->cfq_target_latency * |
2584 | cfqg_busy_async_queues(cfqd, cfqg); | ||
2583 | tmp = tmp/cfqd->busy_queues; | 2585 | tmp = tmp/cfqd->busy_queues; |
2584 | slice = min_t(unsigned, slice, tmp); | 2586 | slice = min_t(unsigned, slice, tmp); |
2585 | 2587 | ||
@@ -4026,6 +4028,7 @@ static int cfq_init_queue(struct request_queue *q) | |||
4026 | cfqd->cfq_back_penalty = cfq_back_penalty; | 4028 | cfqd->cfq_back_penalty = cfq_back_penalty; |
4027 | cfqd->cfq_slice[0] = cfq_slice_async; | 4029 | cfqd->cfq_slice[0] = cfq_slice_async; |
4028 | cfqd->cfq_slice[1] = cfq_slice_sync; | 4030 | cfqd->cfq_slice[1] = cfq_slice_sync; |
4031 | cfqd->cfq_target_latency = cfq_target_latency; | ||
4029 | cfqd->cfq_slice_async_rq = cfq_slice_async_rq; | 4032 | cfqd->cfq_slice_async_rq = cfq_slice_async_rq; |
4030 | cfqd->cfq_slice_idle = cfq_slice_idle; | 4033 | cfqd->cfq_slice_idle = cfq_slice_idle; |
4031 | cfqd->cfq_group_idle = cfq_group_idle; | 4034 | cfqd->cfq_group_idle = cfq_group_idle; |
@@ -4081,6 +4084,7 @@ SHOW_FUNCTION(cfq_slice_sync_show, cfqd->cfq_slice[1], 1); | |||
4081 | SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1); | 4084 | SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1); |
4082 | SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0); | 4085 | SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0); |
4083 | SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0); | 4086 | SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0); |
4087 | SHOW_FUNCTION(cfq_target_latency_show, cfqd->cfq_target_latency, 1); | ||
4084 | #undef SHOW_FUNCTION | 4088 | #undef SHOW_FUNCTION |
4085 | 4089 | ||
4086 | #define STORE_FUNCTION(__FUNC, __PTR, MIN, MAX, __CONV) \ | 4090 | #define STORE_FUNCTION(__FUNC, __PTR, MIN, MAX, __CONV) \ |
@@ -4114,6 +4118,7 @@ STORE_FUNCTION(cfq_slice_async_store, &cfqd->cfq_slice[0], 1, UINT_MAX, 1); | |||
4114 | STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1, | 4118 | STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1, |
4115 | UINT_MAX, 0); | 4119 | UINT_MAX, 0); |
4116 | STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0); | 4120 | STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0); |
4121 | STORE_FUNCTION(cfq_target_latency_store, &cfqd->cfq_target_latency, 1, UINT_MAX, 1); | ||
4117 | #undef STORE_FUNCTION | 4122 | #undef STORE_FUNCTION |
4118 | 4123 | ||
4119 | #define CFQ_ATTR(name) \ | 4124 | #define CFQ_ATTR(name) \ |
@@ -4131,6 +4136,7 @@ static struct elv_fs_entry cfq_attrs[] = { | |||
4131 | CFQ_ATTR(slice_idle), | 4136 | CFQ_ATTR(slice_idle), |
4132 | CFQ_ATTR(group_idle), | 4137 | CFQ_ATTR(group_idle), |
4133 | CFQ_ATTR(low_latency), | 4138 | CFQ_ATTR(low_latency), |
4139 | CFQ_ATTR(target_latency), | ||
4134 | __ATTR_NULL | 4140 | __ATTR_NULL |
4135 | }; | 4141 | }; |
4136 | 4142 | ||