Linux Audio

Check our new training course

Buildroot integration, development and maintenance

Need a Buildroot system for your embedded project?
Loading...
v4.6
 
 1if BLOCK
 2
 3menu "IO Schedulers"
 4
 5config 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.
14
15config 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.
23
24config IOSCHED_CFQ
25	tristate "CFQ I/O scheduler"
26	default y
27	---help---
28	  The CFQ I/O scheduler tries to distribute bandwidth equally
29	  among all processes in the system. It should provide a fair
30	  and low latency working environment, suitable for both desktop
31	  and server systems.
32
33	  This is the default I/O scheduler.
34
35config CFQ_GROUP_IOSCHED
36	bool "CFQ Group Scheduling support"
37	depends on IOSCHED_CFQ && BLK_CGROUP
38	default n
 
 
 
 
 
 
 
39	---help---
40	  Enable group IO scheduling in CFQ.
41
42choice
43	prompt "Default I/O scheduler"
44	default DEFAULT_CFQ
45	help
46	  Select the I/O scheduler which will be used by default for all
47	  block devices.
48
49	config DEFAULT_DEADLINE
50		bool "Deadline" if IOSCHED_DEADLINE=y
51
52	config DEFAULT_CFQ
53		bool "CFQ" if IOSCHED_CFQ=y
54
55	config DEFAULT_NOOP
56		bool "No-op"
57
58endchoice
59
60config DEFAULT_IOSCHED
61	string
62	default "deadline" if DEFAULT_DEADLINE
63	default "cfq" if DEFAULT_CFQ
64	default "noop" if DEFAULT_NOOP
65
66endmenu
67
68endif
v5.4
 1# SPDX-License-Identifier: GPL-2.0
 2if BLOCK
 3
 4menu "IO Schedulers"
 5
 6config MQ_IOSCHED_DEADLINE
 7	tristate "MQ deadline I/O scheduler"
 8	default y
 9	---help---
10	  MQ version of the deadline IO scheduler.
 
 
 
 
11
12config MQ_IOSCHED_KYBER
13	tristate "Kyber I/O scheduler"
14	default y
15	---help---
16	  The Kyber I/O scheduler is a low-overhead scheduler suitable for
17	  multiqueue and other fast devices. Given target latencies for reads and
18	  synchronous writes, it will self-tune queue depths to achieve that
19	  goal.
20
21config IOSCHED_BFQ
22	tristate "BFQ I/O scheduler"
 
23	---help---
24	BFQ I/O scheduler for BLK-MQ. BFQ distributes the bandwidth of
25	of the device among all processes according to their weights,
26	regardless of the device parameters and with any workload. It
27	also guarantees a low latency to interactive and soft
28	real-time applications.  Details in
29	Documentation/block/bfq-iosched.rst
30
31config BFQ_GROUP_IOSCHED
32       bool "BFQ hierarchical scheduling support"
33       depends on IOSCHED_BFQ && BLK_CGROUP
34       ---help---
35
36       Enable hierarchical scheduling in BFQ, using the blkio
37       (cgroups-v1) or io (cgroups-v2) controller.
38
39config BFQ_CGROUP_DEBUG
40	bool "BFQ IO controller debugging"
41	depends on BFQ_GROUP_IOSCHED
42	---help---
43	Enable some debugging help. Currently it exports additional stat
44	files in a cgroup which can be useful for debugging.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
45
46endmenu
47
48endif