mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-25 16:17:02 +00:00 
			
		
		
		
	target-arm: Move feature register setup to per-CPU init fns
Move feature register value setup to per-CPU init functions. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Acked-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
		
							parent
							
								
									0cc892fd97
								
							
						
					
					
						commit
						2e4d7e3e3e
					
				| @ -75,6 +75,20 @@ typedef struct ARMCPU { | |||||||
|     uint32_t mvfr1; |     uint32_t mvfr1; | ||||||
|     uint32_t ctr; |     uint32_t ctr; | ||||||
|     uint32_t reset_sctlr; |     uint32_t reset_sctlr; | ||||||
|  |     uint32_t id_pfr0; | ||||||
|  |     uint32_t id_pfr1; | ||||||
|  |     uint32_t id_dfr0; | ||||||
|  |     uint32_t id_afr0; | ||||||
|  |     uint32_t id_mmfr0; | ||||||
|  |     uint32_t id_mmfr1; | ||||||
|  |     uint32_t id_mmfr2; | ||||||
|  |     uint32_t id_mmfr3; | ||||||
|  |     uint32_t id_isar0; | ||||||
|  |     uint32_t id_isar1; | ||||||
|  |     uint32_t id_isar2; | ||||||
|  |     uint32_t id_isar3; | ||||||
|  |     uint32_t id_isar4; | ||||||
|  |     uint32_t id_isar5; | ||||||
| } ARMCPU; | } ARMCPU; | ||||||
| 
 | 
 | ||||||
