1 #include <stdio.h>
2 #include <stdlib.h>
3
4 #include <cpuinfo.h>
5
main(int argc,char ** argv)6 int main(int argc, char** argv) {
7 if (!cpuinfo_initialize()) {
8 fprintf(stderr, "failed to initialize CPU information\n");
9 exit(EXIT_FAILURE);
10 }
11
12 #if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
13
14 printf("Scalar instructions:\n");
15 #if CPUINFO_ARCH_X86
16 printf("\tx87 FPU: %s\n", cpuinfo_has_x86_fpu() ? "yes" : "no");
17 printf("\tCMOV: %s\n", cpuinfo_has_x86_cmov() ? "yes" : "no");
18 #endif
19 printf("\tLAHF/SAHF: %s\n", cpuinfo_has_x86_lahf_sahf() ? "yes" : "no");
20 printf("\tLZCNT: %s\n", cpuinfo_has_x86_lzcnt() ? "yes" : "no");
21 printf("\tPOPCNT: %s\n", cpuinfo_has_x86_popcnt() ? "yes" : "no");
22 printf("\tTBM: %s\n", cpuinfo_has_x86_tbm() ? "yes" : "no");
23 printf("\tBMI: %s\n", cpuinfo_has_x86_bmi() ? "yes" : "no");
24 printf("\tBMI2: %s\n", cpuinfo_has_x86_bmi2() ? "yes" : "no");
25 printf("\tADCX/ADOX: %s\n", cpuinfo_has_x86_adx() ? "yes" : "no");
26
27
28 printf("Memory instructions:\n");
29 printf("\tMOVBE: %s\n", cpuinfo_has_x86_movbe() ? "yes" : "no");
30 printf("\tPREFETCH: %s\n", cpuinfo_has_x86_prefetch() ? "yes" : "no");
31 printf("\tPREFETCHW: %s\n", cpuinfo_has_x86_prefetchw() ? "yes" : "no");
32 printf("\tPREFETCHWT1: %s\n", cpuinfo_has_x86_prefetchwt1() ? "yes" : "no");
33 printf("\tCLZERO: %s\n", cpuinfo_has_x86_clzero() ? "yes" : "no");
34
35
36 printf("SIMD extensions:\n");
37 printf("\tMMX: %s\n", cpuinfo_has_x86_mmx() ? "yes" : "no");
38 printf("\tMMX+: %s\n", cpuinfo_has_x86_mmx_plus() ? "yes" : "no");
39 printf("\t3dnow!: %s\n", cpuinfo_has_x86_3dnow() ? "yes" : "no");
40 printf("\t3dnow!+: %s\n", cpuinfo_has_x86_3dnow_plus() ? "yes" : "no");
41 printf("\t3dnow! Geode: %s\n", cpuinfo_has_x86_3dnow_geode() ? "yes" : "no");
42 printf("\tDAZ: %s\n", cpuinfo_has_x86_daz() ? "yes" : "no");
43 printf("\tSSE: %s\n", cpuinfo_has_x86_sse() ? "yes" : "no");
44 printf("\tSSE2: %s\n", cpuinfo_has_x86_sse2() ? "yes" : "no");
45 printf("\tSSE3: %s\n", cpuinfo_has_x86_sse3() ? "yes" : "no");
46 printf("\tSSSE3: %s\n", cpuinfo_has_x86_ssse3() ? "yes" : "no");
47 printf("\tSSE4.1: %s\n", cpuinfo_has_x86_sse4_1() ? "yes" : "no");
48 printf("\tSSE4.2: %s\n", cpuinfo_has_x86_sse4_2() ? "yes" : "no");
49 printf("\tSSE4a: %s\n", cpuinfo_has_x86_sse4a() ? "yes" : "no");
50 printf("\tMisaligned SSE: %s\n", cpuinfo_has_x86_misaligned_sse() ? "yes" : "no");
51 printf("\tAVX: %s\n", cpuinfo_has_x86_avx() ? "yes" : "no");
52 printf("\tFMA3: %s\n", cpuinfo_has_x86_fma3() ? "yes" : "no");
53 printf("\tFMA4: %s\n", cpuinfo_has_x86_fma4() ? "yes" : "no");
54 printf("\tXOP: %s\n", cpuinfo_has_x86_xop() ? "yes" : "no");
55 printf("\tF16C: %s\n", cpuinfo_has_x86_f16c() ? "yes" : "no");
56 printf("\tAVX2: %s\n", cpuinfo_has_x86_avx2() ? "yes" : "no");
57 printf("\tAVX512F: %s\n", cpuinfo_has_x86_avx512f() ? "yes" : "no");
58 printf("\tAVX512PF: %s\n", cpuinfo_has_x86_avx512pf() ? "yes" : "no");
59 printf("\tAVX512ER: %s\n", cpuinfo_has_x86_avx512er() ? "yes" : "no");
60 printf("\tAVX512CD: %s\n", cpuinfo_has_x86_avx512cd() ? "yes" : "no");
61 printf("\tAVX512DQ: %s\n", cpuinfo_has_x86_avx512dq() ? "yes" : "no");
62 printf("\tAVX512BW: %s\n", cpuinfo_has_x86_avx512bw() ? "yes" : "no");
63 printf("\tAVX512VL: %s\n", cpuinfo_has_x86_avx512vl() ? "yes" : "no");
64 printf("\tAVX512IFMA: %s\n", cpuinfo_has_x86_avx512ifma() ? "yes" : "no");
65 printf("\tAVX512VBMI: %s\n", cpuinfo_has_x86_avx512vbmi() ? "yes" : "no");
66 printf("\tAVX512VBMI2: %s\n", cpuinfo_has_x86_avx512vbmi2() ? "yes" : "no");
67 printf("\tAVX512BITALG: %s\n", cpuinfo_has_x86_avx512bitalg() ? "yes" : "no");
68 printf("\tAVX512VPOPCNTDQ: %s\n", cpuinfo_has_x86_avx512vpopcntdq() ? "yes" : "no");
69 printf("\tAVX512VNNI: %s\n", cpuinfo_has_x86_avx512vnni() ? "yes" : "no");
70 printf("\tAVX512BF16: %s\n", cpuinfo_has_x86_avx512bf16() ? "yes" : "no");
71 printf("\tAVX512VP2INTERSECT: %s\n", cpuinfo_has_x86_avx512vp2intersect() ? "yes" : "no");
72 printf("\tAVX512_4VNNIW: %s\n", cpuinfo_has_x86_avx512_4vnniw() ? "yes" : "no");
73 printf("\tAVX512_4FMAPS: %s\n", cpuinfo_has_x86_avx512_4fmaps() ? "yes" : "no");
74
75
76 printf("Multi-threading extensions:\n");
77 printf("\tMONITOR/MWAIT: %s\n", cpuinfo_has_x86_mwait() ? "yes" : "no");
78 printf("\tMONITORX/MWAITX: %s\n", cpuinfo_has_x86_mwaitx() ? "yes" : "no");
79 #if CPUINFO_ARCH_X86
80 printf("\tCMPXCHG8B: %s\n", cpuinfo_has_x86_cmpxchg8b() ? "yes" : "no");
81 #endif
82 printf("\tCMPXCHG16B: %s\n", cpuinfo_has_x86_cmpxchg16b() ? "yes" : "no");
83 printf("\tHLE: %s\n", cpuinfo_has_x86_hle() ? "yes" : "no");
84 printf("\tRTM: %s\n", cpuinfo_has_x86_rtm() ? "yes" : "no");
85 printf("\tXTEST: %s\n", cpuinfo_has_x86_xtest() ? "yes" : "no");
86 printf("\tRDPID: %s\n", cpuinfo_has_x86_rdpid() ? "yes" : "no");
87
88
89 printf("Cryptography extensions:\n");
90 printf("\tAES: %s\n", cpuinfo_has_x86_aes() ? "yes" : "no");
91 printf("\tVAES: %s\n", cpuinfo_has_x86_vaes() ? "yes" : "no");
92 printf("\tPCLMULQDQ: %s\n", cpuinfo_has_x86_pclmulqdq() ? "yes" : "no");
93 printf("\tVPCLMULQDQ: %s\n", cpuinfo_has_x86_vpclmulqdq() ? "yes" : "no");
94 printf("\tGFNI: %s\n", cpuinfo_has_x86_gfni() ? "yes" : "no");
95 printf("\tRDRAND: %s\n", cpuinfo_has_x86_rdrand() ? "yes" : "no");
96 printf("\tRDSEED: %s\n", cpuinfo_has_x86_rdseed() ? "yes" : "no");
97 printf("\tSHA: %s\n", cpuinfo_has_x86_sha() ? "yes" : "no");
98
99
100 printf("Profiling instructions:\n");
101 #if CPUINFO_ARCH_X86
102 printf("\tRDTSC: %s\n", cpuinfo_has_x86_rdtsc() ? "yes" : "no");
103 #endif
104 printf("\tRDTSCP: %s\n", cpuinfo_has_x86_rdtscp() ? "yes" : "no");
105 printf("\tMPX: %s\n", cpuinfo_has_x86_mpx() ? "yes" : "no");
106
107
108 printf("System instructions:\n");
109 printf("\tCLWB: %s\n", cpuinfo_has_x86_clwb() ? "yes" : "no");
110 printf("\tFXSAVE/FXSTOR: %s\n", cpuinfo_has_x86_fxsave() ? "yes" : "no");
111 printf("\tXSAVE/XSTOR: %s\n", cpuinfo_has_x86_xsave() ? "yes" : "no");
112
113 #endif /* CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64 */
114
115 #if CPUINFO_ARCH_ARM
116 printf("Instruction sets:\n");
117 printf("\tThumb: %s\n", cpuinfo_has_arm_thumb() ? "yes" : "no");
118 printf("\tThumb 2: %s\n", cpuinfo_has_arm_thumb2() ? "yes" : "no");
119 printf("\tARMv5E: %s\n", cpuinfo_has_arm_v5e() ? "yes" : "no");
120 printf("\tARMv6: %s\n", cpuinfo_has_arm_v6() ? "yes" : "no");
121 printf("\tARMv6-K: %s\n", cpuinfo_has_arm_v6k() ? "yes" : "no");
122 printf("\tARMv7: %s\n", cpuinfo_has_arm_v7() ? "yes" : "no");
123 printf("\tARMv7 MP: %s\n", cpuinfo_has_arm_v7mp() ? "yes" : "no");
124 printf("\tARMv8: %s\n", cpuinfo_has_arm_v8() ? "yes" : "no");
125 printf("\tIDIV: %s\n", cpuinfo_has_arm_idiv() ? "yes" : "no");
126
127 printf("Floating-Point support:\n");
128 printf("\tVFPv2: %s\n", cpuinfo_has_arm_vfpv2() ? "yes" : "no");
129 printf("\tVFPv3: %s\n", cpuinfo_has_arm_vfpv3() ? "yes" : "no");
130 printf("\tVFPv3+D32: %s\n", cpuinfo_has_arm_vfpv3_d32() ? "yes" : "no");
131 printf("\tVFPv3+FP16: %s\n", cpuinfo_has_arm_vfpv3_fp16() ? "yes" : "no");
132 printf("\tVFPv3+FP16+D32: %s\n", cpuinfo_has_arm_vfpv3_fp16_d32() ? "yes" : "no");
133 printf("\tVFPv4: %s\n", cpuinfo_has_arm_vfpv4() ? "yes" : "no");
134 printf("\tVFPv4+D32: %s\n", cpuinfo_has_arm_vfpv4_d32() ? "yes" : "no");
135 printf("\tVJCVT: %s\n", cpuinfo_has_arm_jscvt() ? "yes" : "no");
136
137 printf("SIMD extensions:\n");
138 printf("\tWMMX: %s\n", cpuinfo_has_arm_wmmx() ? "yes" : "no");
139 printf("\tWMMX 2: %s\n", cpuinfo_has_arm_wmmx2() ? "yes" : "no");
140 printf("\tNEON: %s\n", cpuinfo_has_arm_neon() ? "yes" : "no");
141 printf("\tNEON-FP16: %s\n", cpuinfo_has_arm_neon_fp16() ? "yes" : "no");
142 printf("\tNEON-FMA: %s\n", cpuinfo_has_arm_neon_fma() ? "yes" : "no");
143 printf("\tNEON VQRDMLAH/VQRDMLSH: %s\n", cpuinfo_has_arm_neon_rdm() ? "yes" : "no");
144 printf("\tNEON FP16 arithmetics: %s\n", cpuinfo_has_arm_neon_fp16_arith() ? "yes" : "no");
145 printf("\tNEON complex: %s\n", cpuinfo_has_arm_fcma() ? "yes" : "no");
146 printf("\tNEON VSDOT/VUDOT: %s\n", cpuinfo_has_arm_neon_dot() ? "yes" : "no");
147 printf("\tNEON VFMLAL/VFMLSL: %s\n", cpuinfo_has_arm_fhm() ? "yes" : "no");
148
149 printf("Cryptography extensions:\n");
150 printf("\tAES: %s\n", cpuinfo_has_arm_aes() ? "yes" : "no");
151 printf("\tSHA1: %s\n", cpuinfo_has_arm_sha1() ? "yes" : "no");
152 printf("\tSHA2: %s\n", cpuinfo_has_arm_sha2() ? "yes" : "no");
153 printf("\tPMULL: %s\n", cpuinfo_has_arm_pmull() ? "yes" : "no");
154 printf("\tCRC32: %s\n", cpuinfo_has_arm_crc32() ? "yes" : "no");
155 #endif /* CPUINFO_ARCH_ARM */
156 #if CPUINFO_ARCH_ARM64
157 printf("Instruction sets:\n");
158 printf("\tARM v8.1 atomics: %s\n", cpuinfo_has_arm_atomics() ? "yes" : "no");
159 printf("\tARM v8.1 SQRDMLxH: %s\n", cpuinfo_has_arm_neon_rdm() ? "yes" : "no");
160 printf("\tARM v8.2 FP16 arithmetics: %s\n", cpuinfo_has_arm_fp16_arith() ? "yes" : "no");
161 printf("\tARM v8.2 FHM: %s\n", cpuinfo_has_arm_fhm() ? "yes" : "no");
162 printf("\tARM v8.2 BF16: %s\n", cpuinfo_has_arm_bf16() ? "yes" : "no");
163 printf("\tARM v8.2 Int8 dot product: %s\n", cpuinfo_has_arm_neon_dot() ? "yes" : "no");
164 printf("\tARM v8.2 Int8 matrix multiplication: %s\n", cpuinfo_has_arm_i8mm() ? "yes" : "no");
165 printf("\tARM v8.3 JS conversion: %s\n", cpuinfo_has_arm_jscvt() ? "yes" : "no");
166 printf("\tARM v8.3 complex: %s\n", cpuinfo_has_arm_fcma() ? "yes" : "no");
167
168 printf("SIMD extensions:\n");
169 printf("\tARM SVE: %s\n", cpuinfo_has_arm_sve() ? "yes" : "no");
170 printf("\tARM SVE 2: %s\n", cpuinfo_has_arm_sve2() ? "yes" : "no");
171
172 printf("Cryptography extensions:\n");
173 printf("\tAES: %s\n", cpuinfo_has_arm_aes() ? "yes" : "no");
174 printf("\tSHA1: %s\n", cpuinfo_has_arm_sha1() ? "yes" : "no");
175 printf("\tSHA2: %s\n", cpuinfo_has_arm_sha2() ? "yes" : "no");
176 printf("\tPMULL: %s\n", cpuinfo_has_arm_pmull() ? "yes" : "no");
177 printf("\tCRC32: %s\n", cpuinfo_has_arm_crc32() ? "yes" : "no");
178 #endif
179
180 }
181