OSDN Git Service

arm64: Fix single stepping in kernel traps
authorJulien Thierry <julien.thierry@arm.com>
Wed, 25 Oct 2017 09:04:33 +0000 (10:04 +0100)
committerWill Deacon <will.deacon@arm.com>
Wed, 25 Oct 2017 10:57:33 +0000 (11:57 +0100)
commit6436beeee5721a8e906e9eabf866f12d04470437
tree022956462f870882d483fe09492a0c2f679d61eb
parente28cc0255997e9b770039d87276c1b9fd8bc231d
arm64: Fix single stepping in kernel traps

Software Step exception is missing after stepping a trapped instruction.

Ensure SPSR.SS gets set to 0 after emulating/skipping a trapped instruction
before doing ERET.

Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Julien Thierry <julien.thierry@arm.com>
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
[will: replaced AARCH32_INSN_SIZE with 4]
Signed-off-by: Will Deacon <will.deacon@arm.com>
arch/arm64/include/asm/traps.h
arch/arm64/kernel/armv8_deprecated.c
arch/arm64/kernel/cpufeature.c
arch/arm64/kernel/traps.c