|
@@ -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();
|
|
|
|