[PATCH] x86/pti: Add pti= cmdline option and documentation

From: Borislav Petkov
Date: Tue Dec 12 2017 - 08:40:13 EST


From: Borislav Petkov <bp@xxxxxxx>

Keep the "nopti" for traditional reasons.

Requested-by: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx>
Signed-off-by: Borislav Petkov <bp@xxxxxxx>
Cc: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx>
Cc: Andy Lutomirsky <luto@xxxxxxxxxx>
Cc: Peter Zijlstra <peterz@xxxxxxxxxxxxx>
Cc: Dave Hansen <dave.hansen@xxxxxxxxx>
Cc: Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx>
Cc: keescook@xxxxxxxxxx
Cc: hughd@xxxxxxxxxx
Cc: Brian Gerst <brgerst@xxxxxxxxx>
Cc: Josh Poimboeuf <jpoimboe@xxxxxxxxxx>
Cc: Denys Vlasenko <dvlasenk@xxxxxxxxxx>
Cc: Boris Ostrovsky <boris.ostrovsky@xxxxxxxxxx>
Cc: Juergen Gross <jgross@xxxxxxxx>
Cc: David Laight <David.Laight@xxxxxxxxxx>
Cc: Eduardo Valentin <eduval@xxxxxxxxxx>
Cc: aliguori@xxxxxxxxxx
Cc: Will Deacon <will.deacon@xxxxxxx>
Cc: daniel.gruss@xxxxxxxxxxxxxx
---
Documentation/admin-guide/kernel-parameters.txt | 6 ++++++
arch/x86/mm/pti.c | 18 ++++++++++++++++++
2 files changed, 24 insertions(+)

diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
index 5dfd26265484..520fdec15bbb 100644
--- a/Documentation/admin-guide/kernel-parameters.txt
+++ b/Documentation/admin-guide/kernel-parameters.txt
@@ -3255,6 +3255,12 @@
pt. [PARIDE]
See Documentation/blockdev/paride.txt.

+ pti= [X86_64]
+ Control user/kernel address space isolation:
+ on - enable
+ off - disable
+ auto - default setting
+
pty.legacy_count=
[KNL] Number of legacy pty's. Overwrites compiled-in
default number.
diff --git a/arch/x86/mm/pti.c b/arch/x86/mm/pti.c
index f48645d2f3fd..4afa16b444b2 100644
--- a/arch/x86/mm/pti.c
+++ b/arch/x86/mm/pti.c
@@ -51,15 +51,33 @@
void __init pti_check_boottime_disable(void)
{
bool enable = true;
+ char arg[5];
+
+ if (cmdline_find_option(boot_command_line, "pti", arg, sizeof(arg))) {
+ if (!strncmp(arg, "on", 2))
+ goto enable;
+
+ if (!strncmp(arg, "off", 3)) {
+ pr_info("disabled on command line.\n");
+ return;
+ }
+
+ if (!strncmp(arg, "auto", 4))
+ goto skip;
+ }

if (cmdline_find_option_bool(boot_command_line, "nopti")) {
pr_info("disabled on command line.\n");
enable = false;
}
+
+skip:
if (hypervisor_is_type(X86_HYPER_XEN_PV)) {
pr_info("disabled on XEN_PV.\n");
enable = false;
}
+
+enable:
if (enable)
setup_force_cpu_bug(X86_BUG_CPU_SECURE_MODE_PTI);
}
--
2.13.0