Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / block / Kconfig.iosched
blob76b2d50d393da60aa06bde8678d7dbd657d3457a
1 if BLOCK
3 menu "IO Schedulers"
5 config IOSCHED_NOOP
6         bool
7         default y
8         ---help---
9           The no-op I/O scheduler is a minimal scheduler that does basic merging
10           and sorting. Its main uses include non-disk based block devices like
11           memory devices, and specialised software or hardware environments
12           that do their own scheduling and require only minimal assistance from
13           the kernel.
15 config IOSCHED_DEADLINE
16         tristate "Deadline I/O scheduler"
17         default y
18         ---help---
19           The deadline I/O scheduler is simple and compact. It will provide
20           CSCAN service with FIFO expiration of requests, switching to
21           a new point in the service tree and doing a batch of IO from there
22           in case of expiry.
24 config IOSCHED_CFQ
25         tristate "CFQ I/O scheduler"
26         # If BLK_CGROUP is a module, CFQ has to be built as module.
27         depends on (BLK_CGROUP=m && m) || !BLK_CGROUP || BLK_CGROUP=y
28         default y
29         ---help---
30           The CFQ I/O scheduler tries to distribute bandwidth equally
31           among all processes in the system. It should provide a fair
32           and low latency working environment, suitable for both desktop
33           and server systems.
35           This is the default I/O scheduler.
37           Note: If BLK_CGROUP=m, then CFQ can be built only as module.
39 config CFQ_GROUP_IOSCHED
40         bool "CFQ Group Scheduling support"
41         depends on IOSCHED_CFQ && BLK_CGROUP
42         default n
43         ---help---
44           Enable group IO scheduling in CFQ.
46 config IOSCHED_BFQ
47         tristate "BFQ I/O scheduler"
48         depends on EXPERIMENTAL
49         default y
50         ---help---
51           The BFQ I/O scheduler tries to distribute bandwidth among
52           all processes according to their weights.
53           It aims at distributing the bandwidth as desired, independently of
54           the disk parameters and with any workload. It also tries to
55           guarantee low latency to interactive and soft real-time
56           applications.  If compiled built-in (saying Y here), BFQ can
57           be configured to support hierarchical scheduling.
59 config CGROUP_BFQIO
60         bool "BFQ hierarchical scheduling support"
61         depends on CGROUPS && IOSCHED_BFQ=y
62         default n
63         ---help---
64           Enable hierarchical scheduling in BFQ, using the cgroups
65           filesystem interface.  The name of the subsystem will be
66           bfqio.
68 choice
69         prompt "Default I/O scheduler"
70         default DEFAULT_BFQ
71         help
72           Select the I/O scheduler which will be used by default for all
73           block devices.
75         config DEFAULT_DEADLINE
76                 bool "Deadline" if IOSCHED_DEADLINE=y
78         config DEFAULT_CFQ
79                 bool "CFQ" if IOSCHED_CFQ=y
81         config DEFAULT_BFQ
82                 bool "BFQ" if IOSCHED_BFQ=y
84         config DEFAULT_NOOP
85                 bool "No-op"
87 endchoice
89 config DEFAULT_IOSCHED
90         string
91         default "deadline" if DEFAULT_DEADLINE
92         default "cfq" if DEFAULT_CFQ
93         default "bfq" if DEFAULT_BFQ
94         default "noop" if DEFAULT_NOOP
96 endmenu
98 endif