diff options
Diffstat (limited to 'debian/patches-rt/0261-drm-i915-gt-Only-disable-interrupts-for-the-timeline.patch')
-rw-r--r-- | debian/patches-rt/0261-drm-i915-gt-Only-disable-interrupts-for-the-timeline.patch | 52 |
1 files changed, 0 insertions, 52 deletions
diff --git a/debian/patches-rt/0261-drm-i915-gt-Only-disable-interrupts-for-the-timeline.patch b/debian/patches-rt/0261-drm-i915-gt-Only-disable-interrupts-for-the-timeline.patch deleted file mode 100644 index f3e33490b..000000000 --- a/debian/patches-rt/0261-drm-i915-gt-Only-disable-interrupts-for-the-timeline.patch +++ /dev/null @@ -1,52 +0,0 @@ -From 0749672a572de55d3bb02db8ad11f2f09cba9b9a Mon Sep 17 00:00:00 2001 -From: Sebastian Andrzej Siewior <bigeasy@linutronix.de> -Date: Tue, 7 Jul 2020 12:25:11 +0200 -Subject: [PATCH 261/296] drm/i915/gt: Only disable interrupts for the timeline - lock on !force-threaded -Origin: https://www.kernel.org/pub/linux/kernel/projects/rt/5.10/older/patches-5.10.35-rt39.tar.xz - -According to commit - d67739268cf0e ("drm/i915/gt: Mark up the nested engine-pm timeline lock as irqsafe") - -the intrrupts are disabled the code may be called from an interrupt -handler and from preemptible context. -With `force_irqthreads' set the timeline mutex is never observed in IRQ -context so it is not neede to disable interrupts. - -Disable only interrupts if not in `force_irqthreads' mode. - -Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> ---- - drivers/gpu/drm/i915/gt/intel_engine_pm.c | 8 +++++--- - 1 file changed, 5 insertions(+), 3 deletions(-) - -diff --git a/drivers/gpu/drm/i915/gt/intel_engine_pm.c b/drivers/gpu/drm/i915/gt/intel_engine_pm.c -index f7b2e07e2229..313d8a28e776 100644 ---- a/drivers/gpu/drm/i915/gt/intel_engine_pm.c -+++ b/drivers/gpu/drm/i915/gt/intel_engine_pm.c -@@ -60,9 +60,10 @@ static int __engine_unpark(struct intel_wakeref *wf) - - static inline unsigned long __timeline_mark_lock(struct intel_context *ce) - { -- unsigned long flags; -+ unsigned long flags = 0; - -- local_irq_save(flags); -+ if (!force_irqthreads) -+ local_irq_save(flags); - mutex_acquire(&ce->timeline->mutex.dep_map, 2, 0, _THIS_IP_); - - return flags; -@@ -72,7 +73,8 @@ static inline void __timeline_mark_unlock(struct intel_context *ce, - unsigned long flags) - { - mutex_release(&ce->timeline->mutex.dep_map, _THIS_IP_); -- local_irq_restore(flags); -+ if (!force_irqthreads) -+ local_irq_restore(flags); - } - - #else --- -2.30.2 - |