aboutsummaryrefslogtreecommitdiffstats
path: root/Documentation/block
diff options
context:
space:
mode:
Diffstat (limited to 'Documentation/block')
-rw-r--r--Documentation/block/cfq-iosched.txt47
1 files changed, 44 insertions, 3 deletions
diff --git a/Documentation/block/cfq-iosched.txt b/Documentation/block/cfq-iosched.txt
index a5eb7d19a65d..9887f0414c16 100644
--- a/Documentation/block/cfq-iosched.txt
+++ b/Documentation/block/cfq-iosched.txt
@@ -5,7 +5,7 @@ The main aim of CFQ scheduler is to provide a fair allocation of the disk
5I/O bandwidth for all the processes which requests an I/O operation. 5I/O bandwidth for all the processes which requests an I/O operation.
6 6
7CFQ maintains the per process queue for the processes which request I/O 7CFQ maintains the per process queue for the processes which request I/O
8operation(syncronous requests). In case of asynchronous requests, all the 8operation(synchronous requests). In case of asynchronous requests, all the
9requests from all the processes are batched together according to their 9requests from all the processes are batched together according to their
10process's I/O priority. 10process's I/O priority.
11 11
@@ -66,6 +66,47 @@ This parameter is used to set the timeout of synchronous requests. Default
66value of this is 124ms. In case to favor synchronous requests over asynchronous 66value of this is 124ms. In case to favor synchronous requests over asynchronous
67one, this value should be decreased relative to fifo_expire_async. 67one, this value should be decreased relative to fifo_expire_async.
68 68
69group_idle
70-----------
71This parameter forces idling at the CFQ group level instead of CFQ
72queue level. This was introduced after after a bottleneck was observed
73in higher end storage due to idle on sequential queue and allow dispatch
74from a single queue. The idea with this parameter is that it can be run with
75slice_idle=0 and group_idle=8, so that idling does not happen on individual
76queues in the group but happens overall on the group and thus still keeps the
77IO controller working.
78Not idling on individual queues in the group will dispatch requests from
79multiple queues in the group at the same time and achieve higher throughput
80on higher end storage.
81
82Default value for this parameter is 8ms.
83
84latency
85-------
86This parameter is used to enable/disable the latency mode of the CFQ
87scheduler. If latency mode (called low_latency) is enabled, CFQ tries
88to recompute the slice time for each process based on the target_latency set
89for the system. This favors fairness over throughput. Disabling low
90latency (setting it to 0) ignores target latency, allowing each process in the
91system to get a full time slice.
92
93By default low latency mode is enabled.
94
95target_latency
96--------------
97This parameter is used to calculate the time slice for a process if cfq's
98latency mode is enabled. It will ensure that sync requests have an estimated
99latency. But if sequential workload is higher(e.g. sequential read),
100then to meet the latency constraints, throughput may decrease because of less
101time for each process to issue I/O request before the cfq queue is switched.
102
103Though this can be overcome by disabling the latency_mode, it may increase
104the read latency for some applications. This parameter allows for changing
105target_latency through the sysfs interface which can provide the balanced
106throughput and read latency.
107
108Default value for target_latency is 300ms.
109
69slice_async 110slice_async
70----------- 111-----------
71This parameter is same as of slice_sync but for asynchronous queue. The 112This parameter is same as of slice_sync but for asynchronous queue. The
@@ -98,8 +139,8 @@ in the device exceeds this parameter. This parameter is used for synchronous
98request. 139request.
99 140
100In case of storage with several disk, this setting can limit the parallel 141In case of storage with several disk, this setting can limit the parallel
101processing of request. Therefore, increasing the value can imporve the 142processing of request. Therefore, increasing the value can improve the
102performace although this can cause the latency of some I/O to increase due 143performance although this can cause the latency of some I/O to increase due
103to more number of requests. 144to more number of requests.
104 145
105CFQ Group scheduling 146CFQ Group scheduling