mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-28 01:41:01 +00:00
target-arm: Fix REVIDR reset value
According to ARM Cortex-A53/A57 TRM, REVIDR reset value should be zero. So let REVIDR reset value be specified by CPU model and correct it for Cortex-A53/A57. Backports commit 13b72b2b9aa7ab7ee129e38e9587acd6a1b9a932 from qemu
This commit is contained in:
parent
f6d104b33a
commit
113cda90c3
|
@ -126,6 +126,7 @@ typedef struct ARMCPU {
|
||||||
* prefix means a constant register.
|
* prefix means a constant register.
|
||||||
*/
|
*/
|
||||||
uint32_t midr;
|
uint32_t midr;
|
||||||
|
uint32_t revidr;
|
||||||
uint32_t reset_fpsid;
|
uint32_t reset_fpsid;
|
||||||
uint32_t mvfr0;
|
uint32_t mvfr0;
|
||||||
uint32_t mvfr1;
|
uint32_t mvfr1;
|
||||||
|
|
|
@ -93,6 +93,7 @@ static void aarch64_a57_initfn(struct uc_struct *uc, Object *obj, void *opaque)
|
||||||
set_feature(&cpu->env, ARM_FEATURE_PMU);
|
set_feature(&cpu->env, ARM_FEATURE_PMU);
|
||||||
cpu->kvm_target = QEMU_KVM_ARM_TARGET_CORTEX_A57;
|
cpu->kvm_target = QEMU_KVM_ARM_TARGET_CORTEX_A57;
|
||||||
cpu->midr = 0x411fd070;
|
cpu->midr = 0x411fd070;
|
||||||
|
cpu->revidr = 0x00000000;
|
||||||
cpu->reset_fpsid = 0x41034070;
|
cpu->reset_fpsid = 0x41034070;
|
||||||
cpu->mvfr0 = 0x10110222;
|
cpu->mvfr0 = 0x10110222;
|
||||||
cpu->mvfr1 = 0x12111111;
|
cpu->mvfr1 = 0x12111111;
|
||||||
|
@ -143,6 +144,7 @@ static void aarch64_a53_initfn(struct uc_struct *uc, Object *obj, void *opaque)
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V8_PMULL);
|
set_feature(&cpu->env, ARM_FEATURE_V8_PMULL);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CRC);
|
set_feature(&cpu->env, ARM_FEATURE_CRC);
|
||||||
cpu->midr = 0x410fd034;
|
cpu->midr = 0x410fd034;
|
||||||
|
cpu->revidr = 0x00000000;
|
||||||
cpu->reset_fpsid = 0x41034070;
|
cpu->reset_fpsid = 0x41034070;
|
||||||
cpu->mvfr0 = 0x10110222;
|
cpu->mvfr0 = 0x10110222;
|
||||||
cpu->mvfr1 = 0x12111111;
|
cpu->mvfr1 = 0x12111111;
|
||||||
|
|
|
@ -2938,13 +2938,12 @@ void register_cp_regs_for_features(ARMCPU *cpu)
|
||||||
};
|
};
|
||||||
ARMCPRegInfo id_v8_midr_cp_reginfo[] = {
|
ARMCPRegInfo id_v8_midr_cp_reginfo[] = {
|
||||||
/* v8 MIDR -- the wildcard isn't necessary, and nor is the
|
/* v8 MIDR -- the wildcard isn't necessary, and nor is the
|
||||||
* variable-MIDR TI925 behaviour. Instead we have a single
|
* variable-MIDR TI925 behaviour.
|
||||||
* (strictly speaking IMPDEF) alias of the MIDR, REVIDR.
|
|
||||||
*/
|
*/
|
||||||
{ "MIDR_EL1", 0,0,0, 3,0,0, ARM_CP_STATE_BOTH,
|
{ "MIDR_EL1", 0,0,0, 3,0,0, ARM_CP_STATE_BOTH,
|
||||||
ARM_CP_CONST, PL1_R, 0, NULL, cpu->midr },
|
ARM_CP_CONST, PL1_R, 0, NULL, cpu->midr },
|
||||||
{ "REVIDR_EL1", 0,0,0, 3,0,6, ARM_CP_STATE_BOTH,
|
{ "REVIDR_EL1", 0,0,0, 3,0,6, ARM_CP_STATE_BOTH,
|
||||||
ARM_CP_CONST, PL1_R, 0, NULL, cpu->midr },
|
ARM_CP_CONST, PL1_R, 0, NULL, cpu->revidr },
|
||||||
REGINFO_SENTINEL
|
REGINFO_SENTINEL
|
||||||
};
|
};
|
||||||
ARMCPRegInfo id_cp_reginfo[] = {
|
ARMCPRegInfo id_cp_reginfo[] = {
|
||||||
|
|
Loading…
Reference in a new issue