aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/kernel/setup.c
diff options
context:
space:
mode:
authorCatalin Marinas <catalin.marinas@arm.com>2007-09-25 11:49:45 -0400
committerRussell King <rmk+kernel@arm.linux.org.uk>2007-10-12 18:43:27 -0400
commit180005c4efb76a81fd0abcef4c2412d238eea20c (patch)
treefbc9e78fce9c9c071d97e59a77a9e2fb8d7c3c1a /arch/arm/kernel/setup.c
parentc1f438f5eec867707022e5f33bec5e91ec12f6e7 (diff)
[ARM] 4585/1: Correctly identify the CPU architecture version
The cpu_architecture() function in arch/arm/kernel/setup.c only works with cores produced by ARM Ltd. The more generic approach is to read the ID_MMFR0 register and check for the VMSA or PMSA version supported. With this patch, the ARM11MPCore would be reported as ARMv7 since its MMU is compatible with ARMv7. Signed-off-by: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/kernel/setup.c')
-rw-r--r--arch/arm/kernel/setup.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
index 4de432ec903a..efac7df72d65 100644
--- a/arch/arm/kernel/setup.c
+++ b/arch/arm/kernel/setup.c
@@ -304,10 +304,23 @@ int cpu_architecture(void)
304 cpu_arch = (processor_id >> 16) & 7; 304 cpu_arch = (processor_id >> 16) & 7;
305 if (cpu_arch) 305 if (cpu_arch)
306 cpu_arch += CPU_ARCH_ARMv3; 306 cpu_arch += CPU_ARCH_ARMv3;
307 } else { 307 } else if ((processor_id & 0x000f0000) == 0x000f0000) {
308 /* the revised CPUID */ 308 unsigned int mmfr0;
309 cpu_arch = ((processor_id >> 12) & 0xf) - 0xb + CPU_ARCH_ARMv6; 309
310 } 310 /* Revised CPUID format. Read the Memory Model Feature
311 * Register 0 and check for VMSAv7 or PMSAv7 */
312 asm("mrc p15, 0, %0, c0, c1, 4"
313 : "=r" (mmfr0));
314 if ((mmfr0 & 0x0000000f) == 0x00000003 ||
315 (mmfr0 & 0x000000f0) == 0x00000030)
316 cpu_arch = CPU_ARCH_ARMv7;
317 else if ((mmfr0 & 0x0000000f) == 0x00000002 ||
318 (mmfr0 & 0x000000f0) == 0x00000020)
319 cpu_arch = CPU_ARCH_ARMv6;
320 else
321 cpu_arch = CPU_ARCH_UNKNOWN;
322 } else
323 cpu_arch = CPU_ARCH_UNKNOWN;
311 324
312 return cpu_arch; 325 return cpu_arch;
313} 326}