]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commitdiff
x86,smap: Fix smap_{save,restore}() alternatives
authorPeter Zijlstra <peterz@infradead.org>
Tue, 28 Apr 2020 17:57:59 +0000 (19:57 +0200)
committerPeter Zijlstra <peterz@infradead.org>
Thu, 30 Apr 2020 18:14:31 +0000 (20:14 +0200)
As reported by objtool:

  lib/ubsan.o: warning: objtool: .altinstr_replacement+0x0: alternative modifies stack
  lib/ubsan.o: warning: objtool: .altinstr_replacement+0x7: alternative modifies stack

the smap_{save,restore}() alternatives violate (the newly enforced)
rule on stack invariance. That is, due to there only being a single
ORC table it must be valid to any alternative. These alternatives
violate this with the direct result that unwinds will not be correct
when it hits between the PUSH and POP instructions.

Rewrite the functions to only have a conditional jump.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Miroslav Benes <mbenes@suse.cz>
Acked-by: Josh Poimboeuf <jpoimboe@redhat.com>
Link: https://lkml.kernel.org/r/20200429101802.GI13592@hirez.programming.kicks-ass.net
arch/x86/include/asm/smap.h

index 27c47d183f4b3760874549df7eb7cb1acb73fe0e..8b58d6975d5d4b4fa3a77e25529caf464b23bbfe 100644 (file)
@@ -57,8 +57,10 @@ static __always_inline unsigned long smap_save(void)
 {
        unsigned long flags;
 
-       asm volatile (ALTERNATIVE("", "pushf; pop %0; " __ASM_CLAC,
-                                 X86_FEATURE_SMAP)
+       asm volatile ("# smap_save\n\t"
+                     ALTERNATIVE("jmp 1f", "", X86_FEATURE_SMAP)
+                     "pushf; pop %0; " __ASM_CLAC "\n\t"
+                     "1:"
                      : "=rm" (flags) : : "memory", "cc");
 
        return flags;
@@ -66,7 +68,10 @@ static __always_inline unsigned long smap_save(void)
 
 static __always_inline void smap_restore(unsigned long flags)
 {
-       asm volatile (ALTERNATIVE("", "push %0; popf", X86_FEATURE_SMAP)
+       asm volatile ("# smap_restore\n\t"
+                     ALTERNATIVE("jmp 1f", "", X86_FEATURE_SMAP)
+                     "push %0; popf\n\t"
+                     "1:"
                      : : "g" (flags) : "memory", "cc");
 }