[PATCH 6/6] arm64: Emulate CP15 Barrier instructions
Catalin Marinas
catalin.marinas at arm.com
Wed Aug 27 10:40:01 PDT 2014
On Tue, Aug 26, 2014 at 11:28:50AM +0100, Punit Agrawal wrote:
> diff --git a/arch/arm64/kernel/v7_obsolete.c b/arch/arm64/kernel/v7_obsolete.c
> index e9427cb..ed77889 100644
> --- a/arch/arm64/kernel/v7_obsolete.c
> +++ b/arch/arm64/kernel/v7_obsolete.c
> @@ -227,6 +227,94 @@ static void __init swp_emulation_init(void)
> pr_notice("Registered SWP/SWPB emulation handler\n");
> }
>
> +static atomic_t cp15_barrier_count;
Should we add counters for each barrier type? It may be more
informative.
> +/* data barrier */
> +static struct undef_hook cp15db_hook = {
> + .instr_mask = 0x0fff0fdf,
> + .instr_val = 0x0e070f9a,
> + .pstate_mask = COMPAT_PSR_MODE_MASK,
> + .pstate_val = COMPAT_PSR_MODE_USR,
> + .fn = cp15barrier_handler,
> +};
> +
> +/* instruction barrier */
> +static struct undef_hook cp15isb_hook = {
> + .instr_mask = 0x0fff0fff,
> + .instr_val = 0x0e070f95,
> + .pstate_mask = COMPAT_PSR_MODE_MASK,
> + .pstate_val = COMPAT_PSR_MODE_USR,
> + .fn = cp15barrier_handler,
> +};
It now crossed my mind that these CP15 barriers are valid in Thumb-2 as
well, same encoding. But we need the hook and the masks here to trap
them.
--
Catalin
More information about the linux-arm-kernel
mailing list