From: Paolo Bonzini Date: Wed, 26 Apr 2017 14:56:26 +0000 (+0200) Subject: kvm: async_pf: fix rcu_irq_enter() with irqs enabled X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=bbaf0e2b1c1b4f88abd6ef49576f0efb1734eae5;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git kvm: async_pf: fix rcu_irq_enter() with irqs enabled native_safe_halt enables interrupts, and you just shouldn't call rcu_irq_enter() with interrupts enabled. Reorder the call with the following local_irq_disable() to respect the invariant. Reported-by: Ross Zwisler Cc: stable@vger.kernel.org Signed-off-by: Paolo Bonzini Acked-by: Paul E. McKenney Tested-by: Wanpeng Li Signed-off-by: Radim Krčmář --- diff --git a/arch/x86/kernel/kvm.c b/arch/x86/kernel/kvm.c index da5c09789984..43e10d6fdbed 100644 --- a/arch/x86/kernel/kvm.c +++ b/arch/x86/kernel/kvm.c @@ -161,8 +161,8 @@ void kvm_async_pf_task_wait(u32 token) */ rcu_irq_exit(); native_safe_halt(); - rcu_irq_enter(); local_irq_disable(); + rcu_irq_enter(); } } if (!n.halted)