mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-11 13:25:28 +00:00
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:
parent
3501c34344
commit
91cf36e372
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue