Coverage Report

Created: 2026-06-10 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/cpuinfo/include/cpuinfo.h
Line
Count
Source
1
#pragma once
2
#ifndef CPUINFO_H
3
#define CPUINFO_H
4
5
#ifndef __cplusplus
6
#include <stdbool.h>
7
#endif
8
9
#ifdef __APPLE__
10
#include <TargetConditionals.h>
11
#endif
12
13
#include <stdint.h>
14
15
/* Identify architecture and define corresponding macro */
16
17
#if defined(__i386__) || defined(__i486__) || defined(__i586__) || defined(__i686__) || defined(_M_IX86)
18
#define CPUINFO_ARCH_X86 1
19
#endif
20
21
#if defined(__x86_64__) || defined(__x86_64) || defined(_M_X64) || defined(_M_AMD64)
22
#define CPUINFO_ARCH_X86_64 1
23
#endif
24
25
#if defined(__arm__) || defined(_M_ARM)
26
#define CPUINFO_ARCH_ARM 1
27
#endif
28
29
#if defined(__aarch64__) || defined(_M_ARM64)
30
#define CPUINFO_ARCH_ARM64 1
31
#endif
32
33
#if defined(__PPC64__) || defined(__powerpc64__) || defined(_ARCH_PPC64)
34
#define CPUINFO_ARCH_PPC64 1
35
#endif
36
37
#if defined(__asmjs__)
38
#define CPUINFO_ARCH_ASMJS 1
39
#endif
40
41
#if defined(__wasm__)
42
#if defined(__wasm_simd128__)
43
#define CPUINFO_ARCH_WASMSIMD 1
44
#else
45
#define CPUINFO_ARCH_WASM 1
46
#endif
47
#endif
48
49
#if defined(__riscv)
50
#if (__riscv_xlen == 32)
51
#define CPUINFO_ARCH_RISCV32 1
52
#elif (__riscv_xlen == 64)
53
#define CPUINFO_ARCH_RISCV64 1
54
#endif
55
#endif
56
57
/* Define other architecture-specific macros as 0 */
58
59
#ifndef CPUINFO_ARCH_X86
60
#define CPUINFO_ARCH_X86 0
61
#endif
62
63
#ifndef CPUINFO_ARCH_X86_64
64
#define CPUINFO_ARCH_X86_64 0
65
#endif
66
67
#ifndef CPUINFO_ARCH_ARM
68
#define CPUINFO_ARCH_ARM 0
69
#endif
70
71
#ifndef CPUINFO_ARCH_ARM64
72
#define CPUINFO_ARCH_ARM64 0
73
#endif
74
75
#ifndef CPUINFO_ARCH_PPC64
76
#define CPUINFO_ARCH_PPC64 0
77
#endif
78
79
#ifndef CPUINFO_ARCH_ASMJS
80
#define CPUINFO_ARCH_ASMJS 0
81
#endif
82
83
#ifndef CPUINFO_ARCH_WASM
84
#define CPUINFO_ARCH_WASM 0
85
#endif
86
87
#ifndef CPUINFO_ARCH_WASMSIMD
88
#define CPUINFO_ARCH_WASMSIMD 0
89
#endif
90
91
#ifndef CPUINFO_ARCH_RISCV32
92
#define CPUINFO_ARCH_RISCV32 0
93
#endif
94
95
#ifndef CPUINFO_ARCH_RISCV64
96
#define CPUINFO_ARCH_RISCV64 0
97
#endif
98
99
#if CPUINFO_ARCH_X86 && defined(_MSC_VER)
100
#define CPUINFO_ABI __cdecl
101
#elif CPUINFO_ARCH_X86 && defined(__GNUC__)
102
#define CPUINFO_ABI __attribute__((__cdecl__))
103
#else
104
#define CPUINFO_ABI
105
#endif
106
107
#define CPUINFO_CACHE_UNIFIED 0x00000001
108
#define CPUINFO_CACHE_INCLUSIVE 0x00000002
109
#define CPUINFO_CACHE_COMPLEX_INDEXING 0x00000004
110
111
struct cpuinfo_cache {
112
  /** Cache size in bytes */
113
  uint32_t size;
114
  /** Number of ways of associativity */
115
  uint32_t associativity;
116
  /** Number of sets */
117
  uint32_t sets;
118
  /** Number of partitions */
119
  uint32_t partitions;
120
  /** Line size in bytes */
121
  uint32_t line_size;
122
  /**
123
   * Binary characteristics of the cache (unified cache, inclusive cache,
124
   * cache with complex indexing).
125
   *
126
   * @see CPUINFO_CACHE_UNIFIED, CPUINFO_CACHE_INCLUSIVE,
127
   * CPUINFO_CACHE_COMPLEX_INDEXING
128
   */
129
  uint32_t flags;
130
  /** Index of the first logical processor that shares this cache */
131
  uint32_t processor_start;
132
  /** Number of logical processors that share this cache */
133
  uint32_t processor_count;
134
};
135
136
struct cpuinfo_trace_cache {
137
  uint32_t uops;
138
  uint32_t associativity;
139
};
140
141
#define CPUINFO_PAGE_SIZE_4KB 0x1000
142
#define CPUINFO_PAGE_SIZE_1MB 0x100000
143
#define CPUINFO_PAGE_SIZE_2MB 0x200000
144
#define CPUINFO_PAGE_SIZE_4MB 0x400000
145
#define CPUINFO_PAGE_SIZE_16MB 0x1000000
146
#define CPUINFO_PAGE_SIZE_1GB 0x40000000
147
148
struct cpuinfo_tlb {
149
  uint32_t entries;
150
  uint32_t associativity;
151
  uint64_t pages;
152
};
153
154
/** Vendor of processor core design */
155
enum cpuinfo_vendor {
156
  /** Processor vendor is not known to the library, or the library failed
157
     to get vendor information from the OS. */
158
  cpuinfo_vendor_unknown = 0,
159
160
  /* Active vendors of modern CPUs */
161
162
  /**
163
   * Intel Corporation. Vendor of x86, x86-64, IA64, and ARM processor
164
   * microarchitectures.
165
   *
166
   * Sold its ARM design subsidiary in 2006. The last ARM processor design
167
   * was released in 2004.
168
   */
169
  cpuinfo_vendor_intel = 1,
170
  /** Advanced Micro Devices, Inc. Vendor of x86 and x86-64 processor
171
     microarchitectures. */
172
  cpuinfo_vendor_amd = 2,
173
  /** ARM Holdings plc. Vendor of ARM and ARM64 processor
174
     microarchitectures. */
175
  cpuinfo_vendor_arm = 3,
176
  /** Qualcomm Incorporated. Vendor of ARM and ARM64 processor
177
     microarchitectures. */
178
  cpuinfo_vendor_qualcomm = 4,
179
  /** Apple Inc. Vendor of ARM and ARM64 processor microarchitectures. */
180
  cpuinfo_vendor_apple = 5,
181
  /** Samsung Electronics Co., Ltd. Vendir if ARM64 processor
182
     microarchitectures. */
183
  cpuinfo_vendor_samsung = 6,
184
  /** Nvidia Corporation. Vendor of ARM64-compatible processor
185
     microarchitectures. */
186
  cpuinfo_vendor_nvidia = 7,
187
  /** MIPS Technologies, Inc. Vendor of MIPS processor microarchitectures.
188
   */
189
  cpuinfo_vendor_mips = 8,
190
  /** International Business Machines Corporation. Vendor of PowerPC
191
     processor microarchitectures. */
192
  cpuinfo_vendor_ibm = 9,
193
  /** Ingenic Semiconductor. Vendor of MIPS processor microarchitectures.
194
   */
195
  cpuinfo_vendor_ingenic = 10,
196
  /**
197
   * VIA Technologies, Inc. Vendor of x86 and x86-64 processor
198
   * microarchitectures.
199
   *
200
   * Processors are designed by Centaur Technology, a subsidiary of VIA
201
   * Technologies.
202
   */
203
  cpuinfo_vendor_via = 11,
204
  /** Cavium, Inc. Vendor of ARM64 processor microarchitectures. */
205
  cpuinfo_vendor_cavium = 12,
206
  /** Broadcom, Inc. Vendor of ARM processor microarchitectures. */
207
  cpuinfo_vendor_broadcom = 13,
208
  /** Applied Micro Circuits Corporation (APM). Vendor of ARM64 processor
209
     microarchitectures. */
210
  cpuinfo_vendor_apm = 14,
211
  /**
212
   * Huawei Technologies Co., Ltd. Vendor of ARM64 processor
213
   * microarchitectures.
214
   *
215
   * Processors are designed by HiSilicon, a subsidiary of Huawei.
216
   */
217
  cpuinfo_vendor_huawei = 15,
218
  /**
219
   * Hygon (Chengdu Haiguang Integrated Circuit Design Co., Ltd), Vendor
220
   * of x86-64 processor microarchitectures.
221
   *
222
   * Processors are variants of AMD cores.
223
   */
224
  cpuinfo_vendor_hygon = 16,
225
  /** SiFive, Inc. Vendor of RISC-V processor microarchitectures. */
226
  cpuinfo_vendor_sifive = 17,
227
228
  /* Active vendors of embedded CPUs */
229
230
  /** Texas Instruments Inc. Vendor of ARM processor microarchitectures.
231
   */
232
  cpuinfo_vendor_texas_instruments = 30,
233
  /** Marvell Technology Group Ltd. Vendor of ARM processor
234
   * microarchitectures.
235
   */
236
  cpuinfo_vendor_marvell = 31,
237
  /** RDC Semiconductor Co., Ltd. Vendor of x86 processor
238
     microarchitectures. */
239
  cpuinfo_vendor_rdc = 32,
240
  /** DM&P Electronics Inc. Vendor of x86 processor microarchitectures. */
241
  cpuinfo_vendor_dmp = 33,
242
  /** Motorola, Inc. Vendor of PowerPC and ARM processor
243
     microarchitectures. */
244
  cpuinfo_vendor_motorola = 34,
245
246
  /* Defunct CPU vendors */
247
248
  /**
249
   * Transmeta Corporation. Vendor of x86 processor microarchitectures.
250
   *
251
   * Now defunct. The last processor design was released in 2004.
252
   * Transmeta processors implemented VLIW ISA and used binary translation
253
   * to execute x86 code.
254
   */
255
  cpuinfo_vendor_transmeta = 50,
256
  /**
257
   * Cyrix Corporation. Vendor of x86 processor microarchitectures.
258
   *
259
   * Now defunct. The last processor design was released in 1996.
260
   */
261
  cpuinfo_vendor_cyrix = 51,
262
  /**
263
   * Rise Technology. Vendor of x86 processor microarchitectures.
264
   *
265
   * Now defunct. The last processor design was released in 1999.
266
   */
267
  cpuinfo_vendor_rise = 52,
268
  /**
269
   * National Semiconductor. Vendor of x86 processor microarchitectures.
270
   *
271
   * Sold its x86 design subsidiary in 1999. The last processor design was
272
   * released in 1998.
273
   */
274
  cpuinfo_vendor_nsc = 53,
275
  /**
276
   * Silicon Integrated Systems. Vendor of x86 processor
277
   * microarchitectures.
278
   *
279
   * Sold its x86 design subsidiary in 2001. The last processor design was
280
   * released in 2001.
281
   */
282
  cpuinfo_vendor_sis = 54,
283
  /**
284
   * NexGen. Vendor of x86 processor microarchitectures.
285
   *
286
   * Now defunct. The last processor design was released in 1994.
287
   * NexGen designed the first x86 microarchitecture which decomposed x86
288
   * instructions into simple microoperations.
289
   */
290
  cpuinfo_vendor_nexgen = 55,
291
  /**
292
   * United Microelectronics Corporation. Vendor of x86 processor
293
   * microarchitectures.
294
   *
295
   * Ceased x86 in the early 1990s. The last processor design was released
296
   * in 1991. Designed U5C and U5D processors. Both are 486 level.
297
   */
298
  cpuinfo_vendor_umc = 56,
299
  /**
300
   * Digital Equipment Corporation. Vendor of ARM processor
301
   * microarchitecture.
302
   *
303
   * Sold its ARM designs in 1997. The last processor design was released
304
   * in 1997.
305
   */
306
  cpuinfo_vendor_dec = 57,
307
};
308
309
/**
310
 * Processor microarchitecture
311
 *
312
 * Processors with different microarchitectures often have different instruction
313
 * performance characteristics, and may have dramatically different pipeline
314
 * organization.
315
 */
