Re: [PATCH 01/25] xor: assert that xor_blocks is not called from interrupt context

From: Peter Zijlstra

Date: Fri Feb 27 2026 - 09:33:08 EST


On Thu, Feb 26, 2026 at 07:10:13AM -0800, Christoph Hellwig wrote:
> Most of the optimized xor_blocks versions require FPU/vector registers,
> which generally are not supported in interrupt context.
>
> Both callers already are in user context, so enforce this at the highest
> level.
>
> Signed-off-by: Christoph Hellwig <hch@xxxxxx>
> ---
> crypto/xor.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/crypto/xor.c b/crypto/xor.c
> index f39621a57bb3..864f3604e867 100644
> --- a/crypto/xor.c
> +++ b/crypto/xor.c
> @@ -28,6 +28,8 @@ xor_blocks(unsigned int src_count, unsigned int bytes, void *dest, void **srcs)
> {
> unsigned long *p1, *p2, *p3, *p4;
>
> + WARN_ON_ONCE(in_interrupt());

Your changelog makes it sound like you want:

WARN_ON_ONCE(!in_task());

But perhaps something like so:

lockdep_assert_preempt_enabled();

Would do? That ensures we are in preemptible context, which is much the
same. That also ensures the cost of this assertion is only paid on debug
kernels.


> p1 = (unsigned long *) srcs[0];
> if (src_count == 1) {
> active_template->do_2(bytes, dest, p1);
> --
> 2.47.3
>