target/arm: Test correct register in aa32_pan and aa32_ats1e1 checks

The isar_feature_aa32_pan and isar_feature_aa32_ats1e1 functions
are supposed to be testing fields in ID_MMFR3; but a cut-and-paste
error meant we were looking at MVFR0 instead.

Fix the functions to look at the right register; this requires
us to move at least id_mmfr3 to the ARMISARegisters struct; we
choose to move all the ID_MMFRn registers for consistency.

Backports commit 10054016eda1b13bdd8340d100fd029cc8b58f36 from qemu
This commit is contained in:
Peter Maydell 2020-03-21 18:45:48 -04:00 committed by Lioncash
parent e72fa1cb33
commit 4693b2c011
4 changed files with 79 additions and 79 deletions

View file

@ -1183,9 +1183,9 @@ static void arm1136_r2_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x1; cpu->id_pfr1 = 0x1;
cpu->isar.id_dfr0 = 0x2; cpu->isar.id_dfr0 = 0x2;
cpu->id_afr0 = 0x3; cpu->id_afr0 = 0x3;
cpu->id_mmfr0 = 0x01130003; cpu->isar.id_mmfr0 = 0x01130003;
cpu->id_mmfr1 = 0x10030302; cpu->isar.id_mmfr1 = 0x10030302;
cpu->id_mmfr2 = 0x01222110; cpu->isar.id_mmfr2 = 0x01222110;
cpu->isar.id_isar0 = 0x00140011; cpu->isar.id_isar0 = 0x00140011;
cpu->isar.id_isar1 = 0x12002111; cpu->isar.id_isar1 = 0x12002111;
cpu->isar.id_isar2 = 0x11231111; cpu->isar.id_isar2 = 0x11231111;
@ -1215,9 +1215,9 @@ static void arm1136_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x1; cpu->id_pfr1 = 0x1;
cpu->isar.id_dfr0 = 0x2; cpu->isar.id_dfr0 = 0x2;
cpu->id_afr0 = 0x3; cpu->id_afr0 = 0x3;
cpu->id_mmfr0 = 0x01130003; cpu->isar.id_mmfr0 = 0x01130003;
cpu->id_mmfr1 = 0x10030302; cpu->isar.id_mmfr1 = 0x10030302;
cpu->id_mmfr2 = 0x01222110; cpu->isar.id_mmfr2 = 0x01222110;
cpu->isar.id_isar0 = 0x00140011; cpu->isar.id_isar0 = 0x00140011;
cpu->isar.id_isar1 = 0x12002111; cpu->isar.id_isar1 = 0x12002111;
cpu->isar.id_isar2 = 0x11231111; cpu->isar.id_isar2 = 0x11231111;
@ -1248,9 +1248,9 @@ static void arm1176_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x11; cpu->id_pfr1 = 0x11;
cpu->isar.id_dfr0 = 0x33; cpu->isar.id_dfr0 = 0x33;
cpu->id_afr0 = 0; cpu->id_afr0 = 0;
cpu->id_mmfr0 = 0x01130003; cpu->isar.id_mmfr0 = 0x01130003;
cpu->id_mmfr1 = 0x10030302; cpu->isar.id_mmfr1 = 0x10030302;
cpu->id_mmfr2 = 0x01222100; cpu->isar.id_mmfr2 = 0x01222100;
cpu->isar.id_isar0 = 0x0140011; cpu->isar.id_isar0 = 0x0140011;
cpu->isar.id_isar1 = 0x12002111; cpu->isar.id_isar1 = 0x12002111;
cpu->isar.id_isar2 = 0x11231121; cpu->isar.id_isar2 = 0x11231121;
@ -1278,9 +1278,9 @@ static void arm11mpcore_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x1; cpu->id_pfr1 = 0x1;
cpu->isar.id_dfr0 = 0; cpu->isar.id_dfr0 = 0;
cpu->id_afr0 = 0x2; cpu->id_afr0 = 0x2;
cpu->id_mmfr0 = 0x01100103; cpu->isar.id_mmfr0 = 0x01100103;
cpu->id_mmfr1 = 0x10020302; cpu->isar.id_mmfr1 = 0x10020302;
cpu->id_mmfr2 = 0x01222000; cpu->isar.id_mmfr2 = 0x01222000;
cpu->isar.id_isar0 = 0x00100011; cpu->isar.id_isar0 = 0x00100011;
cpu->isar.id_isar1 = 0x12002111; cpu->isar.id_isar1 = 0x12002111;
cpu->isar.id_isar2 = 0x11221011; cpu->isar.id_isar2 = 0x11221011;
@ -1310,10 +1310,10 @@ static void cortex_m3_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00000200; cpu->id_pfr1 = 0x00000200;
cpu->isar.id_dfr0 = 0x00100000; cpu->isar.id_dfr0 = 0x00100000;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x00000030; cpu->isar.id_mmfr0 = 0x00000030;
cpu->id_mmfr1 = 0x00000000; cpu->isar.id_mmfr1 = 0x00000000;
cpu->id_mmfr2 = 0x00000000; cpu->isar.id_mmfr2 = 0x00000000;
cpu->id_mmfr3 = 0x00000000; cpu->isar.id_mmfr3 = 0x00000000;
cpu->isar.id_isar0 = 0x01141110; cpu->isar.id_isar0 = 0x01141110;
cpu->isar.id_isar1 = 0x02111000; cpu->isar.id_isar1 = 0x02111000;
cpu->isar.id_isar2 = 0x21112231; cpu->isar.id_isar2 = 0x21112231;
@ -1341,10 +1341,10 @@ static void cortex_m4_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00000200; cpu->id_pfr1 = 0x00000200;
cpu->isar.id_dfr0 = 0x00100000; cpu->isar.id_dfr0 = 0x00100000;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x00000030; cpu->isar.id_mmfr0 = 0x00000030;
cpu->id_mmfr1 = 0x00000000; cpu->isar.id_mmfr1 = 0x00000000;
cpu->id_mmfr2 = 0x00000000; cpu->isar.id_mmfr2 = 0x00000000;
cpu->id_mmfr3 = 0x00000000; cpu->isar.id_mmfr3 = 0x00000000;
cpu->isar.id_isar0 = 0x01141110; cpu->isar.id_isar0 = 0x01141110;
cpu->isar.id_isar1 = 0x02111000; cpu->isar.id_isar1 = 0x02111000;
cpu->isar.id_isar2 = 0x21112231; cpu->isar.id_isar2 = 0x21112231;
@ -1372,10 +1372,10 @@ static void cortex_m7_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00000200; cpu->id_pfr1 = 0x00000200;
cpu->isar.id_dfr0 = 0x00100000; cpu->isar.id_dfr0 = 0x00100000;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x00100030; cpu->isar.id_mmfr0 = 0x00100030;
cpu->id_mmfr1 = 0x00000000; cpu->isar.id_mmfr1 = 0x00000000;
cpu->id_mmfr2 = 0x01000000; cpu->isar.id_mmfr2 = 0x01000000;
cpu->id_mmfr3 = 0x00000000; cpu->isar.id_mmfr3 = 0x00000000;
cpu->isar.id_isar0 = 0x01101110; cpu->isar.id_isar0 = 0x01101110;
cpu->isar.id_isar1 = 0x02112000; cpu->isar.id_isar1 = 0x02112000;
cpu->isar.id_isar2 = 0x20232231; cpu->isar.id_isar2 = 0x20232231;
@ -1406,10 +1406,10 @@ static void cortex_m33_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00000210; cpu->id_pfr1 = 0x00000210;
cpu->isar.id_dfr0 = 0x00200000; cpu->isar.id_dfr0 = 0x00200000;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x00101F40; cpu->isar.id_mmfr0 = 0x00101F40;
cpu->id_mmfr1 = 0x00000000; cpu->isar.id_mmfr1 = 0x00000000;
cpu->id_mmfr2 = 0x01000000; cpu->isar.id_mmfr2 = 0x01000000;
cpu->id_mmfr3 = 0x00000000; cpu->isar.id_mmfr3 = 0x00000000;
cpu->isar.id_isar0 = 0x01101110; cpu->isar.id_isar0 = 0x01101110;
cpu->isar.id_isar1 = 0x02212000; cpu->isar.id_isar1 = 0x02212000;
cpu->isar.id_isar2 = 0x20232232; cpu->isar.id_isar2 = 0x20232232;
@ -1456,10 +1456,10 @@ static void cortex_r5_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x001; cpu->id_pfr1 = 0x001;
cpu->isar.id_dfr0 = 0x010400; cpu->isar.id_dfr0 = 0x010400;
cpu->id_afr0 = 0x0; cpu->id_afr0 = 0x0;
cpu->id_mmfr0 = 0x0210030; cpu->isar.id_mmfr0 = 0x0210030;
cpu->id_mmfr1 = 0x00000000; cpu->isar.id_mmfr1 = 0x00000000;
cpu->id_mmfr2 = 0x01200000; cpu->isar.id_mmfr2 = 0x01200000;
cpu->id_mmfr3 = 0x0211; cpu->isar.id_mmfr3 = 0x0211;
cpu->isar.id_isar0 = 0x02101111; cpu->isar.id_isar0 = 0x02101111;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232141; cpu->isar.id_isar2 = 0x21232141;
@ -1511,10 +1511,10 @@ static void cortex_a8_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x11; cpu->id_pfr1 = 0x11;
cpu->isar.id_dfr0 = 0x400; cpu->isar.id_dfr0 = 0x400;
cpu->id_afr0 = 0; cpu->id_afr0 = 0;
cpu->id_mmfr0 = 0x31100003; cpu->isar.id_mmfr0 = 0x31100003;
cpu->id_mmfr1 = 0x20000000; cpu->isar.id_mmfr1 = 0x20000000;
cpu->id_mmfr2 = 0x01202000; cpu->isar.id_mmfr2 = 0x01202000;
cpu->id_mmfr3 = 0x11; cpu->isar.id_mmfr3 = 0x11;
cpu->isar.id_isar0 = 0x00101111; cpu->isar.id_isar0 = 0x00101111;
cpu->isar.id_isar1 = 0x12112111; cpu->isar.id_isar1 = 0x12112111;
cpu->isar.id_isar2 = 0x21232031; cpu->isar.id_isar2 = 0x21232031;
@ -1584,10 +1584,10 @@ static void cortex_a9_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x11; cpu->id_pfr1 = 0x11;
cpu->isar.id_dfr0 = 0x000; cpu->isar.id_dfr0 = 0x000;
cpu->id_afr0 = 0; cpu->id_afr0 = 0;
cpu->id_mmfr0 = 0x00100103; cpu->isar.id_mmfr0 = 0x00100103;
cpu->id_mmfr1 = 0x20000000; cpu->isar.id_mmfr1 = 0x20000000;
cpu->id_mmfr2 = 0x01230000; cpu->isar.id_mmfr2 = 0x01230000;
cpu->id_mmfr3 = 0x00002111; cpu->isar.id_mmfr3 = 0x00002111;
cpu->isar.id_isar0 = 0x00101111; cpu->isar.id_isar0 = 0x00101111;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232041; cpu->isar.id_isar2 = 0x21232041;
@ -1647,10 +1647,10 @@ static void cortex_a7_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00011011; cpu->id_pfr1 = 0x00011011;
cpu->isar.id_dfr0 = 0x02010555; cpu->isar.id_dfr0 = 0x02010555;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x10101105; cpu->isar.id_mmfr0 = 0x10101105;
cpu->id_mmfr1 = 0x40000000; cpu->isar.id_mmfr1 = 0x40000000;
cpu->id_mmfr2 = 0x01240000; cpu->isar.id_mmfr2 = 0x01240000;
cpu->id_mmfr3 = 0x02102211; cpu->isar.id_mmfr3 = 0x02102211;
/* a7_mpcore_r0p5_trm, page 4-4 gives 0x01101110; but /* a7_mpcore_r0p5_trm, page 4-4 gives 0x01101110; but
* table 4-41 gives 0x02101110, which includes the arm div insns. * table 4-41 gives 0x02101110, which includes the arm div insns.
*/ */
@ -1693,10 +1693,10 @@ static void cortex_a15_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00011011; cpu->id_pfr1 = 0x00011011;
cpu->isar.id_dfr0 = 0x02010555; cpu->isar.id_dfr0 = 0x02010555;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x10201105; cpu->isar.id_mmfr0 = 0x10201105;
cpu->id_mmfr1 = 0x20000000; cpu->isar.id_mmfr1 = 0x20000000;
cpu->id_mmfr2 = 0x01240000; cpu->isar.id_mmfr2 = 0x01240000;
cpu->id_mmfr3 = 0x02102211; cpu->isar.id_mmfr3 = 0x02102211;
cpu->isar.id_isar0 = 0x02101110; cpu->isar.id_isar0 = 0x02101110;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232041; cpu->isar.id_isar2 = 0x21232041;
@ -1928,13 +1928,13 @@ static void arm_max_initfn(struct uc_struct *uc, Object *obj, void *opaque)
t = FIELD_DP32(t, MVFR2, FPMISC, 4); /* FP MaxNum */ t = FIELD_DP32(t, MVFR2, FPMISC, 4); /* FP MaxNum */
cpu->isar.mvfr2 = t; cpu->isar.mvfr2 = t;
t = cpu->id_mmfr3; t = cpu->isar.id_mmfr3;
t = FIELD_DP32(t, ID_MMFR3, PAN, 2); /* ATS1E1 */ t = FIELD_DP32(t, ID_MMFR3, PAN, 2); /* ATS1E1 */
cpu->id_mmfr3 = t; cpu->isar.id_mmfr3 = t;
t = cpu->id_mmfr4; t = cpu->isar.id_mmfr4;
t = FIELD_DP32(t, ID_MMFR4, HPDS, 1); /* AA32HPD */ t = FIELD_DP32(t, ID_MMFR4, HPDS, 1); /* AA32HPD */
cpu->id_mmfr4 = t; cpu->isar.id_mmfr4 = t;
} }
} }
#endif #endif

