diff options
author | Jerome Brunet <jbrunet@baylibre.com> | 2024-08-07 19:27:03 +0300 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2024-08-08 22:34:55 +0300 |
commit | 5003d0ce5c7da3a02c0aff771f516f99731e7390 (patch) | |
tree | 184f7ddcca1437de2fe83e700a748abdb1d40cb0 /tools/perf/scripts/python/Perf-Trace-Util/lib | |
parent | 2f11f61f9d4d5692bcebb9d089429ee0c046e08a (diff) | |
download | linux-5003d0ce5c7da3a02c0aff771f516f99731e7390.tar.xz |
ASoC: meson: axg-fifo: fix irq scheduling issue with PREEMPT_RT
With PREEMPT_RT enabled a spinlock_t becomes a sleeping lock.
This is usually not a problem with spinlocks used in IRQ context since
IRQ handlers get threaded. However, if IRQF_ONESHOT is set, the primary
handler won't be force-threaded and runs always in hardirq context. This is
a problem because spinlock_t requires a preemptible context on PREEMPT_RT.
In this particular instance, regmap mmio uses spinlock_t to protect the
register access and IRQF_ONESHOT is set on the IRQ. In this case, it is
actually better to do everything in threaded handler and it solves the
problem with PREEMPT_RT.
Reported-by: Arseniy Krasnov <avkrasnov@salutedevices.com>
Closes: https://lore.kernel.org/linux-amlogic/20240729131652.3012327-1-avkrasnov@salutedevices.com
Suggested-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Fixes: b11d26660dff ("ASoC: meson: axg-fifo: use threaded irq to check periods")
Signed-off-by: Jerome Brunet <jbrunet@baylibre.com>
Reviewed-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Link: https://patch.msgid.link/20240807162705.4024136-1-jbrunet@baylibre.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/Perf-Trace-Util/lib')
0 files changed, 0 insertions, 0 deletions