OSDN Git Service

target/arm: Implement AArch32 DBGDEVID, DBGDEVID1, DBGDEVID2
authorPeter Maydell <peter.maydell@linaro.org>
Thu, 30 Jun 2022 19:41:15 +0000 (20:41 +0100)
committerPeter Maydell <peter.maydell@linaro.org>
Thu, 7 Jul 2022 10:37:33 +0000 (11:37 +0100)
commit09754ca867f42d26c5f65350b4c08e958ec9a8da
tree874b272a7a63d6324f947f65ff8fa8c66aab1390
parent40b200279c98ea0c223fa5a2bdeb4aee40d4e40e
target/arm: Implement AArch32 DBGDEVID, DBGDEVID1, DBGDEVID2

Starting with v7 of the debug architecture, there are three extra
ID registers that add information on top of that provided in
DBGDIDR. These are DBGDEVID, DBGDEVID1 and DBGDEVID2. In the
v7 debug architecture, DBGDEVID is optional, present only of
DBGDIDR.DEVID_imp is set. In v7.1 all three must be present.

Implement the missing registers.  Note that we only need to set the
values in the ARMISARegisters struct for the CPUs Cortex-A7, A15,
A53, A57 and A72 (plus the 32-bit 'max' which uses the Cortex-A53
values): earlier CPUs didn't implement v7 of the architecture, and
our other 64-bit CPUs (Cortex-A76, Neoverse-N1 and A64fx) don't have
AArch32 support at EL1.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20220630194116.3438513-5-peter.maydell@linaro.org
target/arm/cpu.h
target/arm/cpu64.c
target/arm/cpu_tcg.c
target/arm/debug_helper.c