| static inline ARMCPU *arm_env_get_cpu(CPUARMState *env) | static inline ARMCPU *arm_env_get_cpu(CPUARMState *env) | ||||||
|  | |||||||
| @ -130,6 +130,13 @@ static void arm1026_initfn(Object *obj) | |||||||
| static void arm1136_r2_initfn(Object *obj) | static void arm1136_r2_initfn(Object *obj) | ||||||
| { | { | ||||||
|     ARMCPU *cpu = ARM_CPU(obj); |     ARMCPU *cpu = ARM_CPU(obj); | ||||||
|  |     /* What qemu calls "arm1136_r2" is actually the 1136 r0p2, ie an
 | ||||||
|  |      * older core than plain "arm1136". In particular this does not | ||||||
|  |      * have the v6K features. | ||||||
|  |      * These ID register values are correct for 1136 but may be wrong | ||||||
|  |      * for 1136_r2 (in particular r0p2 does not actually implement most | ||||||
|  |      * of the ID registers). | ||||||
|  |      */ | ||||||
|     set_feature(&cpu->env, ARM_FEATURE_V6); |     set_feature(&cpu->env, ARM_FEATURE_V6); | ||||||
|     set_feature(&cpu->env, ARM_FEATURE_VFP); |     set_feature(&cpu->env, ARM_FEATURE_VFP); | ||||||
|     cpu->midr = ARM_CPUID_ARM1136_R2; |     cpu->midr = ARM_CPUID_ARM1136_R2; | ||||||
| @ -138,6 +145,18 @@ static void arm1136_r2_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x00000000; |     cpu->mvfr1 = 0x00000000; | ||||||
|     cpu->ctr = 0x1dd20d2; |     cpu->ctr = 0x1dd20d2; | ||||||
|     cpu->reset_sctlr = 0x00050078; |     cpu->reset_sctlr = 0x00050078; | ||||||
|  |     cpu->id_pfr0 = 0x111; | ||||||
|  |     cpu->id_pfr1 = 0x1; | ||||||
|  |     cpu->id_dfr0 = 0x2; | ||||||
|  |     cpu->id_afr0 = 0x3; | ||||||
|  |     cpu->id_mmfr0 = 0x01130003; | ||||||
|  |     cpu->id_mmfr1 = 0x10030302; | ||||||
|  |     cpu->id_mmfr2 = 0x01222110; | ||||||
|  |     cpu->id_isar0 = 0x00140011; | ||||||
|  |     cpu->id_isar1 = 0x12002111; | ||||||
|  |     cpu->id_isar2 = 0x11231111; | ||||||
|  |     cpu->id_isar3 = 0x01102131; | ||||||
|  |     cpu->id_isar4 = 0x141; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void arm1136_initfn(Object *obj) | static void arm1136_initfn(Object *obj) | ||||||
| @ -152,6 +171,18 @@ static void arm1136_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x00000000; |     cpu->mvfr1 = 0x00000000; | ||||||
|     cpu->ctr = 0x1dd20d2; |     cpu->ctr = 0x1dd20d2; | ||||||
|     cpu->reset_sctlr = 0x00050078; |     cpu->reset_sctlr = 0x00050078; | ||||||
|  |     cpu->id_pfr0 = 0x111; | ||||||
|  |     cpu->id_pfr1 = 0x1; | ||||||
|  |     cpu->id_dfr0 = 0x2; | ||||||
|  |     cpu->id_afr0 = 0x3; | ||||||
|  |     cpu->id_mmfr0 = 0x01130003; | ||||||
|  |     cpu->id_mmfr1 = 0x10030302; | ||||||
|  |     cpu->id_mmfr2 = 0x01222110; | ||||||
|  |     cpu->id_isar0 = 0x00140011; | ||||||
|  |     cpu->id_isar1 = 0x12002111; | ||||||
|  |     cpu->id_isar2 = 0x11231111; | ||||||
|  |     cpu->id_isar3 = 0x01102131; | ||||||
|  |     cpu->id_isar4 = 0x141; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void arm1176_initfn(Object *obj) | static void arm1176_initfn(Object *obj) | ||||||
| @ -166,6 +197,18 @@ static void arm1176_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x00000000; |     cpu->mvfr1 = 0x00000000; | ||||||
|     cpu->ctr = 0x1dd20d2; |     cpu->ctr = 0x1dd20d2; | ||||||
|     cpu->reset_sctlr = 0x00050078; |     cpu->reset_sctlr = 0x00050078; | ||||||
|  |     cpu->id_pfr0 = 0x111; | ||||||
|  |     cpu->id_pfr1 = 0x11; | ||||||
|  |     cpu->id_dfr0 = 0x33; | ||||||
|  |     cpu->id_afr0 = 0; | ||||||
|  |     cpu->id_mmfr0 = 0x01130003; | ||||||
|  |     cpu->id_mmfr1 = 0x10030302; | ||||||
|  |     cpu->id_mmfr2 = 0x01222100; | ||||||
|  |     cpu->id_isar0 = 0x0140011; | ||||||
|  |     cpu->id_isar1 = 0x12002111; | ||||||
|  |     cpu->id_isar2 = 0x11231121; | ||||||
|  |     cpu->id_isar3 = 0x01102131; | ||||||
|  |     cpu->id_isar4 = 0x01141; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void arm11mpcore_initfn(Object *obj) | static void arm11mpcore_initfn(Object *obj) | ||||||
| @ -179,6 +222,18 @@ static void arm11mpcore_initfn(Object *obj) | |||||||
|     cpu->mvfr0 = 0x11111111; |     cpu->mvfr0 = 0x11111111; | ||||||
|     cpu->mvfr1 = 0x00000000; |     cpu->mvfr1 = 0x00000000; | ||||||
|     cpu->ctr = 0x1dd20d2; |     cpu->ctr = 0x1dd20d2; | ||||||
|  |     cpu->id_pfr0 = 0x111; | ||||||
|  |     cpu->id_pfr1 = 0x1; | ||||||
|  |     cpu->id_dfr0 = 0; | ||||||
|  |     cpu->id_afr0 = 0x2; | ||||||
|  |     cpu->id_mmfr0 = 0x01100103; | ||||||
|  |     cpu->id_mmfr1 = 0x10020302; | ||||||
|  |     cpu->id_mmfr2 = 0x01222000; | ||||||
|  |     cpu->id_isar0 = 0x00100011; | ||||||
|  |     cpu->id_isar1 = 0x12002111; | ||||||
|  |     cpu->id_isar2 = 0x11221011; | ||||||
|  |     cpu->id_isar3 = 0x01102131; | ||||||
|  |     cpu->id_isar4 = 0x141; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void cortex_m3_initfn(Object *obj) | static void cortex_m3_initfn(Object *obj) | ||||||
| @ -202,6 +257,19 @@ static void cortex_a8_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x00011100; |     cpu->mvfr1 = 0x00011100; | ||||||
|     cpu->ctr = 0x82048004; |     cpu->ctr = 0x82048004; | ||||||
|     cpu->reset_sctlr = 0x00c50078; |     cpu->reset_sctlr = 0x00c50078; | ||||||
|  |     cpu->id_pfr0 = 0x1031; | ||||||
|  |     cpu->id_pfr1 = 0x11; | ||||||
|  |     cpu->id_dfr0 = 0x400; | ||||||
|  |     cpu->id_afr0 = 0; | ||||||
|  |     cpu->id_mmfr0 = 0x31100003; | ||||||
|  |     cpu->id_mmfr1 = 0x20000000; | ||||||
|  |     cpu->id_mmfr2 = 0x01202000; | ||||||
|  |     cpu->id_mmfr3 = 0x11; | ||||||
|  |     cpu->id_isar0 = 0x00101111; | ||||||
|  |     cpu->id_isar1 = 0x12112111; | ||||||
|  |     cpu->id_isar2 = 0x21232031; | ||||||
|  |     cpu->id_isar3 = 0x11112131; | ||||||
|  |     cpu->id_isar4 = 0x00111142; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void cortex_a9_initfn(Object *obj) | static void cortex_a9_initfn(Object *obj) | ||||||
| @ -223,6 +291,19 @@ static void cortex_a9_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x01111111; |     cpu->mvfr1 = 0x01111111; | ||||||
|     cpu->ctr = 0x80038003; |     cpu->ctr = 0x80038003; | ||||||
|     cpu->reset_sctlr = 0x00c50078; |     cpu->reset_sctlr = 0x00c50078; | ||||||
|  |     cpu->id_pfr0 = 0x1031; | ||||||
|  |     cpu->id_pfr1 = 0x11; | ||||||
|  |     cpu->id_dfr0 = 0x000; | ||||||
|  |     cpu->id_afr0 = 0; | ||||||
|  |     cpu->id_mmfr0 = 0x00100103; | ||||||
|  |     cpu->id_mmfr1 = 0x20000000; | ||||||
|  |     cpu->id_mmfr2 = 0x01230000; | ||||||
|  |     cpu->id_mmfr3 = 0x00002111; | ||||||
|  |     cpu->id_isar0 = 0x00101111; | ||||||
|  |     cpu->id_isar1 = 0x13112111; | ||||||
|  |     cpu->id_isar2 = 0x21232041; | ||||||
|  |     cpu->id_isar3 = 0x11112131; | ||||||
|  |     cpu->id_isar4 = 0x00111142; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void cortex_a15_initfn(Object *obj) | static void cortex_a15_initfn(Object *obj) | ||||||
| @ -242,6 +323,19 @@ static void cortex_a15_initfn(Object *obj) | |||||||
|     cpu->mvfr1 = 0x11111111; |     cpu->mvfr1 = 0x11111111; | ||||||
|     cpu->ctr = 0x8444c004; |     cpu->ctr = 0x8444c004; | ||||||
|     cpu->reset_sctlr = 0x00c50078; |     cpu->reset_sctlr = 0x00c50078; | ||||||
|  |     cpu->id_pfr0 = 0x00001131; | ||||||
|  |     cpu->id_pfr1 = 0x00011011; | ||||||
|  |     cpu->id_dfr0 = 0x02010555; | ||||||
|  |     cpu->id_afr0 = 0x00000000; | ||||||
|  |     cpu->id_mmfr0 = 0x10201105; | ||||||
|  |     cpu->id_mmfr1 = 0x20000000; | ||||||
|  |     cpu->id_mmfr2 = 0x01240000; | ||||||
|  |     cpu->id_mmfr3 = 0x02102211; | ||||||
|  |     cpu->id_isar0 = 0x02101110; | ||||||
|  |     cpu->id_isar1 = 0x13112111; | ||||||
|  |     cpu->id_isar2 = 0x21232041; | ||||||
|  |     cpu->id_isar3 = 0x11112131; | ||||||
|  |     cpu->id_isar4 = 0x10011142; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void ti925t_initfn(Object *obj) | static void ti925t_initfn(Object *obj) | ||||||
|  | |||||||
| @ -7,45 +7,6 @@ | |||||||
| #endif | #endif | ||||||
| #include "sysemu.h" | #include "sysemu.h" | ||||||
| 
 | 
 | ||||||
| static uint32_t cortexa15_cp15_c0_c1[8] = { |  | ||||||
|     0x00001131, 0x00011011, 0x02010555, 0x00000000, |  | ||||||
|     0x10201105, 0x20000000, 0x01240000, 0x02102211 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static uint32_t cortexa15_cp15_c0_c2[8] = { |  | ||||||
|     0x02101110, 0x13112111, 0x21232041, 0x11112131, 0x10011142, 0, 0, 0 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static uint32_t cortexa9_cp15_c0_c1[8] = |  | ||||||
| { 0x1031, 0x11, 0x000, 0, 0x00100103, 0x20000000, 0x01230000, 0x00002111 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t cortexa9_cp15_c0_c2[8] = |  | ||||||
| { 0x00101111, 0x13112111, 0x21232041, 0x11112131, 0x00111142, 0, 0, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t cortexa8_cp15_c0_c1[8] = |  | ||||||
| { 0x1031, 0x11, 0x400, 0, 0x31100003, 0x20000000, 0x01202000, 0x11 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t cortexa8_cp15_c0_c2[8] = |  | ||||||
| { 0x00101111, 0x12112111, 0x21232031, 0x11112131, 0x00111142, 0, 0, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t mpcore_cp15_c0_c1[8] = |  | ||||||
| { 0x111, 0x1, 0, 0x2, 0x01100103, 0x10020302, 0x01222000, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t mpcore_cp15_c0_c2[8] = |  | ||||||
| { 0x00100011, 0x12002111, 0x11221011, 0x01102131, 0x141, 0, 0, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t arm1136_cp15_c0_c1[8] = |  | ||||||
| { 0x111, 0x1, 0x2, 0x3, 0x01130003, 0x10030302, 0x01222110, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t arm1136_cp15_c0_c2[8] = |  | ||||||
| { 0x00140011, 0x12002111, 0x11231111, 0x01102131, 0x141, 0, 0, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t arm1176_cp15_c0_c1[8] = |  | ||||||
| { 0x111, 0x11, 0x33, 0, 0x01130003, 0x10030302, 0x01222100, 0 }; |  | ||||||
| 
 |  | ||||||
| static uint32_t arm1176_cp15_c0_c2[8] = |  | ||||||
| { 0x0140011, 0x12002111, 0x11231121, 0x01102131, 0x01141, 0, 0, 0 }; |  | ||||||
| 
 |  | ||||||
| static void cpu_reset_model_id(CPUARMState *env, uint32_t id) | static void cpu_reset_model_id(CPUARMState *env, uint32_t id) | ||||||
| { | { | ||||||
|     switch (id) { |     switch (id) { | ||||||
| @ -58,43 +19,23 @@ static void cpu_reset_model_id(CPUARMState *env, uint32_t id) | |||||||
|     case ARM_CPUID_ARM1136: |     case ARM_CPUID_ARM1136: | ||||||
|         /* This is the 1136 r1, which is a v6K core */ |         /* This is the 1136 r1, which is a v6K core */ | ||||||
|     case ARM_CPUID_ARM1136_R2: |     case ARM_CPUID_ARM1136_R2: | ||||||
|         /* What qemu calls "arm1136_r2" is actually the 1136 r0p2, ie an
 |  | ||||||
|          * older core than plain "arm1136". In particular this does not |  | ||||||
|          * have the v6K features. |  | ||||||
|          */ |  | ||||||
|         /* These ID register values are correct for 1136 but may be wrong
 |  | ||||||
|          * for 1136_r2 (in particular r0p2 does not actually implement most |  | ||||||
|          * of the ID registers). |  | ||||||
|          */ |  | ||||||
|         memcpy(env->cp15.c0_c1, arm1136_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, arm1136_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         break; |         break; | ||||||
|     case ARM_CPUID_ARM1176: |     case ARM_CPUID_ARM1176: | ||||||
|         memcpy(env->cp15.c0_c1, arm1176_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, arm1176_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         break; |         break; | ||||||
|     case ARM_CPUID_ARM11MPCORE: |     case ARM_CPUID_ARM11MPCORE: | ||||||
|         memcpy(env->cp15.c0_c1, mpcore_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, mpcore_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         break; |         break; | ||||||
|     case ARM_CPUID_CORTEXA8: |     case ARM_CPUID_CORTEXA8: | ||||||
|         memcpy(env->cp15.c0_c1, cortexa8_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, cortexa8_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         env->cp15.c0_clid = (1 << 27) | (2 << 24) | 3; |         env->cp15.c0_clid = (1 << 27) | (2 << 24) | 3; | ||||||
|         env->cp15.c0_ccsid[0] = 0xe007e01a; /* 16k L1 dcache. */ |         env->cp15.c0_ccsid[0] = 0xe007e01a; /* 16k L1 dcache. */ | ||||||
|         env->cp15.c0_ccsid[1] = 0x2007e01a; /* 16k L1 icache. */ |         env->cp15.c0_ccsid[1] = 0x2007e01a; /* 16k L1 icache. */ | ||||||
|         env->cp15.c0_ccsid[2] = 0xf0000000; /* No L2 icache. */ |         env->cp15.c0_ccsid[2] = 0xf0000000; /* No L2 icache. */ | ||||||
|         break; |         break; | ||||||
|     case ARM_CPUID_CORTEXA9: |     case ARM_CPUID_CORTEXA9: | ||||||
|         memcpy(env->cp15.c0_c1, cortexa9_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, cortexa9_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         env->cp15.c0_clid = (1 << 27) | (1 << 24) | 3; |         env->cp15.c0_clid = (1 << 27) | (1 << 24) | 3; | ||||||
|         env->cp15.c0_ccsid[0] = 0xe00fe015; /* 16k L1 dcache. */ |         env->cp15.c0_ccsid[0] = 0xe00fe015; /* 16k L1 dcache. */ | ||||||
|         env->cp15.c0_ccsid[1] = 0x200fe015; /* 16k L1 icache. */ |         env->cp15.c0_ccsid[1] = 0x200fe015; /* 16k L1 icache. */ | ||||||
|         break; |         break; | ||||||
|     case ARM_CPUID_CORTEXA15: |     case ARM_CPUID_CORTEXA15: | ||||||
|         memcpy(env->cp15.c0_c1, cortexa15_cp15_c0_c1, 8 * sizeof(uint32_t)); |  | ||||||
|         memcpy(env->cp15.c0_c2, cortexa15_cp15_c0_c2, 8 * sizeof(uint32_t)); |  | ||||||
|         env->cp15.c0_clid = 0x0a200023; |         env->cp15.c0_clid = 0x0a200023; | ||||||
|         env->cp15.c0_ccsid[0] = 0x701fe00a; /* 32K L1 dcache */ |         env->cp15.c0_ccsid[0] = 0x701fe00a; /* 32K L1 dcache */ | ||||||
|         env->cp15.c0_ccsid[1] = 0x201fe00a; /* 32K L1 icache */ |         env->cp15.c0_ccsid[1] = 0x201fe00a; /* 32K L1 icache */ | ||||||
| @ -159,6 +100,20 @@ void cpu_state_reset(CPUARMState *env) | |||||||
|     env->vfp.xregs[ARM_VFP_MVFR1] = cpu->mvfr1; |     env->vfp.xregs[ARM_VFP_MVFR1] = cpu->mvfr1; | ||||||
|     env->cp15.c0_cachetype = cpu->ctr; |     env->cp15.c0_cachetype = cpu->ctr; | ||||||
|     env->cp15.c1_sys = cpu->reset_sctlr; |     env->cp15.c1_sys = cpu->reset_sctlr; | ||||||
|  |     env->cp15.c0_c1[0] = cpu->id_pfr0; | ||||||
|  |     env->cp15.c0_c1[1] = cpu->id_pfr1; | ||||||
|  |     env->cp15.c0_c1[2] = cpu->id_dfr0; | ||||||
|  |     env->cp15.c0_c1[3] = cpu->id_afr0; | ||||||
|  |     env->cp15.c0_c1[4] = cpu->id_mmfr0; | ||||||
|  |     env->cp15.c0_c1[5] = cpu->id_mmfr1; | ||||||
|  |     env->cp15.c0_c1[6] = cpu->id_mmfr2; | ||||||
|  |     env->cp15.c0_c1[7] = cpu->id_mmfr3; | ||||||
|  |     env->cp15.c0_c2[0] = cpu->id_isar0; | ||||||
|  |     env->cp15.c0_c2[1] = cpu->id_isar1; | ||||||
|  |     env->cp15.c0_c2[2] = cpu->id_isar2; | ||||||
|  |     env->cp15.c0_c2[3] = cpu->id_isar3; | ||||||
|  |     env->cp15.c0_c2[4] = cpu->id_isar4; | ||||||
|  |     env->cp15.c0_c2[5] = cpu->id_isar5; | ||||||
| 
 | 
 | ||||||
|     if (arm_feature(env, ARM_FEATURE_IWMMXT)) { |     if (arm_feature(env, ARM_FEATURE_IWMMXT)) { | ||||||
|         env->iwmmxt.cregs[ARM_IWMMXT_wCID] = 0x69051000 | 'Q'; |         env->iwmmxt.cregs[ARM_IWMMXT_wCID] = 0x69051000 | 'Q'; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Peter Maydell
						Peter Maydell