target-arm: cpu64: generalise name of A57 regs

Rename some A57 CP register variables in preparation for support for
Cortex A53. Use "a57_a53" to describe the shareable features. Some of
the CP15 registers (such as ACTLR) are specific to implementation, but
we currently just RAZ them so continue with that as the policy for both
A57 and A53 processors under a shared definition.

Backports commit ee804264ddc4d3cd36a5183a09847e391da0fc66 from qemu
This commit is contained in:
Peter Crosthwaite 2018-02-12 21:23:26 -05:00 committed by Lioncash
parent 3501c34344
commit 91cf36e372
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7

View file

@ -34,21 +34,21 @@ static inline QEMU_UNUSED_FUNC void unset_feature(CPUARMState *env, int feature)
} }
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
static uint64_t a57_l2ctlr_read(CPUARMState *env, const ARMCPRegInfo *ri) static uint64_t a57_a53_l2ctlr_read(CPUARMState *env, const ARMCPRegInfo *ri)
{ {
/* Number of processors is in [25:24]; otherwise we RAZ */ /* Number of processors is in [25:24]; otherwise we RAZ */
return (smp_cpus - 1) << 24; return (smp_cpus - 1) << 24;
} }
#endif #endif
static const ARMCPRegInfo cortexa57_cp_reginfo[] = { static const ARMCPRegInfo cortex_a57_a53_cp_reginfo[] = {
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
{ "L2CTLR_EL1", 0,11,0, 3,1,2, ARM_CP_STATE_AA64, { "L2CTLR_EL1", 0,11,0, 3,1,2, ARM_CP_STATE_AA64,
0, PL1_RW, 0, NULL, 0, 0, {0, 0}, 0, PL1_RW, 0, NULL, 0, 0, {0, 0},
NULL, a57_l2ctlr_read, arm_cp_write_ignore, }, NULL, a57_a53_l2ctlr_read, arm_cp_write_ignore, },
{ "L2CTLR", 15,9,0, 0,1,2, 0, { "L2CTLR", 15,9,0, 0,1,2, 0,
0, PL1_RW, 0, NULL, 0, 0, {0, 0}, 0, PL1_RW, 0, NULL, 0, 0, {0, 0},
NULL, a57_l2ctlr_read, arm_cp_write_ignore, }, NULL, a57_a53_l2ctlr_read, arm_cp_write_ignore, },
#endif #endif
{ "L2ECTLR_EL1", 0,11,0, 3,1,3, ARM_CP_STATE_AA64, { "L2ECTLR_EL1", 0,11,0, 3,1,3, ARM_CP_STATE_AA64,
ARM_CP_CONST, PL1_RW, 0, NULL, 0, }, ARM_CP_CONST, PL1_RW, 0, NULL, 0, },
@ -123,7 +123,7 @@ static void aarch64_a57_initfn(struct uc_struct *uc, Object *obj, void *opaque)
cpu->ccsidr[1] = 0x201fe012; /* 48KB L1 icache */ cpu->ccsidr[1] = 0x201fe012; /* 48KB L1 icache */
cpu->ccsidr[2] = 0x70ffe07a; /* 2048KB L2 cache */ cpu->ccsidr[2] = 0x70ffe07a; /* 2048KB L2 cache */
cpu->dcz_blocksize = 4; /* 64 bytes */ cpu->dcz_blocksize = 4; /* 64 bytes */
define_arm_cp_regs(cpu, cortexa57_cp_reginfo); define_arm_cp_regs(cpu, cortex_a57_a53_cp_reginfo);
} }
#ifdef CONFIG_USER_ONLY #ifdef CONFIG_USER_ONLY