libcpuid
libcpuid_constants.h
1/*
2 * Copyright 2008 Veselin Georgiev,
3 * anrieffNOSPAM @ mgail_DOT.com (convert to gmail)
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
19 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */
32#ifndef __LIBCPUID_CONSTANTS_H__
33#define __LIBCPUID_CONSTANTS_H__
34
35#define VENDOR_STR_MAX 16
36#define BRAND_STR_MAX 64
37#define CODENAME_STR_MAX 64
38#define CPU_FLAGS_MAX 384
39#define MAX_CPUID_LEVEL 32
40#define MAX_EXT_CPUID_LEVEL 32
41#define MAX_INTELFN4_LEVEL 8
42#define MAX_INTELFN11_LEVEL 4
43#define MAX_INTELFN12H_LEVEL 4
44#define MAX_INTELFN14H_LEVEL 4
45#define MAX_AMDFN8000001DH_LEVEL 4
46#define MAX_AMDFN80000026H_LEVEL 4
47#define MAX_ARM_ID_AFR_REGS 1
48#define MAX_ARM_ID_DFR_REGS 2
49#define MAX_ARM_ID_ISAR_REGS 7
50#define MAX_ARM_ID_MMFR_REGS 6
51#define MAX_ARM_ID_PFR_REGS 3
52#define MAX_ARM_ID_AA64AFR_REGS 2
53#define MAX_ARM_ID_AA64DFR_REGS 2
54#define MAX_ARM_ID_AA64ISAR_REGS 3
55#define MAX_ARM_ID_AA64MMFR_REGS 5
56#define MAX_ARM_ID_AA64PFR_REGS 3
57#define MAX_ARM_ID_AA64SMFR_REGS 1
58#define MAX_ARM_ID_AA64ZFR_REGS 1
59#define CPU_HINTS_MAX 16
60#define SGX_FLAGS_MAX 14
61#define ADDRESS_EXT_CPUID_START 0x80000000
62#define ADDRESS_EXT_CPUID_END ADDRESS_EXT_CPUID_START + MAX_EXT_CPUID_LEVEL
63
64typedef enum {
65 EAX,
66 EBX,
67 ECX,
68 EDX,
69 /* termination: */
70 NUM_REGS,
71} cpu_registers_t;
72
73#endif /* __LIBCPUID_CONSTANTS_H__ */