View file

@ -834,6 +834,11 @@ struct ARMCPU {
uint32_t id_isar4; uint32_t id_isar4;
uint32_t id_isar5; uint32_t id_isar5;
uint32_t id_isar6; uint32_t id_isar6;
uint32_t id_mmfr0;
uint32_t id_mmfr1;
uint32_t id_mmfr2;
uint32_t id_mmfr3;
uint32_t id_mmfr4;
uint32_t mvfr0; uint32_t mvfr0;
uint32_t mvfr1; uint32_t mvfr1;
uint32_t mvfr2; uint32_t mvfr2;
@ -859,11 +864,6 @@ struct ARMCPU {
uint64_t pmceid0; uint64_t pmceid0;
uint64_t pmceid1; uint64_t pmceid1;
uint32_t id_afr0; uint32_t id_afr0;
uint32_t id_mmfr0;
uint32_t id_mmfr1;
uint32_t id_mmfr2;
uint32_t id_mmfr3;
uint32_t id_mmfr4;
uint64_t id_aa64afr0; uint64_t id_aa64afr0;
uint64_t id_aa64afr1; uint64_t id_aa64afr1;
uint32_t clidr; uint32_t clidr;
@ -3377,12 +3377,12 @@ static inline bool isar_feature_aa32_vminmaxnm(const ARMISARegisters *id)
static inline bool isar_feature_aa32_pan(const ARMISARegisters *id) static inline bool isar_feature_aa32_pan(const ARMISARegisters *id)
{ {
return FIELD_EX64(id->mvfr0, ID_MMFR3, PAN) != 0; return FIELD_EX32(id->id_mmfr3, ID_MMFR3, PAN) != 0;
} }
static inline bool isar_feature_aa32_ats1e1(const ARMISARegisters *id) static inline bool isar_feature_aa32_ats1e1(const ARMISARegisters *id)
{ {
return FIELD_EX64(id->mvfr0, ID_MMFR3, PAN) >= 2; return FIELD_EX32(id->id_mmfr3, ID_MMFR3, PAN) >= 2;
} }
static inline bool isar_feature_aa32_pmu_8_1(const ARMISARegisters *id) static inline bool isar_feature_aa32_pmu_8_1(const ARMISARegisters *id)

View file

@ -118,10 +118,10 @@ static void aarch64_a57_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00011011; cpu->id_pfr1 = 0x00011011;
cpu->isar.id_dfr0 = 0x03010066; cpu->isar.id_dfr0 = 0x03010066;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x10101105; cpu->isar.id_mmfr0 = 0x10101105;
cpu->id_mmfr1 = 0x40000000; cpu->isar.id_mmfr1 = 0x40000000;
cpu->id_mmfr2 = 0x01260000; cpu->isar.id_mmfr2 = 0x01260000;
cpu->id_mmfr3 = 0x02102211; cpu->isar.id_mmfr3 = 0x02102211;
cpu->isar.id_isar0 = 0x02101110; cpu->isar.id_isar0 = 0x02101110;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232042; cpu->isar.id_isar2 = 0x21232042;
@ -169,10 +169,10 @@ static void aarch64_a53_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00011011; cpu->id_pfr1 = 0x00011011;
cpu->isar.id_dfr0 = 0x03010066; cpu->isar.id_dfr0 = 0x03010066;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x10101105; cpu->isar.id_mmfr0 = 0x10101105;
cpu->id_mmfr1 = 0x40000000; cpu->isar.id_mmfr1 = 0x40000000;
cpu->id_mmfr2 = 0x01260000; cpu->isar.id_mmfr2 = 0x01260000;
cpu->id_mmfr3 = 0x02102211; cpu->isar.id_mmfr3 = 0x02102211;
cpu->isar.id_isar0 = 0x02101110; cpu->isar.id_isar0 = 0x02101110;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232042; cpu->isar.id_isar2 = 0x21232042;
@ -219,10 +219,10 @@ static void aarch64_a72_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->id_pfr1 = 0x00011011; cpu->id_pfr1 = 0x00011011;
cpu->isar.id_dfr0 = 0x03010066; cpu->isar.id_dfr0 = 0x03010066;
cpu->id_afr0 = 0x00000000; cpu->id_afr0 = 0x00000000;
cpu->id_mmfr0 = 0x10201105; cpu->isar.id_mmfr0 = 0x10201105;
cpu->id_mmfr1 = 0x40000000; cpu->isar.id_mmfr1 = 0x40000000;
cpu->id_mmfr2 = 0x01260000; cpu->isar.id_mmfr2 = 0x01260000;
cpu->id_mmfr3 = 0x02102211; cpu->isar.id_mmfr3 = 0x02102211;
cpu->isar.id_isar0 = 0x02101110; cpu->isar.id_isar0 = 0x02101110;
cpu->isar.id_isar1 = 0x13112111; cpu->isar.id_isar1 = 0x13112111;
cpu->isar.id_isar2 = 0x21232042; cpu->isar.id_isar2 = 0x21232042;
@ -343,9 +343,9 @@ static void aarch64_max_initfn(struct uc_struct *uc, Object *obj, void *opaque)
u = FIELD_DP32(u, ID_ISAR6, SPECRES, 1); u = FIELD_DP32(u, ID_ISAR6, SPECRES, 1);
cpu->isar.id_isar6 = u; cpu->isar.id_isar6 = u;
u = cpu->id_mmfr3; u = cpu->isar.id_mmfr3;
u = FIELD_DP32(u, ID_MMFR3, PAN, 2); /* ATS1E1 */ u = FIELD_DP32(u, ID_MMFR3, PAN, 2); /* ATS1E1 */
cpu->id_mmfr3 = u; cpu->isar.id_mmfr3 = u;
u = cpu->isar.id_aa64dfr0; u = cpu->isar.id_aa64dfr0;
u = FIELD_DP64(u, ID_AA64DFR0, PMUVER, 5); /* v8.4-PMU */ u = FIELD_DP64(u, ID_AA64DFR0, PMUVER, 5); /* v8.4-PMU */

View file

@ -6711,22 +6711,22 @@ void register_cp_regs_for_features(ARMCPU *cpu)
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 4, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 4,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
.accessfn = access_aa32_tid3, .accessfn = access_aa32_tid3,
.resetvalue = cpu->id_mmfr0 }, .resetvalue = cpu->isar.id_mmfr0 },
{ .name = "ID_MMFR1", .state = ARM_CP_STATE_BOTH, { .name = "ID_MMFR1", .state = ARM_CP_STATE_BOTH,
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 5, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 5,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
.accessfn = access_aa32_tid3, .accessfn = access_aa32_tid3,
.resetvalue = cpu->id_mmfr1 }, .resetvalue = cpu->isar.id_mmfr1 },
{ .name = "ID_MMFR2", .state = ARM_CP_STATE_BOTH, { .name = "ID_MMFR2", .state = ARM_CP_STATE_BOTH,
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 6, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 6,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
.accessfn = access_aa32_tid3, .accessfn = access_aa32_tid3,
.resetvalue = cpu->id_mmfr2 }, .resetvalue = cpu->isar.id_mmfr2 },
{ .name = "ID_MMFR3", .state = ARM_CP_STATE_BOTH, { .name = "ID_MMFR3", .state = ARM_CP_STATE_BOTH,
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 7, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 1, .opc2 = 7,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
.accessfn = access_aa32_tid3, .accessfn = access_aa32_tid3,
.resetvalue = cpu->id_mmfr3 }, .resetvalue = cpu->isar.id_mmfr3 },
{ .name = "ID_ISAR0", .state = ARM_CP_STATE_BOTH, { .name = "ID_ISAR0", .state = ARM_CP_STATE_BOTH,
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 0, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 0,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
@ -6761,7 +6761,7 @@ void register_cp_regs_for_features(ARMCPU *cpu)
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 6, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 6,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
.accessfn = access_aa32_tid3, .accessfn = access_aa32_tid3,
.resetvalue = cpu->id_mmfr4 }, .resetvalue = cpu->isar.id_mmfr4 },
{ .name = "ID_ISAR6", .state = ARM_CP_STATE_BOTH, { .name = "ID_ISAR6", .state = ARM_CP_STATE_BOTH,
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 7, .opc0 = 3, .opc1 = 0, .crn = 0, .crm = 2, .opc2 = 7,
.access = PL1_R, .type = ARM_CP_CONST, .access = PL1_R, .type = ARM_CP_CONST,
@ -7209,7 +7209,7 @@ void register_cp_regs_for_features(ARMCPU *cpu)
define_arm_cp_regs(cpu, vmsa_pmsa_cp_reginfo); define_arm_cp_regs(cpu, vmsa_pmsa_cp_reginfo);
define_arm_cp_regs(cpu, vmsa_cp_reginfo); define_arm_cp_regs(cpu, vmsa_cp_reginfo);
/* TTCBR2 is introduced with ARMv8.2-A32HPD. */ /* TTCBR2 is introduced with ARMv8.2-A32HPD. */
if (FIELD_EX32(cpu->id_mmfr4, ID_MMFR4, HPDS) != 0) { if (FIELD_EX32(cpu->isar.id_mmfr4, ID_MMFR4, HPDS) != 0) {
define_one_arm_cp_reg(cpu, &ttbcr2_reginfo); define_one_arm_cp_reg(cpu, &ttbcr2_reginfo);
} }
} }