xref: /aosp_15_r20/external/libyuv/unit_test/cpu_test.cc (revision 4e366538070a3a6c5c163c31b791eab742e1657a)
1*4e366538SXin Li /*
2*4e366538SXin Li  *  Copyright 2012 The LibYuv Project Authors. All rights reserved.
3*4e366538SXin Li  *
4*4e366538SXin Li  *  Use of this source code is governed by a BSD-style license
5*4e366538SXin Li  *  that can be found in the LICENSE file in the root of the source
6*4e366538SXin Li  *  tree. An additional intellectual property rights grant can be found
7*4e366538SXin Li  *  in the file PATENTS. All contributing project authors may
8*4e366538SXin Li  *  be found in the AUTHORS file in the root of the source tree.
9*4e366538SXin Li  */
10*4e366538SXin Li 
11*4e366538SXin Li #include <stdlib.h>
12*4e366538SXin Li #include <string.h>
13*4e366538SXin Li 
14*4e366538SXin Li #include "../unit_test/unit_test.h"
15*4e366538SXin Li #include "libyuv/basic_types.h"
16*4e366538SXin Li #include "libyuv/cpu_id.h"
17*4e366538SXin Li #include "libyuv/version.h"
18*4e366538SXin Li 
19*4e366538SXin Li namespace libyuv {
20*4e366538SXin Li 
TEST_F(LibYUVBaseTest,TestCpuHas)21*4e366538SXin Li TEST_F(LibYUVBaseTest, TestCpuHas) {
22*4e366538SXin Li   int cpu_flags = TestCpuFlag(-1);
23*4e366538SXin Li   printf("Cpu Flags 0x%x\n", cpu_flags);
24*4e366538SXin Li #if defined(__arm__) || defined(__aarch64__)
25*4e366538SXin Li   int has_arm = TestCpuFlag(kCpuHasARM);
26*4e366538SXin Li   printf("Has ARM 0x%x\n", has_arm);
27*4e366538SXin Li   int has_neon = TestCpuFlag(kCpuHasNEON);
28*4e366538SXin Li   printf("Has NEON 0x%x\n", has_neon);
29*4e366538SXin Li #endif
30*4e366538SXin Li #if defined(__riscv) && defined(__linux__)
31*4e366538SXin Li   int has_riscv = TestCpuFlag(kCpuHasRISCV);
32*4e366538SXin Li   printf("Has RISCV 0x%x\n", has_riscv);
33*4e366538SXin Li   int has_rvv = TestCpuFlag(kCpuHasRVV);
34*4e366538SXin Li   printf("Has RVV 0x%x\n", has_rvv);
35*4e366538SXin Li   int has_rvvzvfh = TestCpuFlag(kCpuHasRVVZVFH);
36*4e366538SXin Li   printf("Has RVVZVFH 0x%x\n", has_rvvzvfh);
37*4e366538SXin Li #endif
38*4e366538SXin Li #if defined(__i386__) || defined(__x86_64__) || defined(_M_IX86) || \
39*4e366538SXin Li     defined(_M_X64)
40*4e366538SXin Li   int has_x86 = TestCpuFlag(kCpuHasX86);
41*4e366538SXin Li   int has_sse2 = TestCpuFlag(kCpuHasSSE2);
42*4e366538SXin Li   int has_ssse3 = TestCpuFlag(kCpuHasSSSE3);
43*4e366538SXin Li   int has_sse41 = TestCpuFlag(kCpuHasSSE41);
44*4e366538SXin Li   int has_sse42 = TestCpuFlag(kCpuHasSSE42);
45*4e366538SXin Li   int has_avx = TestCpuFlag(kCpuHasAVX);
46*4e366538SXin Li   int has_avx2 = TestCpuFlag(kCpuHasAVX2);
47*4e366538SXin Li   int has_erms = TestCpuFlag(kCpuHasERMS);
48*4e366538SXin Li   int has_fma3 = TestCpuFlag(kCpuHasFMA3);
49*4e366538SXin Li   int has_f16c = TestCpuFlag(kCpuHasF16C);
50*4e366538SXin Li   int has_avx512bw = TestCpuFlag(kCpuHasAVX512BW);
51*4e366538SXin Li   int has_avx512vl = TestCpuFlag(kCpuHasAVX512VL);
52*4e366538SXin Li   int has_avx512vnni = TestCpuFlag(kCpuHasAVX512VNNI);
53*4e366538SXin Li   int has_avx512vbmi = TestCpuFlag(kCpuHasAVX512VBMI);
54*4e366538SXin Li   int has_avx512vbmi2 = TestCpuFlag(kCpuHasAVX512VBMI2);
55*4e366538SXin Li   int has_avx512vbitalg = TestCpuFlag(kCpuHasAVX512VBITALG);
56*4e366538SXin Li   int has_avx10 = TestCpuFlag(kCpuHasAVX10);
57*4e366538SXin Li   int has_avxvnni = TestCpuFlag(kCpuHasAVXVNNI);
58*4e366538SXin Li   int has_avxvnniint8 = TestCpuFlag(kCpuHasAVXVNNIINT8);
59*4e366538SXin Li   printf("Has X86 0x%x\n", has_x86);
60*4e366538SXin Li   printf("Has SSE2 0x%x\n", has_sse2);
61*4e366538SXin Li   printf("Has SSSE3 0x%x\n", has_ssse3);
62*4e366538SXin Li   printf("Has SSE41 0x%x\n", has_sse41);
63*4e366538SXin Li   printf("Has SSE42 0x%x\n", has_sse42);
64*4e366538SXin Li   printf("Has AVX 0x%x\n", has_avx);
65*4e366538SXin Li   printf("Has AVX2 0x%x\n", has_avx2);
66*4e366538SXin Li   printf("Has ERMS 0x%x\n", has_erms);
67*4e366538SXin Li   printf("Has FMA3 0x%x\n", has_fma3);
68*4e366538SXin Li   printf("Has F16C 0x%x\n", has_f16c);
69*4e366538SXin Li   printf("Has AVX512BW 0x%x\n", has_avx512bw);
70*4e366538SXin Li   printf("Has AVX512VL 0x%x\n", has_avx512vl);
71*4e366538SXin Li   printf("Has AVX512VNNI 0x%x\n", has_avx512vnni);
72*4e366538SXin Li   printf("Has AVX512VBMI 0x%x\n", has_avx512vbmi);
73*4e366538SXin Li   printf("Has AVX512VBMI2 0x%x\n", has_avx512vbmi2);
74*4e366538SXin Li   printf("Has AVX512VBITALG 0x%x\n", has_avx512vbitalg);
75*4e366538SXin Li   printf("Has AVX10 0x%x\n", has_avx10);
76*4e366538SXin Li   printf("HAS AVXVNNI 0x%x\n", has_avxvnni);
77*4e366538SXin Li   printf("Has AVXVNNIINT8 0x%x\n", has_avxvnniint8);
78*4e366538SXin Li #endif
79*4e366538SXin Li #if defined(__mips__)
80*4e366538SXin Li   int has_mips = TestCpuFlag(kCpuHasMIPS);
81*4e366538SXin Li   printf("Has MIPS 0x%x\n", has_mips);
82*4e366538SXin Li   int has_msa = TestCpuFlag(kCpuHasMSA);
83*4e366538SXin Li   printf("Has MSA 0x%x\n", has_msa);
84*4e366538SXin Li #endif
85*4e366538SXin Li #if defined(__loongarch__)
86*4e366538SXin Li   int has_loongarch = TestCpuFlag(kCpuHasLOONGARCH);
87*4e366538SXin Li   printf("Has LOONGARCH 0x%x\n", has_loongarch);
88*4e366538SXin Li   int has_lsx = TestCpuFlag(kCpuHasLSX);
89*4e366538SXin Li   printf("Has LSX 0x%x\n", has_lsx);
90*4e366538SXin Li   int has_lasx = TestCpuFlag(kCpuHasLASX);
91*4e366538SXin Li   printf("Has LASX 0x%x\n", has_lasx);
92*4e366538SXin Li #endif
93*4e366538SXin Li }
94*4e366538SXin Li 
TEST_F(LibYUVBaseTest,TestCompilerMacros)95*4e366538SXin Li TEST_F(LibYUVBaseTest, TestCompilerMacros) {
96*4e366538SXin Li   // Tests all macros used in public headers.
97*4e366538SXin Li #ifdef __ATOMIC_RELAXED
98*4e366538SXin Li   printf("__ATOMIC_RELAXED %d\n", __ATOMIC_RELAXED);
99*4e366538SXin Li #endif
100*4e366538SXin Li #ifdef __cplusplus
101*4e366538SXin Li   printf("__cplusplus %ld\n", __cplusplus);
102*4e366538SXin Li #endif
103*4e366538SXin Li #ifdef __clang_major__
104*4e366538SXin Li   printf("__clang_major__ %d\n", __clang_major__);
105*4e366538SXin Li #endif
106*4e366538SXin Li #ifdef __clang_minor__
107*4e366538SXin Li   printf("__clang_minor__ %d\n", __clang_minor__);
108*4e366538SXin Li #endif
109*4e366538SXin Li #ifdef __GNUC__
110*4e366538SXin Li   printf("__GNUC__ %d\n", __GNUC__);
111*4e366538SXin Li #endif
112*4e366538SXin Li #ifdef __GNUC_MINOR__
113*4e366538SXin Li   printf("__GNUC_MINOR__ %d\n", __GNUC_MINOR__);
114*4e366538SXin Li #endif
115*4e366538SXin Li #ifdef __i386__
116*4e366538SXin Li   printf("__i386__ %d\n", __i386__);
117*4e366538SXin Li #endif
118*4e366538SXin Li #ifdef __x86_64__
119*4e366538SXin Li   printf("__x86_64__ %d\n", __x86_64__);
120*4e366538SXin Li #endif
121*4e366538SXin Li #ifdef _M_IX86
122*4e366538SXin Li   printf("_M_IX86 %d\n", _M_IX86);
123*4e366538SXin Li #endif
124*4e366538SXin Li #ifdef _M_X64
125*4e366538SXin Li   printf("_M_X64 %d\n", _M_X64);
126*4e366538SXin Li #endif
127*4e366538SXin Li #ifdef _MSC_VER
128*4e366538SXin Li   printf("_MSC_VER %d\n", _MSC_VER);
129*4e366538SXin Li #endif
130*4e366538SXin Li #ifdef __aarch64__
131*4e366538SXin Li   printf("__aarch64__ %d\n", __aarch64__);
132*4e366538SXin Li #endif
133*4e366538SXin Li #ifdef __arm__
134*4e366538SXin Li   printf("__arm__ %d\n", __arm__);
135*4e366538SXin Li #endif
136*4e366538SXin Li #ifdef __riscv
137*4e366538SXin Li   printf("__riscv %d\n", __riscv);
138*4e366538SXin Li #endif
139*4e366538SXin Li #ifdef __riscv_vector
140*4e366538SXin Li   printf("__riscv_vector %d\n", __riscv_vector);
141*4e366538SXin Li #endif
142*4e366538SXin Li #ifdef __riscv_v_intrinsic
143*4e366538SXin Li   printf("__riscv_v_intrinsic %d\n", __riscv_v_intrinsic);
144*4e366538SXin Li #endif
145*4e366538SXin Li #ifdef __APPLE__
146*4e366538SXin Li   printf("__APPLE__ %d\n", __APPLE__);
147*4e366538SXin Li #endif
148*4e366538SXin Li #ifdef __clang__
149*4e366538SXin Li   printf("__clang__ %d\n", __clang__);
150*4e366538SXin Li #endif
151*4e366538SXin Li #ifdef __CLR_VER
152*4e366538SXin Li   printf("__CLR_VER %d\n", __CLR_VER);
153*4e366538SXin Li #endif
154*4e366538SXin Li #ifdef __CYGWIN__
155*4e366538SXin Li   printf("__CYGWIN__ %d\n", __CYGWIN__);
156*4e366538SXin Li #endif
157*4e366538SXin Li #ifdef __llvm__
158*4e366538SXin Li   printf("__llvm__ %d\n", __llvm__);
159*4e366538SXin Li #endif
160*4e366538SXin Li #ifdef __mips_msa
161*4e366538SXin Li   printf("__mips_msa %d\n", __mips_msa);
162*4e366538SXin Li #endif
163*4e366538SXin Li #ifdef __mips
164*4e366538SXin Li   printf("__mips %d\n", __mips);
165*4e366538SXin Li #endif
166*4e366538SXin Li #ifdef __mips_isa_rev
167*4e366538SXin Li   printf("__mips_isa_rev %d\n", __mips_isa_rev);
168*4e366538SXin Li #endif
169*4e366538SXin Li #ifdef _MIPS_ARCH_LOONGSON3A
170*4e366538SXin Li   printf("_MIPS_ARCH_LOONGSON3A %d\n", _MIPS_ARCH_LOONGSON3A);
171*4e366538SXin Li #endif
172*4e366538SXin Li #ifdef __loongarch__
173*4e366538SXin Li   printf("__loongarch__ %d\n", __loongarch__);
174*4e366538SXin Li #endif
175*4e366538SXin Li #ifdef _WIN32
176*4e366538SXin Li   printf("_WIN32 %d\n", _WIN32);
177*4e366538SXin Li #endif
178*4e366538SXin Li #ifdef __native_client__
179*4e366538SXin Li   printf("__native_client__ %d\n", __native_client__);
180*4e366538SXin Li #endif
181*4e366538SXin Li #ifdef __pic__
182*4e366538SXin Li   printf("__pic__ %d\n", __pic__);
183*4e366538SXin Li #endif
184*4e366538SXin Li #ifdef __pnacl__
185*4e366538SXin Li   printf("__pnacl__ %d\n", __pnacl__);
186*4e366538SXin Li #endif
187*4e366538SXin Li #ifdef GG_LONGLONG
188*4e366538SXin Li   printf("GG_LONGLONG %lld\n", GG_LONGLONG(1));
189*4e366538SXin Li #endif
190*4e366538SXin Li #ifdef INT_TYPES_DEFINED
191*4e366538SXin Li   printf("INT_TYPES_DEFINED\n");
192*4e366538SXin Li #endif
193*4e366538SXin Li #ifdef __has_feature
194*4e366538SXin Li   printf("__has_feature\n");
195*4e366538SXin Li #if __has_feature(memory_sanitizer)
196*4e366538SXin Li   printf("__has_feature(memory_sanitizer) %d\n",
197*4e366538SXin Li          __has_feature(memory_sanitizer));
198*4e366538SXin Li #endif
199*4e366538SXin Li #endif
200*4e366538SXin Li }
201*4e366538SXin Li 
202*4e366538SXin Li #if defined(__i386__) || defined(__x86_64__) || defined(_M_IX86) || \
203*4e366538SXin Li     defined(_M_X64)
TEST_F(LibYUVBaseTest,TestCpuId)204*4e366538SXin Li TEST_F(LibYUVBaseTest, TestCpuId) {
205*4e366538SXin Li   int has_x86 = TestCpuFlag(kCpuHasX86);
206*4e366538SXin Li   if (has_x86) {
207*4e366538SXin Li     int cpu_info[4];
208*4e366538SXin Li     // Vendor ID:
209*4e366538SXin Li     // AuthenticAMD AMD processor
210*4e366538SXin Li     // CentaurHauls Centaur processor
211*4e366538SXin Li     // CyrixInstead Cyrix processor
212*4e366538SXin Li     // GenuineIntel Intel processor
213*4e366538SXin Li     // GenuineTMx86 Transmeta processor
214*4e366538SXin Li     // Geode by NSC National Semiconductor processor
215*4e366538SXin Li     // NexGenDriven NexGen processor
216*4e366538SXin Li     // RiseRiseRise Rise Technology processor
217*4e366538SXin Li     // SiS SiS SiS  SiS processor
218*4e366538SXin Li     // UMC UMC UMC  UMC processor
219*4e366538SXin Li     CpuId(0, 0, cpu_info);
220*4e366538SXin Li     cpu_info[0] = cpu_info[1];  // Reorder output
221*4e366538SXin Li     cpu_info[1] = cpu_info[3];
222*4e366538SXin Li     cpu_info[3] = 0;
223*4e366538SXin Li     printf("Cpu Vendor: %s 0x%x 0x%x 0x%x\n",
224*4e366538SXin Li            reinterpret_cast<char*>(&cpu_info[0]), cpu_info[0], cpu_info[1],
225*4e366538SXin Li            cpu_info[2]);
226*4e366538SXin Li     EXPECT_EQ(12u, strlen(reinterpret_cast<char*>(&cpu_info[0])));
227*4e366538SXin Li 
228*4e366538SXin Li     // CPU Family and Model
229*4e366538SXin Li     // 3:0 - Stepping
230*4e366538SXin Li     // 7:4 - Model
231*4e366538SXin Li     // 11:8 - Family
232*4e366538SXin Li     // 13:12 - Processor Type
233*4e366538SXin Li     // 19:16 - Extended Model
234*4e366538SXin Li     // 27:20 - Extended Family
235*4e366538SXin Li     CpuId(1, 0, cpu_info);
236*4e366538SXin Li     int family = ((cpu_info[0] >> 8) & 0x0f) | ((cpu_info[0] >> 16) & 0xff0);
237*4e366538SXin Li     int model = ((cpu_info[0] >> 4) & 0x0f) | ((cpu_info[0] >> 12) & 0xf0);
238*4e366538SXin Li     printf("Cpu Family %d (0x%x), Model %d (0x%x)\n", family, family, model,
239*4e366538SXin Li            model);
240*4e366538SXin Li   }
241*4e366538SXin Li }
242*4e366538SXin Li #endif
243*4e366538SXin Li 
FileExists(const char * file_name)244*4e366538SXin Li static int FileExists(const char* file_name) {
245*4e366538SXin Li   FILE* f = fopen(file_name, "r");
246*4e366538SXin Li   if (!f) {
247*4e366538SXin Li     return 0;
248*4e366538SXin Li   }
249*4e366538SXin Li   fclose(f);
250*4e366538SXin Li   return 1;
251*4e366538SXin Li }
252*4e366538SXin Li 
TEST_F(LibYUVBaseTest,TestLinuxNeon)253*4e366538SXin Li TEST_F(LibYUVBaseTest, TestLinuxNeon) {
254*4e366538SXin Li   if (FileExists("../../unit_test/testdata/arm_v7.txt")) {
255*4e366538SXin Li     printf("Note: testing to load \"../../unit_test/testdata/arm_v7.txt\"\n");
256*4e366538SXin Li 
257*4e366538SXin Li     EXPECT_EQ(0, ArmCpuCaps("../../unit_test/testdata/arm_v7.txt"));
258*4e366538SXin Li     EXPECT_EQ(kCpuHasNEON, ArmCpuCaps("../../unit_test/testdata/tegra3.txt"));
259*4e366538SXin Li     EXPECT_EQ(kCpuHasNEON, ArmCpuCaps("../../unit_test/testdata/juno.txt"));
260*4e366538SXin Li   } else {
261*4e366538SXin Li     printf("WARNING: unable to load \"../../unit_test/testdata/arm_v7.txt\"\n");
262*4e366538SXin Li   }
263*4e366538SXin Li #if defined(__linux__) && defined(__ARM_NEON__)
264*4e366538SXin Li   if (FileExists("/proc/cpuinfo")) {
265*4e366538SXin Li     if (kCpuHasNEON != ArmCpuCaps("/proc/cpuinfo")) {
266*4e366538SXin Li       // This can happen on ARM emulator but /proc/cpuinfo is from host.
267*4e366538SXin Li       printf("WARNING: Neon build enabled but CPU does not have NEON\n");
268*4e366538SXin Li     }
269*4e366538SXin Li   } else {
270*4e366538SXin Li     printf("WARNING: unable to load \"/proc/cpuinfo\"\n");
271*4e366538SXin Li   }
272*4e366538SXin Li #endif
273*4e366538SXin Li }
274*4e366538SXin Li 
TEST_F(LibYUVBaseTest,TestLinuxMipsMsa)275*4e366538SXin Li TEST_F(LibYUVBaseTest, TestLinuxMipsMsa) {
276*4e366538SXin Li   if (FileExists("../../unit_test/testdata/mips.txt")) {
277*4e366538SXin Li     printf("Note: testing to load \"../../unit_test/testdata/mips.txt\"\n");
278*4e366538SXin Li 
279*4e366538SXin Li     EXPECT_EQ(0, MipsCpuCaps("../../unit_test/testdata/mips.txt"));
280*4e366538SXin Li     EXPECT_EQ(kCpuHasMSA, MipsCpuCaps("../../unit_test/testdata/mips_msa.txt"));
281*4e366538SXin Li     EXPECT_EQ(kCpuHasMSA,
282*4e366538SXin Li               MipsCpuCaps("../../unit_test/testdata/mips_loongson2k.txt"));
283*4e366538SXin Li   } else {
284*4e366538SXin Li     printf("WARNING: unable to load \"../../unit_test/testdata/mips.txt\"\n");
285*4e366538SXin Li   }
286*4e366538SXin Li }
287*4e366538SXin Li 
TEST_F(LibYUVBaseTest,TestLinuxRVV)288*4e366538SXin Li TEST_F(LibYUVBaseTest, TestLinuxRVV) {
289*4e366538SXin Li   if (FileExists("../../unit_test/testdata/riscv64.txt")) {
290*4e366538SXin Li     printf("Note: testing to load \"../../unit_test/testdata/riscv64.txt\"\n");
291*4e366538SXin Li 
292*4e366538SXin Li     EXPECT_EQ(0, RiscvCpuCaps("../../unit_test/testdata/riscv64.txt"));
293*4e366538SXin Li     EXPECT_EQ(kCpuHasRVV,
294*4e366538SXin Li               RiscvCpuCaps("../../unit_test/testdata/riscv64_rvv.txt"));
295*4e366538SXin Li     EXPECT_EQ(kCpuHasRVV | kCpuHasRVVZVFH,
296*4e366538SXin Li               RiscvCpuCaps("../../unit_test/testdata/riscv64_rvv_zvfh.txt"));
297*4e366538SXin Li   } else {
298*4e366538SXin Li     printf(
299*4e366538SXin Li         "WARNING: unable to load "
300*4e366538SXin Li         "\"../../unit_test/testdata/riscv64.txt\"\n");
301*4e366538SXin Li   }
302*4e366538SXin Li #if defined(__linux__) && defined(__riscv)
303*4e366538SXin Li   if (FileExists("/proc/cpuinfo")) {
304*4e366538SXin Li     if (!(kCpuHasRVV & RiscvCpuCaps("/proc/cpuinfo"))) {
305*4e366538SXin Li       // This can happen on RVV emulator but /proc/cpuinfo is from host.
306*4e366538SXin Li       printf("WARNING: RVV build enabled but CPU does not have RVV\n");
307*4e366538SXin Li     }
308*4e366538SXin Li   } else {
309*4e366538SXin Li     printf("WARNING: unable to load \"/proc/cpuinfo\"\n");
310*4e366538SXin Li   }
311*4e366538SXin Li #endif
312*4e366538SXin Li }
313*4e366538SXin Li 
314*4e366538SXin Li // TODO(fbarchard): Fix clangcl test of cpuflags.
315*4e366538SXin Li #ifdef _MSC_VER
TEST_F(LibYUVBaseTest,DISABLED_TestSetCpuFlags)316*4e366538SXin Li TEST_F(LibYUVBaseTest, DISABLED_TestSetCpuFlags) {
317*4e366538SXin Li #else
318*4e366538SXin Li TEST_F(LibYUVBaseTest, TestSetCpuFlags) {
319*4e366538SXin Li #endif
320*4e366538SXin Li   // Reset any masked flags that may have been set so auto init is enabled.
321*4e366538SXin Li   MaskCpuFlags(0);
322*4e366538SXin Li 
323*4e366538SXin Li   int original_cpu_flags = TestCpuFlag(-1);
324*4e366538SXin Li 
325*4e366538SXin Li   // Test setting different CPU configurations.
326*4e366538SXin Li   int cpu_flags = kCpuHasARM | kCpuHasNEON | kCpuInitialized;
327*4e366538SXin Li   SetCpuFlags(cpu_flags);
328*4e366538SXin Li   EXPECT_EQ(cpu_flags, TestCpuFlag(-1));
329*4e366538SXin Li 
330*4e366538SXin Li   cpu_flags = kCpuHasX86 | kCpuInitialized;
331*4e366538SXin Li   SetCpuFlags(cpu_flags);
332*4e366538SXin Li   EXPECT_EQ(cpu_flags, TestCpuFlag(-1));
333*4e366538SXin Li 
334*4e366538SXin Li   // Test that setting 0 turns auto-init back on.
335*4e366538SXin Li   SetCpuFlags(0);
336*4e366538SXin Li   EXPECT_EQ(original_cpu_flags, TestCpuFlag(-1));
337*4e366538SXin Li 
338*4e366538SXin Li   // Restore the CPU flag mask.
339*4e366538SXin Li   MaskCpuFlags(benchmark_cpu_info_);
340*4e366538SXin Li }
341*4e366538SXin Li 
342*4e366538SXin Li }  // namespace libyuv
343