rules: add elevator= kernel command line parameter v239-12
authorLukas Nykryn <lnykryn@redhat.com>
Tue, 12 Feb 2019 15:58:16 +0000 (16:58 +0100)
committerLukáš Nykrýn <lnykryn@redhat.com>
Fri, 15 Feb 2019 10:10:21 +0000 (11:10 +0100)
Kernel removed the elevator= option, so let's reintroduce
it for rhel8 via udev rule.

rhel-only
Resolves: #1670126

rules/40-elevator.rules [new file with mode: 0644]

diff --git a/rules/40-elevator.rules b/rules/40-elevator.rules
new file mode 100644 (file)
index 0000000..dbe8fc8
--- /dev/null
@@ -0,0 +1,20 @@
+# We aren't adding devices skip the elevator check
+ACTION!="add", GOTO="sched_out"
+
+SUBSYSTEM!="block", GOTO="sched_out"
+ENV{DEVTYPE}!="disk", GOTO="sched_out"
+
+# Technically, dm-multipath can be configured to use an I/O scheduler.
+# However, there are races between the 'add' uevent and the linking in
+# of the queue/scheduler sysfs file.  For now, just skip dm- devices.
+KERNEL=="dm-*|md*", GOTO="sched_out"
+
+# Skip bio-based devices, which don't support an I/O scheduler.
+ATTR{queue/scheduler}=="none", GOTO="sched_out"
+
+# If elevator= is specified on the kernel command line, change the
+# scheduler to the one specified.
+IMPORT{cmdline}="elevator"
+ENV{elevator}!="", ATTR{queue/scheduler}="$env{elevator}"
+
+LABEL="sched_out"
\ No newline at end of file