Commit 09c41307 authored by Peter Zijlstra's avatar Peter Zijlstra

x86/xen: Make irq_disable() noinstr

vmlinux.o: warning: objtool: pv_ops[31]: native_irq_disable
vmlinux.o: warning: objtool: pv_ops[31]: __raw_callee_save_xen_irq_disable
vmlinux.o: warning: objtool: pv_ops[31]: xen_irq_disable_direct
vmlinux.o: warning: objtool: lock_is_held_type()+0x5b: call to pv_ops[31]() leaves .noinstr.text section
Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: default avatarJuergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/20210624095148.933869441@infradead.org
parent d7bfc7d5
...@@ -243,6 +243,11 @@ static noinstr void pv_native_irq_enable(void) ...@@ -243,6 +243,11 @@ static noinstr void pv_native_irq_enable(void)
{ {
native_irq_enable(); native_irq_enable();
} }
static noinstr void pv_native_irq_disable(void)
{
native_irq_disable();
}
#endif #endif
enum paravirt_lazy_mode paravirt_get_lazy_mode(void) enum paravirt_lazy_mode paravirt_get_lazy_mode(void)
...@@ -306,7 +311,7 @@ struct paravirt_patch_template pv_ops = { ...@@ -306,7 +311,7 @@ struct paravirt_patch_template pv_ops = {
/* Irq ops. */ /* Irq ops. */
.irq.save_fl = __PV_IS_CALLEE_SAVE(native_save_fl), .irq.save_fl = __PV_IS_CALLEE_SAVE(native_save_fl),
.irq.irq_disable = __PV_IS_CALLEE_SAVE(native_irq_disable), .irq.irq_disable = __PV_IS_CALLEE_SAVE(pv_native_irq_disable),
.irq.irq_enable = __PV_IS_CALLEE_SAVE(pv_native_irq_enable), .irq.irq_enable = __PV_IS_CALLEE_SAVE(pv_native_irq_enable),
.irq.safe_halt = native_safe_halt, .irq.safe_halt = native_safe_halt,
.irq.halt = native_halt, .irq.halt = native_halt,
......
...@@ -42,7 +42,7 @@ asmlinkage __visible noinstr unsigned long xen_save_fl(void) ...@@ -42,7 +42,7 @@ asmlinkage __visible noinstr unsigned long xen_save_fl(void)
} }
__PV_CALLEE_SAVE_REGS_THUNK(xen_save_fl, ".noinstr.text"); __PV_CALLEE_SAVE_REGS_THUNK(xen_save_fl, ".noinstr.text");
asmlinkage __visible void xen_irq_disable(void) asmlinkage __visible noinstr void xen_irq_disable(void)
{ {
/* There's a one instruction preempt window here. We need to /* There's a one instruction preempt window here. We need to
make sure we're don't switch CPUs between getting the vcpu make sure we're don't switch CPUs between getting the vcpu
...@@ -51,7 +51,7 @@ asmlinkage __visible void xen_irq_disable(void) ...@@ -51,7 +51,7 @@ asmlinkage __visible void xen_irq_disable(void)
this_cpu_read(xen_vcpu)->evtchn_upcall_mask = 1; this_cpu_read(xen_vcpu)->evtchn_upcall_mask = 1;
preempt_enable_no_resched(); preempt_enable_no_resched();
} }
PV_CALLEE_SAVE_REGS_THUNK(xen_irq_disable); __PV_CALLEE_SAVE_REGS_THUNK(xen_irq_disable, ".noinstr.text");
asmlinkage __visible noinstr void xen_irq_enable(void) asmlinkage __visible noinstr void xen_irq_enable(void)
{ {
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h> #include <linux/linkage.h>
.pushsection .noinstr.text, "ax"
/* /*
* Disabling events is simply a matter of making the event mask * Disabling events is simply a matter of making the event mask
* non-zero. * non-zero.
...@@ -30,8 +31,6 @@ SYM_FUNC_START(xen_irq_disable_direct) ...@@ -30,8 +31,6 @@ SYM_FUNC_START(xen_irq_disable_direct)
ret ret
SYM_FUNC_END(xen_irq_disable_direct) SYM_FUNC_END(xen_irq_disable_direct)
.pushsection .noinstr.text, "ax"
/* /*
* Force an event check by making a hypercall, but preserve regs * Force an event check by making a hypercall, but preserve regs
* before making the call. * before making the call.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment