什么是CPUID标准function01H?

我需要检查ECX的第30位,这是RDRAND所需的CPUfunction。 来自RDRAND Wiki ,

如果支持,则在调用CPUID标准function01H后设置ECX寄存器的第30位。

我不知道这意味着什么。 “标准function01H ”?

这是否意味着EAX = 80000001h ? 我不确定该怎么办。

我认为这意味着在调用cpuid函数时%eax应为1。 硬件人员有奇怪的约定,所以他们说01H而不是1或0x1。

参见英特尔手册 Vol 2. Ch 3.表3.8。 eax的初始值为01H。 退货时ECX充满了表3.10中的function信息。 在该表底部的第30位,它表示值为1表示处理器支持RDRAND。

如果你有gcc,你可以尝试这样的事情:

 evaitl@bb ~/se $ cat foo.c #include  #include  int main(){ unsigned eax=0, ebx=0, ecx=0, edx=0; unsigned max_lvl=__get_cpuid_max(0,&ebx); printf("Max level: %d sig %x\n",max_lvl,ebx); ebx=0; for(int lvl=0; lvl<=max_lvl; ++lvl){ __get_cpuid(lvl,&eax, &ebx, &ecx, &edx); printf("lvl %-2d eax %08x ebx %08x ecx %08x edx %08x\n", lvl, eax, ebx, ecx, edx); eax=ebx=ecx=edx=0; } return 0; } evaitl@bb ~/se $ ./foo Max level: 13 sig 756e6547 lvl 0 eax 0000000d ebx 756e6547 ecx 6c65746e edx 49656e69 lvl 1 eax 000306e4 ebx 07200800 ecx 7fbee3bf edx bfebfbff lvl 2 eax 76036301 ebx 00f0b2ff ecx 00000000 edx 00ca0000 lvl 3 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 lvl 4 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 lvl 5 eax 00000040 ebx 00000040 ecx 00000003 edx 00001120 lvl 6 eax 00000077 ebx 00000002 ecx 00000009 edx 00000000 lvl 7 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 lvl 8 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 lvl 9 eax 00000001 ebx 00000000 ecx 00000000 edx 00000000 lvl 10 eax 07300403 ebx 00000000 ecx 00000000 edx 00000603 lvl 11 eax 00000000 ebx 00000000 ecx 0000006e edx 00000007 lvl 12 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 lvl 13 eax 00000000 ebx 00000000 ecx 00000000 edx 00000000 

解码所有内容需要相当长的时间,但中的定义可以提供帮助:

 /* %ecx */ #define bit_SSE3 (1 << 0) #define bit_PCLMUL (1 << 1) #define bit_LZCNT (1 << 5) #define bit_SSSE3 (1 << 9) #define bit_FMA (1 << 12) #define bit_CMPXCHG16B (1 << 13) #define bit_SSE4_1 (1 << 19) #define bit_SSE4_2 (1 << 20) #define bit_MOVBE (1 << 22) #define bit_POPCNT (1 << 23) #define bit_AES (1 << 25) #define bit_XSAVE (1 << 26) #define bit_OSXSAVE (1 << 27) #define bit_AVX (1 << 28) #define bit_F16C (1 << 29) #define bit_RDRND (1 << 30) 

头文件中有更多内容。 您会注意到我的ecx(7fbee3bf)的第30位设置为1级,因此我可以使用RDRND指令。

实际上可以通过该指令提取更多信息。 在调用cpuid时,eax的扩展信息设置了最高位。 当你调用cpuid时,许多级别也有不同的“叶子”,具体取决于ecx的值。 无聊的人可能花一两天的时间编写一些东西来完成所有的特征提取并使它看起来很漂亮。 或者,可以执行“grep flags / proc / cpuinfo”并获得如下内容:

标志:fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm epb tpr_shadow vnmi flexpriority ept vpid fsgsbase smep erms xsaveopt dtherm ida arat pln pts