[PATCH] ARM: Disallow kernel mode NEON when IRQs are disabled
Eric Biggers
ebiggers at kernel.org
Tue Mar 25 08:39:48 PDT 2025
On Mon, Mar 24, 2025 at 07:59:28PM +0100, Ard Biesheuvel wrote:
> From: Ard Biesheuvel <ardb at kernel.org>
>
> Commit
>
> c79f81631142 ("ARM: 9283/1: permit non-nested kernel mode NEON in softirq context")
>
> relaxed the rules around the use of SIMD instructions in kernel mode on
> ARM, to allow such use when serving a softirq. To avoid having to
> preserve/restore kernel mode NEON state when such a softirq is taken,
> softirqs are now disabled when using the NEON from task context.
>
> However, the fact that the softirq API does not allow unmasking of
> softirqs with interrupts disabled was overlooked, resulting in a WARN()
> in some cases, as reported by Guenter:
>
> WARNING: CPU: 0 PID: 1145 at kernel/softirq.c:369 __local_bh_enable_ip+0x118/0x194
> Call trace:
> unwind_backtrace from show_stack+0x10/0x14
> show_stack from dump_stack_lvl+0x7c/0xac
> dump_stack_lvl from __warn+0x7c/0x1b8
> __warn from warn_slowpath_fmt+0x19c/0x1a4
> warn_slowpath_fmt from __local_bh_enable_ip+0x118/0x194
> __local_bh_enable_ip from crc_t10dif_arch+0xd4/0xe8
> crc_t10dif_arch from crc_t10dif_wrapper+0x14/0x1c
> crc_t10dif_wrapper from crc_main_test+0x178/0x360
> crc_main_test from kunit_try_run_case+0x78/0x1e0
> kunit_try_run_case from kunit_generic_run_threadfn_adapter+0x1c/0x34
> kunit_generic_run_threadfn_adapter from kthread+0x118/0x254
> kthread from ret_from_fork+0x14/0x28
>
> While disabling softirqs is not really needed when running with IRQs
> disabled (given that the only way a softirq can be delivered
> asynchrously is over the back of an IRQ), let's not complicate this
> logic more than needed, and simply disallow use of the NEON in kernel
> mode when IRQs are disabled.
>
> Another approach might be to only disable and re-enable softirqs if IRQs
> are enabled, but other than the test case above, there are no clear use
> cases for doing non-trivial arithmetic processing (hence using an
> accelerated SIMD implementation) with IRQs disabled.
>
> Reported-by: Guenter Roeck <linux at roeck-us.net>
> Tested-by: Guenter Roeck <linux at roeck-us.net>
> Link: https://lore.kernel.org/all/389b899f-893c-4855-9e30-d8920a5d6f91@roeck-us.net
> Signed-off-by: Ard Biesheuvel <ardb at kernel.org>
> ---
> arch/arm/include/asm/simd.h | 3 ++-
> arch/arm/vfp/vfpmodule.c | 1 +
> 2 files changed, 3 insertions(+), 1 deletion(-)
Reviewed-by: Eric Biggers <ebiggers at kernel.org>
- Eric
More information about the linux-arm-kernel
mailing list