Juergen Gross e03f56
Patch-mainline: v5.6-rc3
Juergen Gross e03f56
Git-commit: 8645e56a4ad6dcbf504872db7f14a2f67db88ef2
Juergen Gross e03f56
References: bsc#1065600
Juergen Gross e03f56
From: Thomas Gleixner <tglx@linutronix.de>
Juergen Gross e03f56
Date: Wed, 19 Feb 2020 18:30:26 +0100
Juergen Gross e03f56
Subject: [PATCH] xen: Enable interrupts when calling _cond_resched()
Juergen Gross e03f56
Juergen Gross e03f56
xen_maybe_preempt_hcall() is called from the exception entry point
Juergen Gross e03f56
xen_do_hypervisor_callback with interrupts disabled.
Juergen Gross e03f56
Juergen Gross e03f56
_cond_resched() evades the might_sleep() check in cond_resched() which
Juergen Gross e03f56
would have caught that and schedule_debug() unfortunately lacks a check
Juergen Gross e03f56
for irqs_disabled().
Juergen Gross e03f56
Juergen Gross e03f56
Enable interrupts around the call and use cond_resched() to catch future
Juergen Gross e03f56
issues.
Juergen Gross e03f56
Juergen Gross e03f56
Fixes: fdfd811ddde3 ("x86/xen: allow privcmd hypercalls to be preempted")
Juergen Gross e03f56
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Juergen Gross e03f56
Link: https://lore.kernel.org/r/878skypjrh.fsf@nanos.tec.linutronix.de
Juergen Gross e03f56
Reviewed-by: Juergen Gross <jgross@suse.com>
Juergen Gross e03f56
Signed-off-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Juergen Gross e03f56
---
Juergen Gross e03f56
 drivers/xen/preempt.c | 4 +++-
Juergen Gross e03f56
 1 file changed, 3 insertions(+), 1 deletion(-)
Juergen Gross e03f56
Juergen Gross e03f56
diff --git a/drivers/xen/preempt.c b/drivers/xen/preempt.c
Juergen Gross e03f56
index 8b9919c26095..456a164364a2 100644
Juergen Gross e03f56
--- a/drivers/xen/preempt.c
Juergen Gross e03f56
+++ b/drivers/xen/preempt.c
Juergen Gross e03f56
@@ -33,7 +33,9 @@ asmlinkage __visible void xen_maybe_preempt_hcall(void)
Juergen Gross e03f56
 		 * cpu.
Juergen Gross e03f56
 		 */
Juergen Gross e03f56
 		__this_cpu_write(xen_in_preemptible_hcall, false);
Juergen Gross e03f56
-		_cond_resched();
Juergen Gross e03f56
+		local_irq_enable();
Juergen Gross e03f56
+		cond_resched();
Juergen Gross e03f56
+		local_irq_disable();
Juergen Gross e03f56
 		__this_cpu_write(xen_in_preemptible_hcall, true);
Juergen Gross e03f56
 	}
Juergen Gross e03f56
 }
Juergen Gross e03f56
-- 
Juergen Gross e03f56
2.16.4
Juergen Gross e03f56