projects
/
openwrt
/
staging
/
blogic.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
e70e589
)
x86/retpoline/xen: Convert Xen hypercall indirect jumps
author
David Woodhouse
<
[email protected]
>
Thu, 11 Jan 2018 21:46:31 +0000
(21:46 +0000)
committer
Thomas Gleixner
<
[email protected]
>
Thu, 11 Jan 2018 23:14:31 +0000
(
00:14
+0100)
Convert indirect call in Xen hypercall to use non-speculative sequence,
when CONFIG_RETPOLINE is enabled.
Signed-off-by: David Woodhouse <
[email protected]
>
Signed-off-by: Thomas Gleixner <
[email protected]
>
Acked-by: Arjan van de Ven <
[email protected]
>
Acked-by: Ingo Molnar <
[email protected]
>
Reviewed-by: Juergen Gross <
[email protected]
>
Cc:
[email protected]
Cc: Rik van Riel <
[email protected]
>
Cc: Andi Kleen <
[email protected]
>
Cc: Josh Poimboeuf <
[email protected]
>
Cc:
[email protected]
Cc: Peter Zijlstra <
[email protected]
>
Cc: Linus Torvalds <
[email protected]
>
Cc: Jiri Kosina <
[email protected]
>
Cc: Andy Lutomirski <
[email protected]
>
Cc: Dave Hansen <
[email protected]
>
Cc: Kees Cook <
[email protected]
>
Cc: Tim Chen <
[email protected]
>
Cc: Greg Kroah-Hartman <
[email protected]
>
Cc: Paul Turner <
[email protected]
>
Link:
https://lkml.kernel.org/r/
[email protected]
arch/x86/include/asm/xen/hypercall.h
patch
|
blob
|
history
diff --git
a/arch/x86/include/asm/xen/hypercall.h
b/arch/x86/include/asm/xen/hypercall.h
index 7cb282e9e58777aeb2ffd86b344d39a5189c5f84..bfd882617613923f0db79c4aae82690bda7a8d4f 100644
(file)
--- a/
arch/x86/include/asm/xen/hypercall.h
+++ b/
arch/x86/include/asm/xen/hypercall.h
@@
-44,6
+44,7
@@
#include <asm/page.h>
#include <asm/pgtable.h>
#include <asm/smap.h>
+#include <asm/nospec-branch.h>
#include <xen/interface/xen.h>
#include <xen/interface/sched.h>
@@
-217,9
+218,9
@@
privcmd_call(unsigned call,
__HYPERCALL_5ARG(a1, a2, a3, a4, a5);
stac();
- asm volatile(
"call *%[call]"
+ asm volatile(
CALL_NOSPEC
: __HYPERCALL_5PARAM
- : [
call
] "a" (&hypercall_page[call])
+ : [
thunk_target
] "a" (&hypercall_page[call])
: __HYPERCALL_CLOBBER5);
clac();