[PATCH 3/4] Add condition code checking to SWP emulation handler.
Will Deacon
will.deacon at arm.com
Fri Dec 9 11:06:23 EST 2011
On Thu, Dec 08, 2011 at 05:32:06PM +0000, Leif Lindholm wrote:
> diff --git a/arch/arm/kernel/swp_emulate.c b/arch/arm/kernel/swp_emulate.c
> index 5f452f8..6a5210e 100644
> --- a/arch/arm/kernel/swp_emulate.c
> +++ b/arch/arm/kernel/swp_emulate.c
> @@ -25,6 +25,7 @@
> #include <linux/syscalls.h>
> #include <linux/perf_event.h>
>
> +#include <asm/opcodes.h>
> #include <asm/traps.h>
> #include <asm/uaccess.h>
>
> @@ -185,6 +186,17 @@ static int swp_handler(struct pt_regs *regs, unsigned int instr)
>
> perf_sw_event(PERF_COUNT_SW_EMULATION_FAULTS, 1, regs, regs->ARM_pc);
>
> + res = arm_check_condition(instr, regs->ARM_cpsr);
> + switch (res) {
> + case ARM_OPCODE_CONDTEST_FAIL:
> + /* Condition failed - return to next instruction */
> + regs->ARM_pc += 4;
> + return 0;
> + case ARM_OPCODE_CONDTEST_UNCOND:
> + /* If unconditional encoding - not a SWP, undef */
> + return -EFAULT;
> + }
> +
Maybe have:
case ARM_OPCODE_CONDTEST_PASS:
break;
for clarity. You could always have -EFAULT for the default case.
Will
More information about the linux-arm-kernel
mailing list