aboutsummaryrefslogtreecommitdiffstats
path: root/block/cfq-iosched.c
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2012-05-01 08:29:55 -0400
committerJens Axboe <axboe@kernel.dk>2012-05-01 08:29:55 -0400
commit0b7877d4eea3f93e3dd941999522bbd8c538cb53 (patch)
treeade6d4e411b9b9b569c802e3b2179826162c934c /block/cfq-iosched.c
parentbd1a68b59c8e3bce45fb76632c64e1e063c3962d (diff)
parent69964ea4c7b68c9399f7977aa5b9aa6539a6a98a (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.c10
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
916static inline unsigned 917static 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);
4081SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1); 4084SHOW_FUNCTION(cfq_slice_async_show, cfqd->cfq_slice[0], 1);
4082SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0); 4085SHOW_FUNCTION(cfq_slice_async_rq_show, cfqd->cfq_slice_async_rq, 0);
4083SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0); 4086SHOW_FUNCTION(cfq_low_latency_show, cfqd->cfq_latency, 0);
4087SHOW_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);
4114STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1, 4118STORE_FUNCTION(cfq_slice_async_rq_store, &cfqd->cfq_slice_async_rq, 1,
4115 UINT_MAX, 0); 4119 UINT_MAX, 0);
4116STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0); 4120STORE_FUNCTION(cfq_low_latency_store, &cfqd->cfq_latency, 0, 1, 0);
4121STORE_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