[PATCH RFC 1/3] arm64/crypto: add shared macro to test for NEED_RESCHED
Nicolas Pitre
nicolas.pitre at linaro.org
Fri Mar 28 21:53:23 EDT 2014
On Fri, 28 Mar 2014, Ard Biesheuvel wrote:
> This adds arch/arm64/crypto/preempt.h, currently containing just a single
> asm macro definition 'b_if_no_resched' that will be shared between multiple
> crypto algorithm implementations that need to test for preemption in the
> inner loop.
This file is a rather bad choice for this pretty generic macro. There
is nothing crypto specific about it, even if crypto might be the only
user for now. This should live in include/asm/assembler.h, or a
separate file in that directory only if including <asm/asm-offsets.h>
from assembler.h is considered a nuisance.
>
> Signed-off-by: Ard Biesheuvel <ard.biesheuvel at linaro.org>
> ---
> arch/arm64/crypto/preempt.h | 28 ++++++++++++++++++++++++++++
> 1 file changed, 28 insertions(+)
> create mode 100644 arch/arm64/crypto/preempt.h
>
> diff --git a/arch/arm64/crypto/preempt.h b/arch/arm64/crypto/preempt.h
> new file mode 100644
> index 000000000000..94302d5b5ae9
> --- /dev/null
> +++ b/arch/arm64/crypto/preempt.h
> @@ -0,0 +1,28 @@
> +/*
> + * preempt.h - shared macros to check preempt state
> + *
> + * Copyright (C) 2014 Linaro Ltd <ard.biesheuvel at linaro.org>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + */
> +
> +#include <asm/asm-offsets.h>
> +#include <asm/thread_info.h>
> +
> + /*
> + * Branch to 'lb' but only if we have not been tagged for preemption.
> + *
> + * Expects current->thread_info in ti, or NULL if running in interrupt
> + * context. reg is a scratch x register.
> + */
> + .macro b_if_no_resched, ti, reg, lb
> +#if defined(CONFIG_PREEMPT) || defined(CONFIG_PREEMPT_VOLUNTARY)
> + cbz \ti, \lb // have thread_info?
> + ldr \reg, [\ti, #TI_FLAGS] // get flags
> + tbz \reg, #TIF_NEED_RESCHED, \lb // needs rescheduling?
> +#else
> + b \lb
> +#endif
> + .endm
> --
> 1.8.3.2
>
>
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
>
More information about the linux-arm-kernel
mailing list