316
enum cpuinfo_uarch {
317
  /** Microarchitecture is unknown, or the library failed to get
318
     information about the microarchitecture from OS */
319
  cpuinfo_uarch_unknown = 0,
320
321
  /** Pentium and Pentium MMX microarchitecture. */
322
  cpuinfo_uarch_p5 = 0x00100100,
323
  /** Intel Quark microarchitecture. */
324
  cpuinfo_uarch_quark = 0x00100101,
325
326
  /** Pentium Pro, Pentium II, and Pentium III. */
327
  cpuinfo_uarch_p6 = 0x00100200,
328
  /** Pentium M. */
329
  cpuinfo_uarch_dothan = 0x00100201,
330
  /** Intel Core microarchitecture. */
331
  cpuinfo_uarch_yonah = 0x00100202,
332
  /** Intel Core 2 microarchitecture on 65 nm process. */
333
  cpuinfo_uarch_conroe = 0x00100203,
334
  /** Intel Core 2 microarchitecture on 45 nm process. */
335
  cpuinfo_uarch_penryn = 0x00100204,
336
  /** Intel Nehalem and Westmere microarchitectures (Core i3/i5/i7 1st
337
     gen). */
338
  cpuinfo_uarch_nehalem = 0x00100205,
339
  /** Intel Sandy Bridge microarchitecture (Core i3/i5/i7 2nd gen). */
340
  cpuinfo_uarch_sandy_bridge = 0x00100206,
341
  /** Intel Ivy Bridge microarchitecture (Core i3/i5/i7 3rd gen). */
342
  cpuinfo_uarch_ivy_bridge = 0x00100207,
343
  /** Intel Haswell microarchitecture (Core i3/i5/i7 4th gen). */
344
  cpuinfo_uarch_haswell = 0x00100208,
345
  /** Intel Broadwell microarchitecture. */
346
  cpuinfo_uarch_broadwell = 0x00100209,
347
  /** Intel Sky Lake microarchitecture (14 nm, including
348
     Kaby/Coffee/Whiskey/Amber/Comet/Cascade/Cooper Lake). */
349
  cpuinfo_uarch_sky_lake = 0x0010020A,
350
  /** DEPRECATED (Intel Kaby Lake microarchitecture). */
351
  cpuinfo_uarch_kaby_lake = 0x0010020A,
352
  /** Intel Palm Cove microarchitecture (10 nm, Cannon Lake). */
353
  cpuinfo_uarch_palm_cove = 0x0010020B,
354
  /** Intel Sunny Cove microarchitecture (10 nm, Ice Lake). */
355
  cpuinfo_uarch_sunny_cove = 0x0010020C,
356
  /** Intel Willow Cove microarchitecture (10 nm, Tiger Lake). */
357
  cpuinfo_uarch_willow_cove = 0x0010020D,
358
  /** Intel Golden Cove microarchitecture (Sapphire Rapids). */
359
  cpuinfo_uarch_golden_cove = 0x0010020E,
360
  /** Intel Raptor Cove microarchitecture (Emerald Rapids). */
361
  cpuinfo_uarch_raptor_cove = 0x0010020F,
362
  /** Intel Redwood Cove microarchitecture (Granite Rapids). */
363
  cpuinfo_uarch_redwood_cove = 0x00100210,
364
365
  /** Pentium 4 with Willamette, Northwood, or Foster cores. */
366
  cpuinfo_uarch_willamette = 0x00100300,
367
  /** Pentium 4 with Prescott and later cores. */
368
  cpuinfo_uarch_prescott = 0x00100301,
369
370
  /** Intel Atom on 45 nm process. */
371
  cpuinfo_uarch_bonnell = 0x00100400,
372
  /** Intel Atom on 32 nm process. */
373
  cpuinfo_uarch_saltwell = 0x00100401,
374
  /** Intel Silvermont microarchitecture (22 nm out-of-order Atom). */
375
  cpuinfo_uarch_silvermont = 0x00100402,
376
  /** Intel Airmont microarchitecture (14 nm out-of-order Atom). */
377
  cpuinfo_uarch_airmont = 0x00100403,
378
  /** Intel Goldmont microarchitecture (Denverton, Apollo Lake). */
379
  cpuinfo_uarch_goldmont = 0x00100404,
380
  /** Intel Goldmont Plus microarchitecture (Gemini Lake). */
381
  cpuinfo_uarch_goldmont_plus = 0x00100405,
382
  /** Intel Airmont microarchitecture (10 nm out-of-order Atom). */
383
  cpuinfo_uarch_tremont = 0x00100406,
384
  /** Intel Gracemont microarchitecture (AlderLake N). */
385
  cpuinfo_uarch_gracemont = 0x00100407,
386
  /** Intel Crestmont microarchitecture (Sierra Forest). */
387
  cpuinfo_uarch_crestmont = 0x00100408,
388
  /** Intel Darkmont microarchitecture (e-core used in Clearwater Forest). */
389
  cpuinfo_uarch_darkmont = 0x00100409,
390
391
  /** Intel Knights Ferry HPC boards. */
392
  cpuinfo_uarch_knights_ferry = 0x00100500,
393
  /** Intel Knights Corner HPC boards (aka Xeon Phi). */
394
  cpuinfo_uarch_knights_corner = 0x00100501,
395
  /** Intel Knights Landing microarchitecture (second-gen MIC). */
396
  cpuinfo_uarch_knights_landing = 0x00100502,
397
  /** Intel Knights Hill microarchitecture (third-gen MIC). */
398
  cpuinfo_uarch_knights_hill = 0x00100503,
399
  /** Intel Knights Mill Xeon Phi. */
400
  cpuinfo_uarch_knights_mill = 0x00100504,
401
402
  /** Intel/Marvell XScale series. */
403
  cpuinfo_uarch_xscale = 0x00100600,
404
405
  /** AMD K5. */
406
  cpuinfo_uarch_k5 = 0x00200100,
407
  /** AMD K6 and alike. */
408
  cpuinfo_uarch_k6 = 0x00200101,
409
  /** AMD Athlon and Duron. */
410
  cpuinfo_uarch_k7 = 0x00200102,
411
  /** AMD Athlon 64, Opteron 64. */
412
  cpuinfo_uarch_k8 = 0x00200103,
413
  /** AMD Family 10h (Barcelona, Istambul, Magny-Cours). */
414
  cpuinfo_uarch_k10 = 0x00200104,
415
  /**
416
   * AMD Bulldozer microarchitecture
417
   * Zambezi FX-series CPUs, Zurich, Valencia and Interlagos Opteron CPUs.
418
   */
419
  cpuinfo_uarch_bulldozer = 0x00200105,
420
  /**
421
   * AMD Piledriver microarchitecture
422
   * Vishera FX-series CPUs, Trinity and Richland APUs, Delhi, Seoul, Abu
423
   * Dhabi Opteron CPUs.
424
   */
425
  cpuinfo_uarch_piledriver = 0x00200106,
426
  /** AMD Steamroller microarchitecture (Kaveri APUs). */
427
  cpuinfo_uarch_steamroller = 0x00200107,
428
  /** AMD Excavator microarchitecture (Carizzo APUs). */
429
  cpuinfo_uarch_excavator = 0x00200108,
430
  /** AMD Zen microarchitecture (12/14 nm Ryzen and EPYC CPUs). */
431
  cpuinfo_uarch_zen = 0x00200109,
432
  /** AMD Zen 2 microarchitecture (7 nm Ryzen and EPYC CPUs). */
433
  cpuinfo_uarch_zen2 = 0x0020010A,
434
  /** AMD Zen 3 microarchitecture. */
435
  cpuinfo_uarch_zen3 = 0x0020010B,
436
  /** AMD Zen 4 microarchitecture. */
437
  cpuinfo_uarch_zen4 = 0x0020010C,
438
  /** AMD Zen 5 microarchitecture. */
439
  cpuinfo_uarch_zen5 = 0x0020010D,
440
  /** AMD Zen 6 microarchitecture. */
441
  cpuinfo_uarch_zen6 = 0x0020010E,
442
443
  /** NSC Geode and AMD Geode GX and LX. */
444
  cpuinfo_uarch_geode = 0x00200200,
445
  /** AMD Bobcat mobile microarchitecture. */
446
  cpuinfo_uarch_bobcat = 0x00200201,
447
  /** AMD Jaguar mobile microarchitecture. */
448
  cpuinfo_uarch_jaguar = 0x00200202,
449
  /** AMD Puma mobile microarchitecture. */
450
  cpuinfo_uarch_puma = 0x00200203,
451
452
  /** ARM7 series. */
453
  cpuinfo_uarch_arm7 = 0x00300100,
454
  /** ARM9 series. */
455
  cpuinfo_uarch_arm9 = 0x00300101,
456
  /** ARM 1136, ARM 1156, ARM 1176, or ARM 11MPCore. */
457
  cpuinfo_uarch_arm11 = 0x00300102,
458
459
  /** ARM Cortex-A5. */
460
  cpuinfo_uarch_cortex_a5 = 0x00300205,
461
  /** ARM Cortex-A7. */
462
  cpuinfo_uarch_cortex_a7 = 0x00300207,
463
  /** ARM Cortex-A8. */
464
  cpuinfo_uarch_cortex_a8 = 0x00300208,
465
  /** ARM Cortex-A9. */
466
  cpuinfo_uarch_cortex_a9 = 0x00300209,
467
  /** ARM Cortex-A12. */
468
  cpuinfo_uarch_cortex_a12 = 0x00300212,
469
  /** ARM Cortex-A15. */
470
  cpuinfo_uarch_cortex_a15 = 0x00300215,
471
  /** ARM Cortex-A17. */
472
  cpuinfo_uarch_cortex_a17 = 0x00300217,
473
474
  /** ARM Cortex-A32. */
475
  cpuinfo_uarch_cortex_a32 = 0x00300332,
476
  /** ARM Cortex-A35. */
477
  cpuinfo_uarch_cortex_a35 = 0x00300335,
478
  /** ARM Cortex-A53. */
479
  cpuinfo_uarch_cortex_a53 = 0x00300353,
480
  /** ARM Cortex-A55 revision 0 (restricted dual-issue capabilities
481
     compared to revision 1+). */
482
  cpuinfo_uarch_cortex_a55r0 = 0x00300354,
483
  /** ARM Cortex-A55. */
484
  cpuinfo_uarch_cortex_a55 = 0x00300355,
485
  /** ARM Cortex-A57. */
486
  cpuinfo_uarch_cortex_a57 = 0x00300357,
487
  /** ARM Cortex-A65. */
488
  cpuinfo_uarch_cortex_a65 = 0x00300365,
489
  /** ARM Cortex-A72. */
490
  cpuinfo_uarch_cortex_a72 = 0x00300372,
491
  /** ARM Cortex-A73. */
492
  cpuinfo_uarch_cortex_a73 = 0x00300373,
493
  /** ARM Cortex-A75. */
494
  cpuinfo_uarch_cortex_a75 = 0x00300375,
495
  /** ARM Cortex-A76. */
496
  cpuinfo_uarch_cortex_a76 = 0x00300376,
497
  /** ARM Cortex-A77. */
498
  cpuinfo_uarch_cortex_a77 = 0x00300377,
499
  /** ARM Cortex-A78. */
500
  cpuinfo_uarch_cortex_a78 = 0x00300378,
501
502
  /** ARM Neoverse N1. */
503
  cpuinfo_uarch_neoverse_n1 = 0x00300400,
504
  /** ARM Neoverse E1. */
505
  cpuinfo_uarch_neoverse_e1 = 0x00300401,
506
  /** ARM Neoverse V1. */
507
  cpuinfo_uarch_neoverse_v1 = 0x00300402,
508
  /** ARM Neoverse N2. */
509
  cpuinfo_uarch_neoverse_n2 = 0x00300403,
510
  /** ARM Neoverse V2. */
511
  cpuinfo_uarch_neoverse_v2 = 0x00300404,
512
513
  /** ARM Cortex-X1. */
514
  cpuinfo_uarch_cortex_x1 = 0x00300501,
515
  /** ARM Cortex-X2. */
516
  cpuinfo_uarch_cortex_x2 = 0x00300502,
517
  /** ARM Cortex-X3. */
518
  cpuinfo_uarch_cortex_x3 = 0x00300503,
519
  /** ARM Cortex-X4. */
520
  cpuinfo_uarch_cortex_x4 = 0x00300504,
521
  /** ARM Cortex-X925. */
522
  cpuinfo_uarch_cortex_x925 = 0x00300505,
523
524
  /** ARM Cortex-A510. */
525
  cpuinfo_uarch_cortex_a510 = 0x00300551,
526
  /** ARM Cortex-A520. */
527
  cpuinfo_uarch_cortex_a520 = 0x00300552,
528
  /** ARM Cortex-A320. */
529
  cpuinfo_uarch_cortex_a320 = 0x00300553,
530
  /** ARM Cortex-A710. */
531
  cpuinfo_uarch_cortex_a710 = 0x00300571,
532
  /** ARM Cortex-A715. */
533
  cpuinfo_uarch_cortex_a715 = 0x00300572,
534
  /** ARM Cortex-A720. */
535
  cpuinfo_uarch_cortex_a720 = 0x00300573,
536
  /** ARM Cortex-A725. */
537
  cpuinfo_uarch_cortex_a725 = 0x00300574,
538
539
  /** ARM Lumex-C1-Ultra. */
540
  cpuinfo_uarch_lumex_c1_ultra = 0x00300600,
541
  /** ARM Lumex-C1-Premium. */
542
  cpuinfo_uarch_lumex_c1_premium = 0x00300601,
543
  /** ARM Lumex-C1-Pro. */
544
  cpuinfo_uarch_lumex_c1_pro = 0x00300602,
545
  /** ARM Lumex-C1-Nano. */
546
  cpuinfo_uarch_lumex_c1_nano = 0x00300603,
547
548
  /** Qualcomm Scorpion. */
549
  cpuinfo_uarch_scorpion = 0x00400100,
550
  /** Qualcomm Krait. */
551
  cpuinfo_uarch_krait = 0x00400101,
552
  /** Qualcomm Kryo. */
553
  cpuinfo_uarch_kryo = 0x00400102,
554
  /** Qualcomm Falkor. */
555
  cpuinfo_uarch_falkor = 0x00400103,
556
  /** Qualcomm Saphira. */
557
  cpuinfo_uarch_saphira = 0x00400104,
558
  /** Qualcomm Oryon. */
559
  cpuinfo_uarch_oryon = 0x00400105,
560
  /** Qualcomm Oryon V3. */
561
  cpuinfo_uarch_oryon_v3 = 0x00400106,
562
563
  /** Nvidia Denver. */
564
  cpuinfo_uarch_denver = 0x00500100,
565
  /** Nvidia Denver 2. */
566
  cpuinfo_uarch_denver2 = 0x00500101,
567
  /** Nvidia Carmel. */
568
  cpuinfo_uarch_carmel = 0x00500102,
569
570
  /** Samsung Exynos M1 (Exynos 8890 big cores). */
571
  cpuinfo_uarch_exynos_m1 = 0x00600100,
572
  /** Samsung Exynos M2 (Exynos 8895 big cores). */
573
  cpuinfo_uarch_exynos_m2 = 0x00600101,
574
  /** Samsung Exynos M3 (Exynos 9810 big cores). */
575
  cpuinfo_uarch_exynos_m3 = 0x00600102,
576
  /** Samsung Exynos M4 (Exynos 9820 big cores). */
577
  cpuinfo_uarch_exynos_m4 = 0x00600103,
578
  /** Samsung Exynos M5 (Exynos 9830 big cores). */
579
  cpuinfo_uarch_exynos_m5 = 0x00600104,
580
581
  /* Deprecated synonym for Cortex-A76 */
582
  cpuinfo_uarch_cortex_a76ae = 0x00300376,
583
  /* Deprecated names for Exynos. */
584
  cpuinfo_uarch_mongoose_m1 = 0x00600100,
585
  cpuinfo_uarch_mongoose_m2 = 0x00600101,
586
  cpuinfo_uarch_meerkat_m3 = 0x00600102,
587
  cpuinfo_uarch_meerkat_m4 = 0x00600103,
588
589
  /** Apple A6 and A6X processors. */
590
  cpuinfo_uarch_swift = 0x00700100,
591
  /** Apple A7 processor. */
592
  cpuinfo_uarch_cyclone = 0x00700101,
593
  /** Apple A8 and A8X processor. */
594
  cpuinfo_uarch_typhoon = 0x00700102,
595
  /** Apple A9 and A9X processor. */
596
  cpuinfo_uarch_twister = 0x00700103,
597
  /** Apple A10 and A10X processor. */
598
  cpuinfo_uarch_hurricane = 0x00700104,
599
  /** Apple A11 processor (big cores). */
600
  cpuinfo_uarch_monsoon = 0x00700105,
601
  /** Apple A11 processor (little cores). */
602
  cpuinfo_uarch_mistral = 0x00700106,
603
  /** Apple A12 processor (big cores). */
604
  cpuinfo_uarch_vortex = 0x00700107,
605
  /** Apple A12 processor (little cores). */
606
  cpuinfo_uarch_tempest = 0x00700108,
607
  /** Apple A13 processor (big cores). */
608
  cpuinfo_uarch_lightning = 0x00700109,
609
  /** Apple A13 processor (little cores). */
610
  cpuinfo_uarch_thunder = 0x0070010A,
611
  /** Apple A14 / M1 processor (big cores). */
612
  cpuinfo_uarch_firestorm = 0x0070010B,
613
  /** Apple A14 / M1 processor (little cores). */
614
  cpuinfo_uarch_icestorm = 0x0070010C,
615
  /** Apple A15 / M2 processor (big cores). */
616
  cpuinfo_uarch_avalanche = 0x0070010D,
617
  /** Apple A15 / M2 processor (little cores). */
618
  cpuinfo_uarch_blizzard = 0x0070010E,
619
  /** Apple A16 processor (big cores). */
620
  cpuinfo_uarch_everest = 0x00700200,
621
  /** Apple A16 processor (little cores). */
622
  cpuinfo_uarch_sawtooth = 0x00700201,
623
  /** Apple A17 processor (big cores). */
624
  cpuinfo_uarch_coll_everest = 0x00700202,
625
  /** Apple A17 processor (little cores). */
626
  cpuinfo_uarch_coll_sawtooth = 0x00700203,
627
  /** Apple A18 processor (big cores). */
628
  cpuinfo_uarch_tupai_everest = 0x00700204,
629
  /** Apple A18 processor (little cores). */
630
  cpuinfo_uarch_tupai_sawtooth = 0x00700205,
631
  /** Apple A18 pro processor (big cores). */
632
  cpuinfo_uarch_tahiti_everest = 0x00700206,
633
  /** Apple A18 pro processor (little cores). */
634
  cpuinfo_uarch_tahiti_sawtooth = 0x00700207,
635
636
  /** Apple A19 processor (big cores). */
637
  cpuinfo_uarch_tilos_everest = 0x00700208,
638
  /** Apple A19 processor (little cores). */
639
  cpuinfo_uarch_tilos_sawtooth = 0x00700209,
640
641
  /** Apple M4 processor (big cores). */
642
  cpuinfo_uarch_donan_everest = 0x00700308,
643
  /** Apple M4 processor (little cores). */
644
  cpuinfo_uarch_donan_sawtooth = 0x00700309,
645
646
  /** Cavium ThunderX. */
647
  cpuinfo_uarch_thunderx = 0x00800100,
648
  /** Cavium ThunderX2 (originally Broadcom Vulkan). */
649
  cpuinfo_uarch_thunderx2 = 0x00800200,
650
651
  /** Marvell PJ4. */
652
  cpuinfo_uarch_pj4 = 0x00900100,
653
654
  /** Broadcom Brahma B15. */
655
  cpuinfo_uarch_brahma_b15 = 0x00A00100,
656
  /** Broadcom Brahma B53. */
657
  cpuinfo_uarch_brahma_b53 = 0x00A00101,
658
659
  /** Applied Micro X-Gene. */
660
  cpuinfo_uarch_xgene = 0x00B00100,
661
662
  /* Hygon Dhyana (a modification of AMD Zen for Chinese market). */
663
  cpuinfo_uarch_dhyana = 0x01000100,
664
665
  /** HiSilicon TaiShan v110 (Huawei Kunpeng 920 series processors). */
666
  cpuinfo_uarch_taishan_v110 = 0x00C00100,
667
};
668
669
struct cpuinfo_processor {
670
  /** SMT (hyperthread) ID within a core */
671
  uint32_t smt_id;
672
  /** Core containing this logical processor */
673
  const struct cpuinfo_core* core;
674
  /** Cluster of cores containing this logical processor */
675
  const struct cpuinfo_cluster* cluster;
676
  /** Physical package containing this logical processor */
677
  const struct cpuinfo_package* package;
678
#if defined(__linux__)
679
  /**
680
   * Linux-specific ID for the logical processor:
681
   * - Linux kernel exposes information about this logical processor in
682
   * /sys/devices/system/cpu/cpu<linux_id>/
683
   * - Bit <linux_id> in the cpu_set_t identifies this logical processor
684
   */
685
  int linux_id;
686
#endif
687
#if defined(_WIN32) || defined(__CYGWIN__)
688
  /** Windows-specific ID for the group containing the logical processor.
689
   */
690
  uint16_t windows_group_id;
691
  /**
692
   * Windows-specific ID of the logical processor within its group:
693
   * - Bit <windows_processor_id> in the KAFFINITY mask identifies this
694
   * logical processor within its group.
695
   */
696
  uint16_t windows_processor_id;
697
#endif
698
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
699
  /** APIC ID (unique x86-specific ID of the logical processor) */
700
  uint32_t apic_id;
701
#endif
702
  struct {
703
    /** Level 1 instruction cache */
704
    const struct cpuinfo_cache* l1i;
705
    /** Level 1 data cache */
706
    const struct cpuinfo_cache* l1d;
707
    /** Level 2 unified or data cache */
708
    const struct cpuinfo_cache* l2;
709
    /** Level 3 unified or data cache */
710
    const struct cpuinfo_cache* l3;
711
    /** Level 4 unified or data cache */
712
    const struct cpuinfo_cache* l4;
713
  } cache;
714
};
715
716
struct cpuinfo_core {
717
  /** Index of the first logical processor on this core. */
718
  uint32_t processor_start;
719
  /** Number of logical processors on this core */
720
  uint32_t processor_count;
721
  /** Core ID within a package */
722
  uint32_t core_id;
723
  /** Cluster containing this core */
724
  const struct cpuinfo_cluster* cluster;
725
  /** Physical package containing this core. */
726
  const struct cpuinfo_package* package;
727
  /** Vendor of the CPU microarchitecture for this core */
728
  enum cpuinfo_vendor vendor;
729
  /** CPU microarchitecture for this core */
730
  enum cpuinfo_uarch uarch;
731
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
732
  /** Value of CPUID leaf 1 EAX register for this core */
733
  uint32_t cpuid;
734
#elif CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
735
  /** Value of Main ID Register (MIDR) for this core */
736
  uint32_t midr;
737
#endif
738
  /** Clock rate (non-Turbo) of the core, in Hz */
739
  uint64_t frequency;
740
};
741
742
struct cpuinfo_cluster {
743
  /** Index of the first logical processor in the cluster */
744
  uint32_t processor_start;
745
  /** Number of logical processors in the cluster */
746
  uint32_t processor_count;
747
  /** Index of the first core in the cluster */
748
  uint32_t core_start;
749
  /** Number of cores on the cluster */
750
  uint32_t core_count;
751
  /** Cluster ID within a package */
752
  uint32_t cluster_id;
753
  /** Physical package containing the cluster */
754
  const struct cpuinfo_package* package;
755
  /** CPU microarchitecture vendor of the cores in the cluster */
756
  enum cpuinfo_vendor vendor;
757
  /** CPU microarchitecture of the cores in the cluster */
758
  enum cpuinfo_uarch uarch;
759
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
760
  /** Value of CPUID leaf 1 EAX register of the cores in the cluster */
761
  uint32_t cpuid;
762
#elif CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
763
  /** Value of Main ID Register (MIDR) of the cores in the cluster */
764
  uint32_t midr;
765
#endif
766
  /** Clock rate (non-Turbo) of the cores in the cluster, in Hz */
767
  uint64_t frequency;
768
};
769
770
#define CPUINFO_PACKAGE_NAME_MAX 64
771
772
struct cpuinfo_package {
773
  /** SoC or processor chip model name */
774
  char name[CPUINFO_PACKAGE_NAME_MAX];
775
  /** Index of the first logical processor on this physical package */
776
  uint32_t processor_start;
777
  /** Number of logical processors on this physical package */
778
  uint32_t processor_count;
779
  /** Index of the first core on this physical package */
780
  uint32_t core_start;
781
  /** Number of cores on this physical package */
782
  uint32_t core_count;
783
  /** Index of the first cluster of cores on this physical package */
784
  uint32_t cluster_start;
785
  /** Number of clusters of cores on this physical package */
786
  uint32_t cluster_count;
787
};
788
789
struct cpuinfo_uarch_info {
790
  /** Type of CPU microarchitecture */
791
  enum cpuinfo_uarch uarch;
792
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
793
  /** Value of CPUID leaf 1 EAX register for the microarchitecture */
794
  uint32_t cpuid;
795
#elif CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
796
  /** Value of Main ID Register (MIDR) for the microarchitecture */
797
  uint32_t midr;
798
#endif
799
  /** Number of logical processors with the microarchitecture */
800
  uint32_t processor_count;
801
  /** Number of cores with the microarchitecture */
802
  uint32_t core_count;
803
};
804
805
#ifdef __cplusplus
806
extern "C" {
807
#endif
808
809
bool CPUINFO_ABI cpuinfo_initialize(void);
810
811
void CPUINFO_ABI cpuinfo_deinitialize(void);
812
813
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
814
/* This structure is not a part of stable API. Use cpuinfo_has_x86_* functions
815
 * instead. */
816
struct cpuinfo_x86_isa {
817
#if CPUINFO_ARCH_X86
818
  bool rdtsc;
819
#endif
820
  bool rdtscp;
821
  bool rdpid;
822
  bool sysenter;
823
#if CPUINFO_ARCH_X86
824
  bool syscall;
825
#endif
826
  bool msr;
827
  bool clzero;
828
  bool clflush;
829
  bool clflushopt;
830
  bool mwait;
831
  bool mwaitx;
832
#if CPUINFO_ARCH_X86
833
  bool emmx;
834
#endif
835
  bool fxsave;
836
  bool xsave;
837
#if CPUINFO_ARCH_X86
838
  bool fpu;
839
  bool mmx;
840
  bool mmx_plus;
841
#endif
842
  bool three_d_now;
843
  bool three_d_now_plus;
844
#if CPUINFO_ARCH_X86
845
  bool three_d_now_geode;
846
#endif
847
  bool prefetch;
848
  bool prefetchw;
849
  bool prefetchwt1;
850
#if CPUINFO_ARCH_X86
851
  bool daz;
852
  bool sse;
853
  bool sse2;
854
#endif
855
  bool sse3;
856
  bool ssse3;
857
  bool sse4_1;
858
  bool sse4_2;
859
  bool sse4a;
860
  bool misaligned_sse;
861
  bool avx;
862
  bool avxvnni;
863
  bool fma3;
864
  bool fma4;
865
  bool xop;
866
  bool f16c;
867
  bool avx2;
868
  bool avx512f;
869
  bool avx512pf;
870
  bool avx512er;
871
  bool avx512cd;
872
  bool avx512dq;
873
  bool avx512bw;
874
  bool avx512vl;
875
  bool avx512ifma;
876
  bool avx512vbmi;
877
  bool avx512vbmi2;
878
  bool avx512bitalg;
879
  bool avx512vpopcntdq;
880
  bool avx512vnni;
881
  bool avx512bf16;
882
  bool avx512fp16;
883
  bool avx512vp2intersect;
884
  bool avx512_4vnniw;
885
  bool avx512_4fmaps;
886
  bool avx10_1;
887
  bool avx10_2;
888
  bool amx_bf16;
889
  bool amx_tile;
890
  bool amx_int8;
891
  bool amx_fp16;
892
  bool avx_vnni_int8;
893
  bool avx_vnni_int16;
894
  bool avx_ne_convert;
895
  bool hle;
896
  bool rtm;
897
  bool xtest;
898
  bool mpx;
899
#if CPUINFO_ARCH_X86
900
  bool cmov;
901
  bool cmpxchg8b;
902
#endif
903
  bool cmpxchg16b;
904
  bool clwb;
905
  bool movbe;
906
#if CPUINFO_ARCH_X86_64
907
  bool lahf_sahf;
908
#endif
909
  bool fs_gs_base;
910
  bool lzcnt;
911
  bool popcnt;
912
  bool tbm;
913
  bool bmi;
914
  bool bmi2;
915
  bool adx;
916
  bool aes;
917
  bool vaes;
918
  bool pclmulqdq;
919
  bool vpclmulqdq;
920
  bool gfni;
921
  bool rdrand;
922
  bool rdseed;
923
  bool sha;
924
  bool rng;
925
  bool ace;
926
  bool ace2;
927
  bool phe;
928
  bool pmm;
929
  bool lwp;
930
};
931
932
extern struct cpuinfo_x86_isa cpuinfo_isa;
933
#endif
934
935
0
static inline bool cpuinfo_has_x86_rdtsc(void) {
936
0
#if CPUINFO_ARCH_X86_64
937
0
  return true;
938
0
#elif CPUINFO_ARCH_X86
939
0
#if defined(__ANDROID__)
940
0
  return true;
941
0
#else
942
0
  return cpuinfo_isa.rdtsc;
943
0
#endif
944
0
#else
945
0
  return false;
946
0
#endif
947
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rdtsc
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rdtsc
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rdtsc
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rdtsc
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rdtsc
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rdtsc
948
949
0
static inline bool cpuinfo_has_x86_rdtscp(void) {
950
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
951
0
  return cpuinfo_isa.rdtscp;
952
0
#else
953
0
  return false;
954
0
#endif
955
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rdtscp
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rdtscp
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rdtscp
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rdtscp
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rdtscp
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rdtscp
956
957
0
static inline bool cpuinfo_has_x86_rdpid(void) {
958
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
959
0
  return cpuinfo_isa.rdpid;
960
0
#else
961
0
  return false;
962
0
#endif
963
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rdpid
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rdpid
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rdpid
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rdpid
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rdpid
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rdpid
964
965
0
static inline bool cpuinfo_has_x86_clzero(void) {
966
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
967
0
  return cpuinfo_isa.clzero;
968
0
#else
969
0
  return false;
970
0
#endif
971
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_clzero
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_clzero
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_clzero
Unexecuted instantiation: processors.c:cpuinfo_has_x86_clzero
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_clzero
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_clzero
972
973
0
static inline bool cpuinfo_has_x86_mwait(void) {
974
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
975
0
  return cpuinfo_isa.mwait;
976
0
#else
977
0
  return false;
978
0
#endif
979
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_mwait
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_mwait
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_mwait
Unexecuted instantiation: processors.c:cpuinfo_has_x86_mwait
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_mwait
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_mwait
980
981
0
static inline bool cpuinfo_has_x86_mwaitx(void) {
982
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
983
0
  return cpuinfo_isa.mwaitx;
984
0
#else
985
0
  return false;
986
0
#endif
987
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_mwaitx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_mwaitx
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_mwaitx
Unexecuted instantiation: processors.c:cpuinfo_has_x86_mwaitx
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_mwaitx
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_mwaitx
988
989
0
static inline bool cpuinfo_has_x86_fxsave(void) {
990
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
991
0
  return cpuinfo_isa.fxsave;
992
0
#else
993
0
  return false;
994
0
#endif
995
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_fxsave
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_fxsave
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_fxsave
Unexecuted instantiation: processors.c:cpuinfo_has_x86_fxsave
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_fxsave
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_fxsave
996
997
0
static inline bool cpuinfo_has_x86_xsave(void) {
998
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
999
0
  return cpuinfo_isa.xsave;
1000
0
#else
1001
0
  return false;
1002
0
#endif
1003
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_xsave
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_xsave
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_xsave
Unexecuted instantiation: processors.c:cpuinfo_has_x86_xsave
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_xsave
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_xsave
1004
1005
0
static inline bool cpuinfo_has_x86_fpu(void) {
1006
0
#if CPUINFO_ARCH_X86_64
1007
0
  return true;
1008
0
#elif CPUINFO_ARCH_X86
1009
0
#if defined(__ANDROID__)
1010
0
  return true;
1011
0
#else
1012
0
  return cpuinfo_isa.fpu;
1013
0
#endif
1014
0
#else
1015
0
  return false;
1016
0
#endif
1017
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_fpu
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_fpu
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_fpu
Unexecuted instantiation: processors.c:cpuinfo_has_x86_fpu
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_fpu
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_fpu
1018
1019
0
static inline bool cpuinfo_has_x86_mmx(void) {
1020
0
#if CPUINFO_ARCH_X86_64
1021
0
  return true;
1022
0
#elif CPUINFO_ARCH_X86
1023
0
#if defined(__ANDROID__)
1024
0
  return true;
1025
0
#else
1026
0
  return cpuinfo_isa.mmx;
1027
0
#endif
1028
0
#else
1029
0
  return false;
1030
0
#endif
1031
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_mmx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_mmx
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_mmx
Unexecuted instantiation: processors.c:cpuinfo_has_x86_mmx
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_mmx
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_mmx
1032
1033
0
static inline bool cpuinfo_has_x86_mmx_plus(void) {
1034
0
#if CPUINFO_ARCH_X86_64
1035
0
  return true;
1036
0
#elif CPUINFO_ARCH_X86
1037
0
#if defined(__ANDROID__)
1038
0
  return true;
1039
0
#else
1040
0
  return cpuinfo_isa.mmx_plus;
1041
0
#endif
1042
0
#else
1043
0
  return false;
1044
0
#endif
1045
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_mmx_plus
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_mmx_plus
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_mmx_plus
Unexecuted instantiation: processors.c:cpuinfo_has_x86_mmx_plus
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_mmx_plus
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_mmx_plus
1046
1047
0
static inline bool cpuinfo_has_x86_3dnow(void) {
1048
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1049
0
  return cpuinfo_isa.three_d_now;
1050
0
#else
1051
0
  return false;
1052
0
#endif
1053
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_3dnow
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_3dnow
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_3dnow
Unexecuted instantiation: processors.c:cpuinfo_has_x86_3dnow
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_3dnow
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_3dnow
1054
1055
0
static inline bool cpuinfo_has_x86_3dnow_plus(void) {
1056
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1057
0
  return cpuinfo_isa.three_d_now_plus;
1058
0
#else
1059
0
  return false;
1060
0
#endif
1061
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_3dnow_plus
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_3dnow_plus
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_3dnow_plus
Unexecuted instantiation: processors.c:cpuinfo_has_x86_3dnow_plus
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_3dnow_plus
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_3dnow_plus
1062
1063
0
static inline bool cpuinfo_has_x86_3dnow_geode(void) {
1064
0
#if CPUINFO_ARCH_X86_64
1065
0
  return false;
1066
0
#elif CPUINFO_ARCH_X86
1067
0
#if defined(__ANDROID__)
1068
0
  return false;
1069
0
#else
1070
0
  return cpuinfo_isa.three_d_now_geode;
1071
0
#endif
1072
0
#else
1073
0
  return false;
1074
0
#endif
1075
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_3dnow_geode
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_3dnow_geode
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_3dnow_geode
Unexecuted instantiation: processors.c:cpuinfo_has_x86_3dnow_geode
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_3dnow_geode
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_3dnow_geode
1076
1077
0
static inline bool cpuinfo_has_x86_prefetch(void) {
1078
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1079
0
  return cpuinfo_isa.prefetch;
1080
0
#else
1081
0
  return false;
1082
0
#endif
1083
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_prefetch
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_prefetch
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_prefetch
Unexecuted instantiation: processors.c:cpuinfo_has_x86_prefetch
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_prefetch
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_prefetch
1084
1085
0
static inline bool cpuinfo_has_x86_prefetchw(void) {
1086
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1087
0
  return cpuinfo_isa.prefetchw;
1088
0
#else
1089
0
  return false;
1090
0
#endif
1091
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_prefetchw
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_prefetchw
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_prefetchw
Unexecuted instantiation: processors.c:cpuinfo_has_x86_prefetchw
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_prefetchw
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_prefetchw
1092
1093
0
static inline bool cpuinfo_has_x86_prefetchwt1(void) {
1094
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1095
0
  return cpuinfo_isa.prefetchwt1;
1096
0
#else
1097
0
  return false;
1098
0
#endif
1099
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_prefetchwt1
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_prefetchwt1
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_prefetchwt1
Unexecuted instantiation: processors.c:cpuinfo_has_x86_prefetchwt1
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_prefetchwt1
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_prefetchwt1
1100
1101
0
static inline bool cpuinfo_has_x86_daz(void) {
1102
0
#if CPUINFO_ARCH_X86_64
1103
0
  return true;
1104
0
#elif CPUINFO_ARCH_X86
1105
0
#if defined(__ANDROID__)
1106
0
  return true;
1107
0
#else
1108
0
  return cpuinfo_isa.daz;
1109
0
#endif
1110
0
#else
1111
0
  return false;
1112
0
#endif
1113
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_daz
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_daz
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_daz
Unexecuted instantiation: processors.c:cpuinfo_has_x86_daz
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_daz
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_daz
1114
1115
0
static inline bool cpuinfo_has_x86_sse(void) {
1116
0
#if CPUINFO_ARCH_X86_64
1117
0
  return true;
1118
0
#elif CPUINFO_ARCH_X86
1119
0
#if defined(__ANDROID__)
1120
0
  return true;
1121
0
#else
1122
0
  return cpuinfo_isa.sse;
1123
0
#endif
1124
0
#else
1125
0
  return false;
1126
0
#endif
1127
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse
1128
1129
0
static inline bool cpuinfo_has_x86_sse2(void) {
1130
0
#if CPUINFO_ARCH_X86_64
1131
0
  return true;
1132
0
#elif CPUINFO_ARCH_X86
1133
0
#if defined(__ANDROID__)
1134
0
  return true;
1135
0
#else
1136
0
  return cpuinfo_isa.sse2;
1137
0
#endif
1138
0
#else
1139
0
  return false;
1140
0
#endif
1141
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse2
1142
1143
0
static inline bool cpuinfo_has_x86_sse3(void) {
1144
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1145
0
#if defined(__ANDROID__)
1146
0
  return true;
1147
0
#else
1148
0
  return cpuinfo_isa.sse3;
1149
0
#endif
1150
0
#else
1151
0
  return false;
1152
0
#endif
1153
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse3
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse3
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse3
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse3
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse3
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse3
1154
1155
0
static inline bool cpuinfo_has_x86_ssse3(void) {
1156
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1157
0
#if defined(__ANDROID__)
1158
0
  return true;
1159
0
#else
1160
0
  return cpuinfo_isa.ssse3;
1161
0
#endif
1162
0
#else
1163
0
  return false;
1164
0
#endif
1165
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_ssse3
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_ssse3
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_ssse3
Unexecuted instantiation: processors.c:cpuinfo_has_x86_ssse3
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_ssse3
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_ssse3
1166
1167
0
static inline bool cpuinfo_has_x86_sse4_1(void) {
1168
0
#if CPUINFO_ARCH_X86_64
1169
0
#if defined(__ANDROID__)
1170
0
  return true;
1171
0
#else
1172
0
  return cpuinfo_isa.sse4_1;
1173
0
#endif
1174
0
#elif CPUINFO_ARCH_X86
1175
0
  return cpuinfo_isa.sse4_1;
1176
0
#else
1177
0
  return false;
1178
0
#endif
1179
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse4_1
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse4_1
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse4_1
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse4_1
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse4_1
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse4_1
1180
1181
0
static inline bool cpuinfo_has_x86_sse4_2(void) {
1182
0
#if CPUINFO_ARCH_X86_64
1183
0
#if defined(__ANDROID__)
1184
0
  return true;
1185
0
#else
1186
0
  return cpuinfo_isa.sse4_2;
1187
0
#endif
1188
0
#elif CPUINFO_ARCH_X86
1189
0
  return cpuinfo_isa.sse4_2;
1190
0
#else
1191
0
  return false;
1192
0
#endif
1193
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse4_2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse4_2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse4_2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse4_2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse4_2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse4_2
1194
1195
0
static inline bool cpuinfo_has_x86_sse4a(void) {
1196
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1197
0
  return cpuinfo_isa.sse4a;
1198
0
#else
1199
0
  return false;
1200
0
#endif
1201
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sse4a
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sse4a
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sse4a
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sse4a
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sse4a
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sse4a
1202
1203
0
static inline bool cpuinfo_has_x86_misaligned_sse(void) {
1204
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1205
0
  return cpuinfo_isa.misaligned_sse;
1206
0
#else
1207
0
  return false;
1208
0
#endif
1209
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_misaligned_sse
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_misaligned_sse
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_misaligned_sse
Unexecuted instantiation: processors.c:cpuinfo_has_x86_misaligned_sse
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_misaligned_sse
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_misaligned_sse
1210
1211
0
static inline bool cpuinfo_has_x86_avx(void) {
1212
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1213
0
  return cpuinfo_isa.avx;
1214
0
#else
1215
0
  return false;
1216
0
#endif
1217
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx
1218
1219
0
static inline bool cpuinfo_has_x86_avxvnni(void) {
1220
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1221
0
  return cpuinfo_isa.avxvnni;
1222
0
#else
1223
0
  return false;
1224
0
#endif
1225
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avxvnni
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avxvnni
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avxvnni
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avxvnni
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avxvnni
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avxvnni
1226
1227
0
static inline bool cpuinfo_has_x86_fma3(void) {
1228
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1229
0
  return cpuinfo_isa.fma3;
1230
0
#else
1231
0
  return false;
1232
0
#endif
1233
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_fma3
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_fma3
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_fma3
Unexecuted instantiation: processors.c:cpuinfo_has_x86_fma3
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_fma3
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_fma3
1234
1235
0
static inline bool cpuinfo_has_x86_fma4(void) {
1236
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1237
0
  return cpuinfo_isa.fma4;
1238
0
#else
1239
0
  return false;
1240
0
#endif
1241
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_fma4
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_fma4
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_fma4
Unexecuted instantiation: processors.c:cpuinfo_has_x86_fma4
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_fma4
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_fma4
1242
1243
0
static inline bool cpuinfo_has_x86_xop(void) {
1244
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1245
0
  return cpuinfo_isa.xop;
1246
0
#else
1247
0
  return false;
1248
0
#endif
1249
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_xop
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_xop
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_xop
Unexecuted instantiation: processors.c:cpuinfo_has_x86_xop
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_xop
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_xop
1250
1251
0
static inline bool cpuinfo_has_x86_f16c(void) {
1252
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1253
0
  return cpuinfo_isa.f16c;
1254
0
#else
1255
0
  return false;
1256
0
#endif
1257
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_f16c
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_f16c
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_f16c
Unexecuted instantiation: processors.c:cpuinfo_has_x86_f16c
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_f16c
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_f16c
1258
1259
0
static inline bool cpuinfo_has_x86_avx2(void) {
1260
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1261
0
  return cpuinfo_isa.avx2;
1262
0
#else
1263
0
  return false;
1264
0
#endif
1265
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx2
1266
1267
0
static inline bool cpuinfo_has_x86_avx512f(void) {
1268
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1269
0
  return cpuinfo_isa.avx512f;
1270
0
#else
1271
0
  return false;
1272
0
#endif
1273
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512f
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512f
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512f
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512f
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512f
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512f
1274
1275
0
static inline bool cpuinfo_has_x86_avx512pf(void) {
1276
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1277
0
  return cpuinfo_isa.avx512pf;
1278
0
#else
1279
0
  return false;
1280
0
#endif
1281
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512pf
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512pf
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512pf
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512pf
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512pf
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512pf
1282
1283
0
static inline bool cpuinfo_has_x86_avx512er(void) {
1284
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1285
0
  return cpuinfo_isa.avx512er;
1286
0
#else
1287
0
  return false;
1288
0
#endif
1289
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512er
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512er
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512er
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512er
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512er
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512er
1290
1291
0
static inline bool cpuinfo_has_x86_avx512cd(void) {
1292
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1293
0
  return cpuinfo_isa.avx512cd;
1294
0
#else
1295
0
  return false;
1296
0
#endif
1297
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512cd
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512cd
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512cd
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512cd
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512cd
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512cd
1298
1299
0
static inline bool cpuinfo_has_x86_avx512dq(void) {
1300
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1301
0
  return cpuinfo_isa.avx512dq;
1302
0
#else
1303
0
  return false;
1304
0
#endif
1305
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512dq
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512dq
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512dq
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512dq
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512dq
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512dq
1306
1307
0
static inline bool cpuinfo_has_x86_avx512bw(void) {
1308
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1309
0
  return cpuinfo_isa.avx512bw;
1310
0
#else
1311
0
  return false;
1312
0
#endif
1313
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512bw
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512bw
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512bw
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512bw
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512bw
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512bw
1314
1315
0
static inline bool cpuinfo_has_x86_avx512vl(void) {
1316
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1317
0
  return cpuinfo_isa.avx512vl;
1318
0
#else
1319
0
  return false;
1320
0
#endif
1321
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vl
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vl
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vl
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vl
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vl
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vl
1322
1323
0
static inline bool cpuinfo_has_x86_avx512ifma(void) {
1324
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1325
0
  return cpuinfo_isa.avx512ifma;
1326
0
#else
1327
0
  return false;
1328
0
#endif
1329
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512ifma
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512ifma
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512ifma
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512ifma
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512ifma
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512ifma
1330
1331
0
static inline bool cpuinfo_has_x86_avx512vbmi(void) {
1332
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1333
0
  return cpuinfo_isa.avx512vbmi;
1334
0
#else
1335
0
  return false;
1336
0
#endif
1337
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vbmi
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vbmi
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vbmi
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vbmi
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vbmi
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vbmi
1338
1339
0
static inline bool cpuinfo_has_x86_avx512vbmi2(void) {
1340
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1341
0
  return cpuinfo_isa.avx512vbmi2;
1342
0
#else
1343
0
  return false;
1344
0
#endif
1345
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vbmi2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vbmi2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vbmi2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vbmi2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vbmi2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vbmi2
1346
1347
0
static inline bool cpuinfo_has_x86_avx512bitalg(void) {
1348
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1349
0
  return cpuinfo_isa.avx512bitalg;
1350
0
#else
1351
0
  return false;
1352
0
#endif
1353
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512bitalg
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512bitalg
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512bitalg
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512bitalg
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512bitalg
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512bitalg
1354
1355
0
static inline bool cpuinfo_has_x86_avx512vpopcntdq(void) {
1356
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1357
0
  return cpuinfo_isa.avx512vpopcntdq;
1358
0
#else
1359
0
  return false;
1360
0
#endif
1361
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vpopcntdq
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vpopcntdq
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vpopcntdq
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vpopcntdq
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vpopcntdq
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vpopcntdq
1362
1363
0
static inline bool cpuinfo_has_x86_avx512vnni(void) {
1364
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1365
0
  return cpuinfo_isa.avx512vnni;
1366
0
#else
1367
0
  return false;
1368
0
#endif
1369
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vnni
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vnni
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vnni
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vnni
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vnni
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vnni
1370
1371
0
static inline bool cpuinfo_has_x86_avx512bf16(void) {
1372
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1373
0
  return cpuinfo_isa.avx512bf16;
1374
0
#else
1375
0
  return false;
1376
0
#endif
1377
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512bf16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512bf16
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512bf16
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512bf16
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512bf16
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512bf16
1378
1379
0
static inline bool cpuinfo_has_x86_avx512fp16(void) {
1380
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1381
0
  return cpuinfo_isa.avx512fp16;
1382
0
#else
1383
0
  return false;
1384
0
#endif
1385
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512fp16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512fp16
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512fp16
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512fp16
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512fp16
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512fp16
1386
1387
0
static inline bool cpuinfo_has_x86_avx512vp2intersect(void) {
1388
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1389
0
  return cpuinfo_isa.avx512vp2intersect;
1390
0
#else
1391
0
  return false;
1392
0
#endif
1393
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512vp2intersect
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512vp2intersect
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512vp2intersect
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512vp2intersect
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512vp2intersect
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512vp2intersect
1394
1395
0
static inline bool cpuinfo_has_x86_avx512_4vnniw(void) {
1396
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1397
0
  return cpuinfo_isa.avx512_4vnniw;
1398
0
#else
1399
0
  return false;
1400
0
#endif
1401
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512_4vnniw
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512_4vnniw
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512_4vnniw
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512_4vnniw
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512_4vnniw
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512_4vnniw
1402
1403
0
static inline bool cpuinfo_has_x86_avx512_4fmaps(void) {
1404
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1405
0
  return cpuinfo_isa.avx512_4fmaps;
1406
0
#else
1407
0
  return false;
1408
0
#endif
1409
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx512_4fmaps
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx512_4fmaps
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx512_4fmaps
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx512_4fmaps
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx512_4fmaps
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx512_4fmaps
1410
1411
/* [NOTE] Intel Advanced Matrix Extensions (AMX) detection
1412
 *
1413
 * I.  AMX is a new extensions to the x86 ISA to work on matrices, consists of
1414
 *   1) 2-dimentional registers (tiles), hold sub-matrices from larger matrices in memory
1415
 *   2) Accelerator called Tile Matrix Multiply (TMUL), contains instructions operating on tiles
1416
 *
1417
 * II. Platforms that supports AMX:
1418
 * +-----------------+-----+----------+----------+----------+----------+
1419
 * |    Platforms    | Gen | amx-bf16 | amx-tile | amx-int8 | amx-fp16 |
1420
 * +-----------------+-----+----------+----------+----------+----------+
1421
 * | Sapphire Rapids | 4th |   YES    |   YES    |   YES    |    NO    |
1422
 * +-----------------+-----+----------+----------+----------+----------+
1423
 * | Emerald Rapids  | 5th |   YES    |   YES    |   YES    |    NO    |
1424
 * +-----------------+-----+----------+----------+----------+----------+
1425
 * | Granite Rapids  | 6th |   YES    |   YES    |   YES    |   YES    |
1426
 * +-----------------+-----+----------+----------+----------+----------+
1427
 *
1428
 * Reference: https://www.intel.com/content/www/us/en/products/docs
1429
 *    /accelerator-engines/advanced-matrix-extensions/overview.html
1430
 */
1431
0
static inline bool cpuinfo_has_x86_amx_bf16(void) {
1432
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1433
0
  return cpuinfo_isa.amx_bf16;
1434
0
#else
1435
0
  return false;
1436
0
#endif
1437
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_amx_bf16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_amx_bf16
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_amx_bf16
Unexecuted instantiation: processors.c:cpuinfo_has_x86_amx_bf16
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_amx_bf16
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_amx_bf16
1438
1439
0
static inline bool cpuinfo_has_x86_amx_tile(void) {
1440
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1441
0
  return cpuinfo_isa.amx_tile;
1442
0
#else
1443
0
  return false;
1444
0
#endif
1445
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_amx_tile
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_amx_tile
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_amx_tile
Unexecuted instantiation: processors.c:cpuinfo_has_x86_amx_tile
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_amx_tile
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_amx_tile
1446
1447
0
static inline bool cpuinfo_has_x86_amx_int8(void) {
1448
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1449
0
  return cpuinfo_isa.amx_int8;
1450
0
#else
1451
0
  return false;
1452
0
#endif
1453
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_amx_int8
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_amx_int8
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_amx_int8
Unexecuted instantiation: processors.c:cpuinfo_has_x86_amx_int8
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_amx_int8
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_amx_int8
1454
1455
0
static inline bool cpuinfo_has_x86_amx_fp16(void) {
1456
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1457
0
  return cpuinfo_isa.amx_fp16;
1458
0
#else
1459
0
  return false;
1460
0
#endif
1461
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_amx_fp16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_amx_fp16
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_amx_fp16
Unexecuted instantiation: processors.c:cpuinfo_has_x86_amx_fp16
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_amx_fp16
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_amx_fp16
1462
1463
/*
1464
 * Intel AVX Vector Neural Network Instructions (VNNI) INT8
1465
 * Supported Platfroms: Sierra Forest, Arrow Lake, Lunar Lake
1466
 */
1467
0
static inline bool cpuinfo_has_x86_avx_vnni_int8(void) {
1468
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1469
0
  return cpuinfo_isa.avx_vnni_int8;
1470
0
#else
1471
0
  return false;
1472
0
#endif
1473
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx_vnni_int8
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx_vnni_int8
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx_vnni_int8
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx_vnni_int8
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx_vnni_int8
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx_vnni_int8
1474
1475
/*
1476
 * Intel AVX Vector Neural Network Instructions (VNNI) INT16
1477
 * Supported Platfroms: Arrow Lake, Lunar Lake
1478
 */
1479
0
static inline bool cpuinfo_has_x86_avx_vnni_int16(void) {
1480
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1481
0
  return cpuinfo_isa.avx_vnni_int16;
1482
0
#else
1483
0
  return false;
1484
0
#endif
1485
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx_vnni_int16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx_vnni_int16
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx_vnni_int16
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx_vnni_int16
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx_vnni_int16
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx_vnni_int16
1486
1487
/*
1488
 * A new set of instructions, which can convert low precision floating point
1489
 * like BF16/FP16 to high precision floating point FP32, as well as convert FP32
1490
 * elements to BF16. This instruction allows the platform to have improved AI
1491
 * capabilities and better compatibility.
1492
 *
1493
 * Supported Platforms: Sierra Forest, Arrow Lake, Lunar Lake
1494
 */
1495
0
static inline bool cpuinfo_has_x86_avx_ne_convert(void) {
1496
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1497
0
  return cpuinfo_isa.avx_ne_convert;
1498
0
#else
1499
0
  return false;
1500
0
#endif
1501
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx_ne_convert
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx_ne_convert
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx_ne_convert
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx_ne_convert
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx_ne_convert
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx_ne_convert
1502
1503
0
static inline bool cpuinfo_has_x86_avx10_1(void) {
1504
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1505
0
  return cpuinfo_isa.avx10_1;
1506
0
#else
1507
0
  return false;
1508
0
#endif
1509
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx10_1
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx10_1
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx10_1
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx10_1
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx10_1
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx10_1
1510
1511
0
static inline bool cpuinfo_has_x86_avx10_2(void) {
1512
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1513
0
  return cpuinfo_isa.avx10_2;
1514
0
#else
1515
0
  return false;
1516
0
#endif
1517
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_avx10_2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_avx10_2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_avx10_2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_avx10_2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_avx10_2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_avx10_2
1518
1519
0
static inline bool cpuinfo_has_x86_hle(void) {
1520
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1521
0
  return cpuinfo_isa.hle;
1522
0
#else
1523
0
  return false;
1524
0
#endif
1525
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_hle
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_hle
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_hle
Unexecuted instantiation: processors.c:cpuinfo_has_x86_hle
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_hle
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_hle
1526
1527
0
static inline bool cpuinfo_has_x86_rtm(void) {
1528
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1529
0
  return cpuinfo_isa.rtm;
1530
0
#else
1531
0
  return false;
1532
0
#endif
1533
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rtm
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rtm
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rtm
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rtm
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rtm
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rtm
1534
1535
0
static inline bool cpuinfo_has_x86_xtest(void) {
1536
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1537
0
  return cpuinfo_isa.xtest;
1538
0
#else
1539
0
  return false;
1540
0
#endif
1541
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_xtest
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_xtest
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_xtest
Unexecuted instantiation: processors.c:cpuinfo_has_x86_xtest
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_xtest
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_xtest
1542
1543
0
static inline bool cpuinfo_has_x86_mpx(void) {
1544
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1545
0
  return cpuinfo_isa.mpx;
1546
0
#else
1547
0
  return false;
1548
0
#endif
1549
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_mpx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_mpx
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_mpx
Unexecuted instantiation: processors.c:cpuinfo_has_x86_mpx
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_mpx
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_mpx
1550
1551
0
static inline bool cpuinfo_has_x86_cmov(void) {
1552
0
#if CPUINFO_ARCH_X86_64
1553
0
  return true;
1554
0
#elif CPUINFO_ARCH_X86
1555
0
  return cpuinfo_isa.cmov;
1556
0
#else
1557
0
  return false;
1558
0
#endif
1559
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_cmov
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_cmov
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_cmov
Unexecuted instantiation: processors.c:cpuinfo_has_x86_cmov
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_cmov
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_cmov
1560
1561
0
static inline bool cpuinfo_has_x86_cmpxchg8b(void) {
1562
0
#if CPUINFO_ARCH_X86_64
1563
0
  return true;
1564
0
#elif CPUINFO_ARCH_X86
1565
0
  return cpuinfo_isa.cmpxchg8b;
1566
0
#else
1567
0
  return false;
1568
0
#endif
1569
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_cmpxchg8b
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_cmpxchg8b
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_cmpxchg8b
Unexecuted instantiation: processors.c:cpuinfo_has_x86_cmpxchg8b
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_cmpxchg8b
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_cmpxchg8b
1570
1571
0
static inline bool cpuinfo_has_x86_cmpxchg16b(void) {
1572
0
#if CPUINFO_ARCH_X86_64
1573
0
  return cpuinfo_isa.cmpxchg16b;
1574
0
#else
1575
0
  return false;
1576
0
#endif
1577
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_cmpxchg16b
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_cmpxchg16b
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_cmpxchg16b
Unexecuted instantiation: processors.c:cpuinfo_has_x86_cmpxchg16b
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_cmpxchg16b
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_cmpxchg16b
1578
1579
0
static inline bool cpuinfo_has_x86_clwb(void) {
1580
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1581
0
  return cpuinfo_isa.clwb;
1582
0
#else
1583
0
  return false;
1584
0
#endif
1585
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_clwb
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_clwb
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_clwb
Unexecuted instantiation: processors.c:cpuinfo_has_x86_clwb
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_clwb
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_clwb
1586
1587
0
static inline bool cpuinfo_has_x86_movbe(void) {
1588
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1589
0
  return cpuinfo_isa.movbe;
1590
0
#else
1591
0
  return false;
1592
0
#endif
1593
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_movbe
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_movbe
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_movbe
Unexecuted instantiation: processors.c:cpuinfo_has_x86_movbe
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_movbe
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_movbe
1594
1595
0
static inline bool cpuinfo_has_x86_lahf_sahf(void) {
1596
0
#if CPUINFO_ARCH_X86
1597
0
  return true;
1598
0
#elif CPUINFO_ARCH_X86_64
1599
0
  return cpuinfo_isa.lahf_sahf;
1600
0
#else
1601
0
  return false;
1602
0
#endif
1603
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_lahf_sahf
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_lahf_sahf
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_lahf_sahf
Unexecuted instantiation: processors.c:cpuinfo_has_x86_lahf_sahf
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_lahf_sahf
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_lahf_sahf
1604
1605
0
static inline bool cpuinfo_has_x86_lzcnt(void) {
1606
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1607
0
  return cpuinfo_isa.lzcnt;
1608
0
#else
1609
0
  return false;
1610
0
#endif
1611
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_lzcnt
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_lzcnt
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_lzcnt
Unexecuted instantiation: processors.c:cpuinfo_has_x86_lzcnt
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_lzcnt
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_lzcnt
1612
1613
0
static inline bool cpuinfo_has_x86_popcnt(void) {
1614
0
#if CPUINFO_ARCH_X86_64
1615
0
#if defined(__ANDROID__)
1616
0
  return true;
1617
0
#else
1618
0
  return cpuinfo_isa.popcnt;
1619
0
#endif
1620
0
#elif CPUINFO_ARCH_X86
1621
0
  return cpuinfo_isa.popcnt;
1622
0
#else
1623
0
  return false;
1624
0
#endif
1625
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_popcnt
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_popcnt
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_popcnt
Unexecuted instantiation: processors.c:cpuinfo_has_x86_popcnt
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_popcnt
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_popcnt
1626
1627
0
static inline bool cpuinfo_has_x86_tbm(void) {
1628
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1629
0
  return cpuinfo_isa.tbm;
1630
0
#else
1631
0
  return false;
1632
0
#endif
1633
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_tbm
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_tbm
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_tbm
Unexecuted instantiation: processors.c:cpuinfo_has_x86_tbm
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_tbm
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_tbm
1634
1635
0
static inline bool cpuinfo_has_x86_bmi(void) {
1636
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1637
0
  return cpuinfo_isa.bmi;
1638
0
#else
1639
0
  return false;
1640
0
#endif
1641
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_bmi
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_bmi
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_bmi
Unexecuted instantiation: processors.c:cpuinfo_has_x86_bmi
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_bmi
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_bmi
1642
1643
0
static inline bool cpuinfo_has_x86_bmi2(void) {
1644
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1645
0
  return cpuinfo_isa.bmi2;
1646
0
#else
1647
0
  return false;
1648
0
#endif
1649
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_bmi2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_bmi2
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_bmi2
Unexecuted instantiation: processors.c:cpuinfo_has_x86_bmi2
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_bmi2
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_bmi2
1650
1651
0
static inline bool cpuinfo_has_x86_adx(void) {
1652
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1653
0
  return cpuinfo_isa.adx;
1654
0
#else
1655
0
  return false;
1656
0
#endif
1657
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_adx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_adx
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_adx
Unexecuted instantiation: processors.c:cpuinfo_has_x86_adx
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_adx
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_adx
1658
1659
0
static inline bool cpuinfo_has_x86_aes(void) {
1660
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1661
0
  return cpuinfo_isa.aes;
1662
0
#else
1663
0
  return false;
1664
0
#endif
1665
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_aes
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_aes
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_aes
Unexecuted instantiation: processors.c:cpuinfo_has_x86_aes
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_aes
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_aes
1666
1667
0
static inline bool cpuinfo_has_x86_vaes(void) {
1668
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1669
0
  return cpuinfo_isa.vaes;
1670
0
#else
1671
0
  return false;
1672
0
#endif
1673
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_vaes
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_vaes
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_vaes
Unexecuted instantiation: processors.c:cpuinfo_has_x86_vaes
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_vaes
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_vaes
1674
1675
0
static inline bool cpuinfo_has_x86_pclmulqdq(void) {
1676
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1677
0
  return cpuinfo_isa.pclmulqdq;
1678
0
#else
1679
0
  return false;
1680
0
#endif
1681
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_pclmulqdq
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_pclmulqdq
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_pclmulqdq
Unexecuted instantiation: processors.c:cpuinfo_has_x86_pclmulqdq
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_pclmulqdq
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_pclmulqdq
1682
1683
0
static inline bool cpuinfo_has_x86_vpclmulqdq(void) {
1684
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1685
0
  return cpuinfo_isa.vpclmulqdq;
1686
0
#else
1687
0
  return false;
1688
0
#endif
1689
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_vpclmulqdq
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_vpclmulqdq
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_vpclmulqdq
Unexecuted instantiation: processors.c:cpuinfo_has_x86_vpclmulqdq
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_vpclmulqdq
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_vpclmulqdq
1690
1691
0
static inline bool cpuinfo_has_x86_gfni(void) {
1692
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1693
0
  return cpuinfo_isa.gfni;
1694
0
#else
1695
0
  return false;
1696
0
#endif
1697
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_gfni
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_gfni
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_gfni
Unexecuted instantiation: processors.c:cpuinfo_has_x86_gfni
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_gfni
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_gfni
1698
1699
0
static inline bool cpuinfo_has_x86_rdrand(void) {
1700
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1701
0
  return cpuinfo_isa.rdrand;
1702
0
#else
1703
0
  return false;
1704
0
#endif
1705
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rdrand
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rdrand
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rdrand
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rdrand
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rdrand
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rdrand
1706
1707
0
static inline bool cpuinfo_has_x86_rdseed(void) {
1708
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1709
0
  return cpuinfo_isa.rdseed;
1710
0
#else
1711
0
  return false;
1712
0
#endif
1713
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_rdseed
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_rdseed
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_rdseed
Unexecuted instantiation: processors.c:cpuinfo_has_x86_rdseed
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_rdseed
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_rdseed
1714
1715
0
static inline bool cpuinfo_has_x86_sha(void) {
1716
0
#if CPUINFO_ARCH_X86 || CPUINFO_ARCH_X86_64
1717
0
  return cpuinfo_isa.sha;
1718
0
#else
1719
0
  return false;
1720
0
#endif
1721
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_x86_sha
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_x86_sha
Unexecuted instantiation: multiline.c:cpuinfo_has_x86_sha
Unexecuted instantiation: processors.c:cpuinfo_has_x86_sha
Unexecuted instantiation: smallfile.c:cpuinfo_has_x86_sha
Unexecuted instantiation: cpulist.c:cpuinfo_has_x86_sha
1722
1723
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
1724
/* This structure is not a part of stable API. Use cpuinfo_has_arm_* functions
1725
 * instead. */
1726
struct cpuinfo_arm_isa {
1727
#if CPUINFO_ARCH_ARM
1728
  bool thumb;
1729
  bool thumb2;
1730
  bool thumbee;
1731
  bool jazelle;
1732
  bool armv5e;
1733
  bool armv6;
1734
  bool armv6k;
1735
  bool armv7;
1736
  bool armv7mp;
1737
  bool armv8;
1738
  bool idiv;
1739
1740
  bool vfpv2;
1741
  bool vfpv3;
1742
  bool d32;
1743
  bool fp16;
1744
  bool fma;
1745
1746
  bool wmmx;
1747
  bool wmmx2;
1748
  bool neon;
1749
#endif
1750
#if CPUINFO_ARCH_ARM64
1751
  bool atomics;
1752
  bool bf16;
1753
  bool sve;
1754
  bool sve2;
1755
  bool i8mm;
1756
  bool sme;
1757
  bool sme2;
1758
  bool sme2p1;
1759
  bool sme_i16i32;
1760
  bool sme_bi32i32;
1761
  bool sme_b16b16;
1762
  bool sme_f16f16;
1763
  uint32_t svelen;
1764
  uint32_t smelen;
1765
#endif
1766
  bool rdm;
1767
  bool fp16arith;
1768
  bool dot;
1769
  bool jscvt;
1770
  bool fcma;
1771
  bool fhm;
1772
1773
  bool aes;
1774
  bool sha1;
1775
  bool sha2;
1776
  bool pmull;
1777
  bool crc32;
1778
};
1779
1780
extern struct cpuinfo_arm_isa cpuinfo_isa;
1781
#endif
1782
1783
0
static inline bool cpuinfo_has_arm_thumb(void) {
1784
0
#if CPUINFO_ARCH_ARM
1785
0
  return cpuinfo_isa.thumb;
1786
0
#else
1787
0
  return false;
1788
0
#endif
1789
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_thumb
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_thumb
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_thumb
Unexecuted instantiation: processors.c:cpuinfo_has_arm_thumb
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_thumb
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_thumb
1790
1791
0
static inline bool cpuinfo_has_arm_thumb2(void) {
1792
0
#if CPUINFO_ARCH_ARM
1793
0
  return cpuinfo_isa.thumb2;
1794
0
#else
1795
0
  return false;
1796
0
#endif
1797
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_thumb2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_thumb2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_thumb2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_thumb2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_thumb2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_thumb2
1798
1799
0
static inline bool cpuinfo_has_arm_v5e(void) {
1800
0
#if CPUINFO_ARCH_ARM
1801
0
  return cpuinfo_isa.armv5e;
1802
0
#else
1803
0
  return false;
1804
0
#endif
1805
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v5e
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v5e
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v5e
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v5e
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v5e
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v5e
1806
1807
0
static inline bool cpuinfo_has_arm_v6(void) {
1808
0
#if CPUINFO_ARCH_ARM
1809
0
  return cpuinfo_isa.armv6;
1810
0
#else
1811
0
  return false;
1812
0
#endif
1813
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v6
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v6
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v6
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v6
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v6
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v6
1814
1815
0
static inline bool cpuinfo_has_arm_v6k(void) {
1816
0
#if CPUINFO_ARCH_ARM
1817
0
  return cpuinfo_isa.armv6k;
1818
0
#else
1819
0
  return false;
1820
0
#endif
1821
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v6k
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v6k
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v6k
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v6k
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v6k
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v6k
1822
1823
0
static inline bool cpuinfo_has_arm_v7(void) {
1824
0
#if CPUINFO_ARCH_ARM
1825
0
  return cpuinfo_isa.armv7;
1826
0
#else
1827
0
  return false;
1828
0
#endif
1829
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v7
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v7
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v7
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v7
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v7
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v7
1830
1831
0
static inline bool cpuinfo_has_arm_v7mp(void) {
1832
0
#if CPUINFO_ARCH_ARM
1833
0
  return cpuinfo_isa.armv7mp;
1834
0
#else
1835
0
  return false;
1836
0
#endif
1837
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v7mp
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v7mp
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v7mp
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v7mp
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v7mp
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v7mp
1838
1839
0
static inline bool cpuinfo_has_arm_v8(void) {
1840
0
#if CPUINFO_ARCH_ARM64
1841
0
  return true;
1842
0
#elif CPUINFO_ARCH_ARM
1843
0
  return cpuinfo_isa.armv8;
1844
0
#else
1845
0
  return false;
1846
0
#endif
1847
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_v8
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_v8
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_v8
Unexecuted instantiation: processors.c:cpuinfo_has_arm_v8
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_v8
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_v8
1848
1849
0
static inline bool cpuinfo_has_arm_idiv(void) {
1850
0
#if CPUINFO_ARCH_ARM64
1851
0
  return true;
1852
0
#elif CPUINFO_ARCH_ARM
1853
0
  return cpuinfo_isa.idiv;
1854
0
#else
1855
0
  return false;
1856
0
#endif
1857
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_idiv
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_idiv
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_idiv
Unexecuted instantiation: processors.c:cpuinfo_has_arm_idiv
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_idiv
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_idiv
1858
1859
0
static inline bool cpuinfo_has_arm_vfpv2(void) {
1860
0
#if CPUINFO_ARCH_ARM
1861
0
  return cpuinfo_isa.vfpv2;
1862
0
#else
1863
0
  return false;
1864
0
#endif
1865
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv2
1866
1867
0
static inline bool cpuinfo_has_arm_vfpv3(void) {
1868
0
#if CPUINFO_ARCH_ARM64
1869
0
  return true;
1870
0
#elif CPUINFO_ARCH_ARM
1871
0
  return cpuinfo_isa.vfpv3;
1872
0
#else
1873
0
  return false;
1874
0
#endif
1875
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv3
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv3
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv3
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv3
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv3
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv3
1876
1877
0
static inline bool cpuinfo_has_arm_vfpv3_d32(void) {
1878
0
#if CPUINFO_ARCH_ARM64
1879
0
  return true;
1880
0
#elif CPUINFO_ARCH_ARM
1881
0
  return cpuinfo_isa.vfpv3 && cpuinfo_isa.d32;
1882
0
#else
1883
0
  return false;
1884
0
#endif
1885
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv3_d32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv3_d32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv3_d32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv3_d32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv3_d32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv3_d32
1886
1887
0
static inline bool cpuinfo_has_arm_vfpv3_fp16(void) {
1888
0
#if CPUINFO_ARCH_ARM64
1889
0
  return true;
1890
0
#elif CPUINFO_ARCH_ARM
1891
0
  return cpuinfo_isa.vfpv3 && cpuinfo_isa.fp16;
1892
0
#else
1893
0
  return false;
1894
0
#endif
1895
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv3_fp16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv3_fp16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv3_fp16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv3_fp16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv3_fp16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv3_fp16
1896
1897
0
static inline bool cpuinfo_has_arm_vfpv3_fp16_d32(void) {
1898
0
#if CPUINFO_ARCH_ARM64
1899
0
  return true;
1900
0
#elif CPUINFO_ARCH_ARM
1901
0
  return cpuinfo_isa.vfpv3 && cpuinfo_isa.fp16 && cpuinfo_isa.d32;
1902
0
#else
1903
0
  return false;
1904
0
#endif
1905
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv3_fp16_d32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv3_fp16_d32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv3_fp16_d32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv3_fp16_d32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv3_fp16_d32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv3_fp16_d32
1906
1907
0
static inline bool cpuinfo_has_arm_vfpv4(void) {
1908
0
#if CPUINFO_ARCH_ARM64
1909
0
  return true;
1910
0
#elif CPUINFO_ARCH_ARM
1911
0
  return cpuinfo_isa.vfpv3 && cpuinfo_isa.fma;
1912
0
#else
1913
0
  return false;
1914
0
#endif
1915
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv4
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv4
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv4
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv4
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv4
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv4
1916
1917
0
static inline bool cpuinfo_has_arm_vfpv4_d32(void) {
1918
0
#if CPUINFO_ARCH_ARM64
1919
0
  return true;
1920
0
#elif CPUINFO_ARCH_ARM
1921
0
  return cpuinfo_isa.vfpv3 && cpuinfo_isa.fma && cpuinfo_isa.d32;
1922
0
#else
1923
0
  return false;
1924
0
#endif
1925
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_vfpv4_d32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_vfpv4_d32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_vfpv4_d32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_vfpv4_d32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_vfpv4_d32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_vfpv4_d32
1926
1927
0
static inline bool cpuinfo_has_arm_fp16_arith(void) {
1928
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
1929
0
  return cpuinfo_isa.fp16arith;
1930
0
#else
1931
0
  return false;
1932
0
#endif
1933
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_fp16_arith
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_fp16_arith
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_fp16_arith
Unexecuted instantiation: processors.c:cpuinfo_has_arm_fp16_arith
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_fp16_arith
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_fp16_arith
1934
1935
0
static inline bool cpuinfo_has_arm_bf16(void) {
1936
0
#if CPUINFO_ARCH_ARM64
1937
0
  return cpuinfo_isa.bf16;
1938
0
#else
1939
0
  return false;
1940
0
#endif
1941
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_bf16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_bf16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_bf16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_bf16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_bf16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_bf16
1942
1943
0
static inline bool cpuinfo_has_arm_wmmx(void) {
1944
0
#if CPUINFO_ARCH_ARM
1945
0
  return cpuinfo_isa.wmmx;
1946
0
#else
1947
0
  return false;
1948
0
#endif
1949
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_wmmx
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_wmmx
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_wmmx
Unexecuted instantiation: processors.c:cpuinfo_has_arm_wmmx
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_wmmx
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_wmmx
1950
1951
0
static inline bool cpuinfo_has_arm_wmmx2(void) {
1952
0
#if CPUINFO_ARCH_ARM
1953
0
  return cpuinfo_isa.wmmx2;
1954
0
#else
1955
0
  return false;
1956
0
#endif
1957
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_wmmx2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_wmmx2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_wmmx2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_wmmx2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_wmmx2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_wmmx2
1958
1959
0
static inline bool cpuinfo_has_arm_neon(void) {
1960
0
#if CPUINFO_ARCH_ARM64
1961
0
  return true;
1962
0
#elif CPUINFO_ARCH_ARM
1963
0
  return cpuinfo_isa.neon;
1964
0
#else
1965
0
  return false;
1966
0
#endif
1967
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon
1968
1969
0
static inline bool cpuinfo_has_arm_neon_fp16(void) {
1970
0
#if CPUINFO_ARCH_ARM64
1971
0
  return true;
1972
0
#elif CPUINFO_ARCH_ARM
1973
0
  return cpuinfo_isa.neon && cpuinfo_isa.fp16;
1974
0
#else
1975
0
  return false;
1976
0
#endif
1977
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_fp16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_fp16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_fp16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_fp16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_fp16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_fp16
1978
1979
0
static inline bool cpuinfo_has_arm_neon_fma(void) {
1980
0
#if CPUINFO_ARCH_ARM64
1981
0
  return true;
1982
0
#elif CPUINFO_ARCH_ARM
1983
0
  return cpuinfo_isa.neon && cpuinfo_isa.fma;
1984
0
#else
1985
0
  return false;
1986
0
#endif
1987
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_fma
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_fma
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_fma
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_fma
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_fma
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_fma
1988
1989
0
static inline bool cpuinfo_has_arm_neon_v8(void) {
1990
0
#if CPUINFO_ARCH_ARM64
1991
0
  return true;
1992
0
#elif CPUINFO_ARCH_ARM
1993
0
  return cpuinfo_isa.neon && cpuinfo_isa.armv8;
1994
0
#else
1995
0
  return false;
1996
0
#endif
1997
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_v8
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_v8
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_v8
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_v8
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_v8
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_v8
1998
1999
0
static inline bool cpuinfo_has_arm_atomics(void) {
2000
0
#if CPUINFO_ARCH_ARM64
2001
0
  return cpuinfo_isa.atomics;
2002
0
#else
2003
0
  return false;
2004
0
#endif
2005
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_atomics
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_atomics
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_atomics
Unexecuted instantiation: processors.c:cpuinfo_has_arm_atomics
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_atomics
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_atomics
2006
2007
0
static inline bool cpuinfo_has_arm_neon_rdm(void) {
2008
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2009
0
  return cpuinfo_isa.rdm;
2010
0
#else
2011
0
  return false;
2012
0
#endif
2013
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_rdm
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_rdm
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_rdm
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_rdm
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_rdm
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_rdm
2014
2015
0
static inline bool cpuinfo_has_arm_neon_fp16_arith(void) {
2016
0
#if CPUINFO_ARCH_ARM
2017
0
  return cpuinfo_isa.neon && cpuinfo_isa.fp16arith;
2018
0
#elif CPUINFO_ARCH_ARM64
2019
0
  return cpuinfo_isa.fp16arith;
2020
0
#else
2021
0
  return false;
2022
0
#endif
2023
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_fp16_arith
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_fp16_arith
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_fp16_arith
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_fp16_arith
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_fp16_arith
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_fp16_arith
2024
2025
0
static inline bool cpuinfo_has_arm_fhm(void) {
2026
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2027
0
  return cpuinfo_isa.fhm;
2028
0
#else
2029
0
  return false;
2030
0
#endif
2031
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_fhm
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_fhm
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_fhm
Unexecuted instantiation: processors.c:cpuinfo_has_arm_fhm
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_fhm
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_fhm
2032
2033
0
static inline bool cpuinfo_has_arm_neon_dot(void) {
2034
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2035
0
  return cpuinfo_isa.dot;
2036
0
#else
2037
0
  return false;
2038
0
#endif
2039
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_dot
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_dot
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_dot
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_dot
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_dot
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_dot
2040
2041
0
static inline bool cpuinfo_has_arm_neon_bf16(void) {
2042
0
#if CPUINFO_ARCH_ARM64
2043
0
  return cpuinfo_isa.bf16;
2044
0
#else
2045
0
  return false;
2046
0
#endif
2047
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_neon_bf16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_neon_bf16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_neon_bf16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_neon_bf16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_neon_bf16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_neon_bf16
2048
2049
0
static inline bool cpuinfo_has_arm_jscvt(void) {
2050
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2051
0
  return cpuinfo_isa.jscvt;
2052
0
#else
2053
0
  return false;
2054
0
#endif
2055
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_jscvt
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_jscvt
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_jscvt
Unexecuted instantiation: processors.c:cpuinfo_has_arm_jscvt
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_jscvt
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_jscvt
2056
2057
0
static inline bool cpuinfo_has_arm_fcma(void) {
2058
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2059
0
  return cpuinfo_isa.fcma;
2060
0
#else
2061
0
  return false;
2062
0
#endif
2063
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_fcma
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_fcma
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_fcma
Unexecuted instantiation: processors.c:cpuinfo_has_arm_fcma
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_fcma
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_fcma
2064
2065
0
static inline bool cpuinfo_has_arm_i8mm(void) {
2066
0
#if CPUINFO_ARCH_ARM64
2067
0
  return cpuinfo_isa.i8mm;
2068
0
#else
2069
0
  return false;
2070
0
#endif
2071
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_i8mm
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_i8mm
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_i8mm
Unexecuted instantiation: processors.c:cpuinfo_has_arm_i8mm
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_i8mm
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_i8mm
2072
2073
0
static inline bool cpuinfo_has_arm_aes(void) {
2074
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2075
0
  return cpuinfo_isa.aes;
2076
0
#else
2077
0
  return false;
2078
0
#endif
2079
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_aes
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_aes
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_aes
Unexecuted instantiation: processors.c:cpuinfo_has_arm_aes
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_aes
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_aes
2080
2081
0
static inline bool cpuinfo_has_arm_sha1(void) {
2082
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2083
0
  return cpuinfo_isa.sha1;
2084
0
#else
2085
0
  return false;
2086
0
#endif
2087
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sha1
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sha1
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sha1
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sha1
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sha1
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sha1
2088
2089
0
static inline bool cpuinfo_has_arm_sha2(void) {
2090
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2091
0
  return cpuinfo_isa.sha2;
2092
0
#else
2093
0
  return false;
2094
0
#endif
2095
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sha2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sha2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sha2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sha2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sha2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sha2
2096
2097
0
static inline bool cpuinfo_has_arm_pmull(void) {
2098
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2099
0
  return cpuinfo_isa.pmull;
2100
0
#else
2101
0
  return false;
2102
0
#endif
2103
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_pmull
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_pmull
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_pmull
Unexecuted instantiation: processors.c:cpuinfo_has_arm_pmull
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_pmull
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_pmull
2104
2105
0
static inline bool cpuinfo_has_arm_crc32(void) {
2106
0
#if CPUINFO_ARCH_ARM || CPUINFO_ARCH_ARM64
2107
0
  return cpuinfo_isa.crc32;
2108
0
#else
2109
0
  return false;
2110
0
#endif
2111
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_crc32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_crc32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_crc32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_crc32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_crc32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_crc32
2112
2113
0
static inline bool cpuinfo_has_arm_sve(void) {
2114
0
#if CPUINFO_ARCH_ARM64
2115
0
  return cpuinfo_isa.sve;
2116
0
#else
2117
0
  return false;
2118
0
#endif
2119
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sve
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sve
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sve
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sve
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sve
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sve
2120
2121
0
static inline bool cpuinfo_has_arm_sve_bf16(void) {
2122
0
#if CPUINFO_ARCH_ARM64
2123
0
  return cpuinfo_isa.sve && cpuinfo_isa.bf16;
2124
0
#else
2125
0
  return false;
2126
0
#endif
2127
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sve_bf16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sve_bf16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sve_bf16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sve_bf16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sve_bf16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sve_bf16
2128
2129
0
static inline bool cpuinfo_has_arm_sve2(void) {
2130
0
#if CPUINFO_ARCH_ARM64
2131
0
  return cpuinfo_isa.sve2;
2132
0
#else
2133
0
  return false;
2134
0
#endif
2135
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sve2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sve2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sve2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sve2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sve2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sve2
2136
2137
// Function to get the max SVE vector length on ARM CPU's which support SVE.
2138
0
static inline uint32_t cpuinfo_get_max_arm_sve_length(void) {
2139
0
#if CPUINFO_ARCH_ARM64
2140
0
  return cpuinfo_isa.svelen * 8; // bytes * 8 = bit length(vector length)
2141
0
#else
2142
0
  return 0;
2143
0
#endif
2144
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_get_max_arm_sve_length
Unexecuted instantiation: cpuinfo.c:cpuinfo_get_max_arm_sve_length
Unexecuted instantiation: multiline.c:cpuinfo_get_max_arm_sve_length
Unexecuted instantiation: processors.c:cpuinfo_get_max_arm_sve_length
Unexecuted instantiation: smallfile.c:cpuinfo_get_max_arm_sve_length
Unexecuted instantiation: cpulist.c:cpuinfo_get_max_arm_sve_length
2145
2146
// Function to get the max SME vector length on ARM CPU's which support SME.
2147
0
static inline uint32_t cpuinfo_get_max_arm_sme_length(void) {
2148
0
#if CPUINFO_ARCH_ARM64
2149
0
  return cpuinfo_isa.smelen * 8; // bytes * 8 = bit length(vector length)
2150
0
#else
2151
0
  return 0;
2152
0
#endif
2153
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_get_max_arm_sme_length
Unexecuted instantiation: cpuinfo.c:cpuinfo_get_max_arm_sme_length
Unexecuted instantiation: multiline.c:cpuinfo_get_max_arm_sme_length
Unexecuted instantiation: processors.c:cpuinfo_get_max_arm_sme_length
Unexecuted instantiation: smallfile.c:cpuinfo_get_max_arm_sme_length
Unexecuted instantiation: cpulist.c:cpuinfo_get_max_arm_sme_length
2154
2155
0
static inline bool cpuinfo_has_arm_sme(void) {
2156
0
#if CPUINFO_ARCH_ARM64
2157
0
  return cpuinfo_isa.sme;
2158
0
#else
2159
0
  return false;
2160
0
#endif
2161
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme
2162
2163
0
static inline bool cpuinfo_has_arm_sme2(void) {
2164
0
#if CPUINFO_ARCH_ARM64
2165
0
  return cpuinfo_isa.sme2;
2166
0
#else
2167
0
  return false;
2168
0
#endif
2169
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme2
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme2
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme2
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme2
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme2
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme2
2170
2171
0
static inline bool cpuinfo_has_arm_sme2p1(void) {
2172
0
#if CPUINFO_ARCH_ARM64
2173
0
  return cpuinfo_isa.sme2p1;
2174
0
#else
2175
0
  return false;
2176
0
#endif
2177
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme2p1
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme2p1
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme2p1
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme2p1
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme2p1
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme2p1
2178
2179
0
static inline bool cpuinfo_has_arm_sme_i16i32(void) {
2180
0
#if CPUINFO_ARCH_ARM64
2181
0
  return cpuinfo_isa.sme_i16i32;
2182
0
#else
2183
0
  return false;
2184
0
#endif
2185
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme_i16i32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme_i16i32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme_i16i32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme_i16i32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme_i16i32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme_i16i32
2186
2187
0
static inline bool cpuinfo_has_arm_sme_bi32i32(void) {
2188
0
#if CPUINFO_ARCH_ARM64
2189
0
  return cpuinfo_isa.sme_bi32i32;
2190
0
#else
2191
0
  return false;
2192
0
#endif
2193
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme_bi32i32
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme_bi32i32
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme_bi32i32
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme_bi32i32
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme_bi32i32
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme_bi32i32
2194
2195
0
static inline bool cpuinfo_has_arm_sme_b16b16(void) {
2196
0
#if CPUINFO_ARCH_ARM64
2197
0
  return cpuinfo_isa.sme_b16b16;
2198
0
#else
2199
0
  return false;
2200
0
#endif
2201
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme_b16b16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme_b16b16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme_b16b16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme_b16b16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme_b16b16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme_b16b16
2202
2203
0
static inline bool cpuinfo_has_arm_sme_f16f16(void) {
2204
0
#if CPUINFO_ARCH_ARM64
2205
0
  return cpuinfo_isa.sme_f16f16;
2206
0
#else
2207
0
  return false;
2208
0
#endif
2209
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_arm_sme_f16f16
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_arm_sme_f16f16
Unexecuted instantiation: multiline.c:cpuinfo_has_arm_sme_f16f16
Unexecuted instantiation: processors.c:cpuinfo_has_arm_sme_f16f16
Unexecuted instantiation: smallfile.c:cpuinfo_has_arm_sme_f16f16
Unexecuted instantiation: cpulist.c:cpuinfo_has_arm_sme_f16f16
2210
2211
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2212
/* This structure is not a part of stable API. Use cpuinfo_has_riscv_* functions
2213
 * instead. */
2214
struct cpuinfo_riscv_isa {
2215
  /**
2216
   * Keep fields in line with the canonical order as defined by
2217
   * Section 27.11 Subset Naming Convention.
2218
   */
2219
  /* RV32I/64I/128I Base ISA. */
2220
  bool i;
2221
#if CPUINFO_ARCH_RISCV32
2222
  /* RV32E Base ISA. */
2223
  bool e;
2224
#endif
2225
  /* Integer Multiply/Divide Extension. */
2226
  bool m;
2227
  /* Atomic Extension. */
2228
  bool a;
2229
  /* Single-Precision Floating-Point Extension. */
2230
  bool f;
2231
  /* Double-Precision Floating-Point Extension. */
2232
  bool d;
2233
  /* Compressed Extension. */
2234
  bool c;
2235
  /* Vector Extension. */
2236
  bool v;
2237
2238
  /* ISA Extensions */
2239
  /* Half-Precision Floating-Point Extension. */
2240
  bool zfh;
2241
  /* Half-Precision Floating-Point Vector Extension. */
2242
  bool zvfh;
2243
};
2244
2245
extern struct cpuinfo_riscv_isa cpuinfo_isa;
2246
#endif
2247
2248
0
static inline bool cpuinfo_has_riscv_i(void) {
2249
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2250
0
  return cpuinfo_isa.i;
2251
0
#else
2252
0
  return false;
2253
0
#endif
2254
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_i
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_i
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_i
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_i
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_i
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_i
2255
2256
0
static inline bool cpuinfo_has_riscv_e(void) {
2257
0
#if CPUINFO_ARCH_RISCV32
2258
0
  return cpuinfo_isa.e;
2259
0
#else
2260
0
  return false;
2261
0
#endif
2262
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_e
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_e
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_e
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_e
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_e
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_e
2263
2264
0
static inline bool cpuinfo_has_riscv_m(void) {
2265
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2266
0
  return cpuinfo_isa.m;
2267
0
#else
2268
0
  return false;
2269
0
#endif
2270
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_m
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_m
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_m
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_m
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_m
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_m
2271
2272
0
static inline bool cpuinfo_has_riscv_a(void) {
2273
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2274
0
  return cpuinfo_isa.a;
2275
0
#else
2276
0
  return false;
2277
0
#endif
2278
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_a
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_a
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_a
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_a
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_a
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_a
2279
2280
0
static inline bool cpuinfo_has_riscv_f(void) {
2281
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2282
0
  return cpuinfo_isa.f;
2283
0
#else
2284
0
  return false;
2285
0
#endif
2286
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_f
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_f
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_f
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_f
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_f
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_f
2287
2288
0
static inline bool cpuinfo_has_riscv_d(void) {
2289
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2290
0
  return cpuinfo_isa.d;
2291
0
#else
2292
0
  return false;
2293
0
#endif
2294
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_d
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_d
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_d
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_d
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_d
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_d
2295
2296
0
static inline bool cpuinfo_has_riscv_g(void) {
2297
0
  // The 'G' extension is simply shorthand for 'IMAFD'.
2298
0
  return cpuinfo_has_riscv_i() && cpuinfo_has_riscv_m() && cpuinfo_has_riscv_a() && cpuinfo_has_riscv_f() &&
2299
0
    cpuinfo_has_riscv_d();
2300
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_g
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_g
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_g
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_g
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_g
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_g
2301
2302
0
static inline bool cpuinfo_has_riscv_c(void) {
2303
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2304
0
  return cpuinfo_isa.c;
2305
0
#else
2306
0
  return false;
2307
0
#endif
2308
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_c
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_c
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_c
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_c
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_c
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_c
2309
2310
0
static inline bool cpuinfo_has_riscv_v(void) {
2311
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2312
0
  return cpuinfo_isa.v;
2313
0
#else
2314
0
  return false;
2315
0
#endif
2316
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_v
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_v
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_v
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_v
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_v
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_v
2317
2318
0
static inline bool cpuinfo_has_riscv_zfh(void) {
2319
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2320
0
  return cpuinfo_isa.zfh;
2321
0
#else
2322
0
  return false;
2323
0
#endif
2324
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_zfh
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_zfh
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_zfh
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_zfh
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_zfh
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_zfh
2325
2326
0
static inline bool cpuinfo_has_riscv_zvfh(void) {
2327
0
#if CPUINFO_ARCH_RISCV32 || CPUINFO_ARCH_RISCV64
2328
0
  return cpuinfo_isa.zvfh;
2329
0
#else
2330
0
  return false;
2331
0
#endif
2332
0
}
Unexecuted instantiation: fuzz_cpuinfo.c:cpuinfo_has_riscv_zvfh
Unexecuted instantiation: cpuinfo.c:cpuinfo_has_riscv_zvfh
Unexecuted instantiation: multiline.c:cpuinfo_has_riscv_zvfh
Unexecuted instantiation: processors.c:cpuinfo_has_riscv_zvfh
Unexecuted instantiation: smallfile.c:cpuinfo_has_riscv_zvfh
Unexecuted instantiation: cpulist.c:cpuinfo_has_riscv_zvfh
2333
2334
const struct cpuinfo_processor* CPUINFO_ABI cpuinfo_get_processors(void);
2335
const struct cpuinfo_core* CPUINFO_ABI cpuinfo_get_cores(void);
2336
const struct cpuinfo_cluster* CPUINFO_ABI cpuinfo_get_clusters(void);
2337
const struct cpuinfo_package* CPUINFO_ABI cpuinfo_get_packages(void);
2338
const struct cpuinfo_uarch_info* CPUINFO_ABI cpuinfo_get_uarchs(void);
2339
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l1i_caches(void);
2340
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l1d_caches(void);
2341
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l2_caches(void);
2342
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l3_caches(void);
2343
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l4_caches(void);
2344
2345
const struct cpuinfo_processor* CPUINFO_ABI cpuinfo_get_processor(uint32_t index);
2346
const struct cpuinfo_core* CPUINFO_ABI cpuinfo_get_core(uint32_t index);
2347
const struct cpuinfo_cluster* CPUINFO_ABI cpuinfo_get_cluster(uint32_t index);
2348
const struct cpuinfo_package* CPUINFO_ABI cpuinfo_get_package(uint32_t index);
2349
const struct cpuinfo_uarch_info* CPUINFO_ABI cpuinfo_get_uarch(uint32_t index);
2350
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l1i_cache(uint32_t index);
2351
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l1d_cache(uint32_t index);
2352
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l2_cache(uint32_t index);
2353
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l3_cache(uint32_t index);
2354
const struct cpuinfo_cache* CPUINFO_ABI cpuinfo_get_l4_cache(uint32_t index);
2355
2356
uint32_t CPUINFO_ABI cpuinfo_get_processors_count(void);
2357
uint32_t CPUINFO_ABI cpuinfo_get_cores_count(void);
2358
uint32_t CPUINFO_ABI cpuinfo_get_clusters_count(void);
2359
uint32_t CPUINFO_ABI cpuinfo_get_packages_count(void);
2360
uint32_t CPUINFO_ABI cpuinfo_get_uarchs_count(void);
2361
uint32_t CPUINFO_ABI cpuinfo_get_l1i_caches_count(void);
2362
uint32_t CPUINFO_ABI cpuinfo_get_l1d_caches_count(void);
2363
uint32_t CPUINFO_ABI cpuinfo_get_l2_caches_count(void);
2364
uint32_t CPUINFO_ABI cpuinfo_get_l3_caches_count(void);
2365
uint32_t CPUINFO_ABI cpuinfo_get_l4_caches_count(void);
2366
2367
/**
2368
 * Returns upper bound on cache size.
2369
 */
2370
uint32_t CPUINFO_ABI cpuinfo_get_max_cache_size(void);
2371
2372
/**
2373
 * Identify the logical processor that executes the current thread.
2374
 *
2375
 * There is no guarantee that the thread will stay on the same logical processor
2376
 * for any time. Callers should treat the result as only a hint, and be prepared
2377
 * to handle NULL return value.
2378
 */
2379
const struct cpuinfo_processor* CPUINFO_ABI cpuinfo_get_current_processor(void);
2380
2381
/**
2382
 * Identify the core that executes the current thread.
2383
 *
2384
 * There is no guarantee that the thread will stay on the same core for any
2385
 * time. Callers should treat the result as only a hint, and be prepared to
2386
 * handle NULL return value.
2387
 */
2388
const struct cpuinfo_core* CPUINFO_ABI cpuinfo_get_current_core(void);
2389
2390
/**
2391
 * Identify the microarchitecture index of the core that executes the current
2392
 * thread. If the system does not support such identification, the function
2393
 * returns 0.
2394
 *
2395
 * There is no guarantee that the thread will stay on the same type of core for
2396
 * any time. Callers should treat the result as only a hint.
2397
 */
2398
uint32_t CPUINFO_ABI cpuinfo_get_current_uarch_index(void);
2399
2400
/**
2401
 * Identify the microarchitecture index of the core that executes the current
2402
 * thread. If the system does not support such identification, the function
2403
 * returns the user-specified default value.
2404
 *
2405
 * There is no guarantee that the thread will stay on the same type of core for
2406
 * any time. Callers should treat the result as only a hint.
2407
 */
2408
uint32_t CPUINFO_ABI cpuinfo_get_current_uarch_index_with_default(uint32_t default_uarch_index);
2409
2410
#ifdef __cplusplus
2411
} /* extern "C" */
2412
#endif
2413
2414
#endif /* CPUINFO_H */