2020-06-15 14:18:57 +00:00
|
|
|
#ifndef COSMOPOLITAN_LIBC_NEXGEN32E_KCPUIDS_H_
|
|
|
|
#define COSMOPOLITAN_LIBC_NEXGEN32E_KCPUIDS_H_
|
|
|
|
|
|
|
|
#define KCPUIDS_0H 0
|
|
|
|
#define KCPUIDS_1H 1
|
|
|
|
#define KCPUIDS_2H 2
|
|
|
|
#define KCPUIDS_7H 3
|
|
|
|
#define KCPUIDS_80000001H 4
|
|
|
|
#define KCPUIDS_80000007H 5
|
|
|
|
#define KCPUIDS_16H 6
|
2020-08-25 11:23:25 +00:00
|
|
|
#define KCPUIDS_LEN 7
|
2020-06-15 14:18:57 +00:00
|
|
|
#define KCPUIDS_6H -1 /* TBD: Thermal and Power Management */
|
|
|
|
#define KCPUIDS_DH -1 /* TBD: Extended state features */
|
|
|
|
#define KCPUIDS_80000008H -1 /* TBD: AMD Miscellaneous */
|
|
|
|
#define KCPUIDS_8000000AH -1 /* TBD: AMD SVM */
|
|
|
|
|
|
|
|
#define KCPUIDS_EAX 0
|
|
|
|
#define KCPUIDS_EBX 1
|
|
|
|
#define KCPUIDS_ECX 2
|
|
|
|
#define KCPUIDS_EDX 3
|
|
|
|
|
|
|
|
#define KCPUIDS(LEAF, REG) _KCPUIDS(LEAF, REG)
|
|
|
|
#ifdef __ASSEMBLER__
|
|
|
|
#define _KCPUIDS(LEAF, REG) KCPUIDS_##LEAF * 16 + KCPUIDS_##REG * 4
|
|
|
|
#else
|
|
|
|
#define _KCPUIDS(LEAF, REG) kCpuids[KCPUIDS_##LEAF][KCPUIDS_##REG]
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
|
|
COSMOPOLITAN_C_START_
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Globally precomputed x86 CPUID values.
|
|
|
|
*
|
|
|
|
* @note Referencing Is Initialization (RII)
|
|
|
|
* @note Protected with PIRO
|
|
|
|
* @see X86_HAVE()
|
|
|
|
*/
|
2020-08-25 11:23:25 +00:00
|
|
|
extern const unsigned kCpuids[KCPUIDS_LEN][4];
|
2020-06-15 14:18:57 +00:00
|
|
|
|
|
|
|
COSMOPOLITAN_C_END_
|
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
#endif /* COSMOPOLITAN_LIBC_NEXGEN32E_KCPUIDS_H_ */
|