arm: Correctly handle watchpoints for BE32 CPUs
commit40612000599e52e792d23c998377a0fa429c4036
authorJulian Brown <julian@codesourcery.com>
Tue, 7 Feb 2017 18:29:59 +0000 (7 18:29 +0000)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 7 Feb 2017 18:29:59 +0000 (7 18:29 +0000)
tree8549aae95f252fb42907a2e7678fed6fc6b4605e
parentf7478a92dd9ee2276bfaa5b7317140d3f9d6a53b
arm: Correctly handle watchpoints for BE32 CPUs

In BE32 mode, sub-word size watchpoints can fail to trigger because the
address of the access is adjusted in the opcode helpers before being
compared with the watchpoint registers.  This patch reverses the address
adjustment before performing the comparison with the help of a new CPUClass
hook.

This version of the patch augments and tidies up comments a little.

Signed-off-by: Julian Brown <julian@codesourcery.com>
Message-id: caaf64ffc72f6ae183015337b7afdbd4b8989cb6.1484929304.git.julian@codesourcery.com
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
exec.c
include/qom/cpu.h
qom/cpu.c
target/arm/cpu.c
target/arm/internals.h
target/arm/op_helper.c