target/arm: Fix SCR RES1 handling
commit10d0ef3e6cfe228df4b2d3e27325f1b0e2b71fd5
authorMike Nawrocki <michael.nawrocki@gtri.gatech.edu>
Wed, 3 Feb 2021 16:55:52 +0000 (3 11:55 -0500)
committerPeter Maydell <peter.maydell@linaro.org>
Thu, 11 Feb 2021 11:50:13 +0000 (11 11:50 +0000)
tree409a37c68cd4d05d769b8fba6da5e6e26477b313
parentaf903caed9fc62cc60a589da75e61ea8008c8265
target/arm: Fix SCR RES1 handling

The FW and AW bits of SCR_EL3 are RES1 only in some contexts. Force them
to 1 only when there is no support for AArch32 at EL1 or above.

The reset value will be 0x30 only if the CPU is AArch64-only; if there
is support for AArch32 at EL1 or above, it will be reset to 0.

Also adds helper function isar_feature_aa64_aa32_el1 to check if AArch32
is supported at EL1 or above.

Signed-off-by: Mike Nawrocki <michael.nawrocki@gtri.gatech.edu>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20210203165552.16306-2-michael.nawrocki@gtri.gatech.edu
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
target/arm/cpu.h
target/arm/helper.c