]> Git Repo - linux.git/commit
x86,smap: Fix smap_{save,restore}() alternatives
authorPeter Zijlstra <[email protected]>
Tue, 28 Apr 2020 17:57:59 +0000 (19:57 +0200)
committerPeter Zijlstra <[email protected]>
Thu, 30 Apr 2020 18:14:31 +0000 (20:14 +0200)
commit1ff865e343c2b59469d7e41d370a980a3f972c71
tree079fbd5fce19b9fbca6162f603eb3af11c704af3
parent7117f16bf460ef8cd132e6e80c989677397b4868
x86,smap: Fix smap_{save,restore}() alternatives

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) <[email protected]>
Reviewed-by: Miroslav Benes <[email protected]>
Acked-by: Josh Poimboeuf <[email protected]>
Link: https://lkml.kernel.org/r/[email protected]
arch/x86/include/asm/smap.h
This page took 0.058922 seconds and 4 git commands to generate.