代码主要是从TCPMP0.72中提取出来,其原理就是操作CP15,当操作CP15的register0且opcode2为0时返回的就是Main ID,opcode2为1是返回的是Cache type。有关CP15的操作是用的汇编代码,而上层调用则是用的C代码,两者结合起来达到应用程序获取cpuid的目的。不过因为TCPMP的代码出来较早,我发现它对cpuid的分析主要是基于"ARM Architecture Reference Manual"、issue为"E"(具体见B2-6),因为版本较旧所以会有所偏差,对于Context A/M系列前的ARM,如果用"ARMv5 Architecture Reference Manual"、issue为"I"(具体见B3.3)则能够比较准确的分析cpuid及cache信息。
1、汇编代码部分
2、C部分
3、调用实例
4、厂家信息(Main ID的Bits[31:24])
0x41 A (ARM Limited)
0x44 D (Digital Equipment Corporation)
0x4D M (Motorola - Freescale Semiconductor Inc.)
0x56 V (Marvell Semiconductor Inc.)
0x69 i (Intel Corporation)
5、架构信息(当不是ARM7的时候Main ID的Bits[19:16])
0x1 ARM architecture v4
0x2 ARM architecture v4T
0x3 ARM architecture v5
0x4 ARM architecture v5T
0x5 ARM architecture v5TE
0x6 ARM architecture v5TEJ
0x7 ARM architecture v6
0xF Revised CPUID format. Details available from ARM.