// // Created by rick on 12-02-21. // #ifndef NEW_KERNEL_CPUIDX_H #define NEW_KERNEL_CPUIDX_H #include typedef struct { bool sse3: 1; bool pclmul: 1; bool dtes64: 1; bool monitor: 1; bool ds_cpl: 1; bool vmx: 1; bool smx: 1; bool est: 1; bool tm2: 1; bool ssse3: 1; bool cid: 1; bool reserved: 1; bool fma: 1; bool cx16: 1; bool etprd: 1; bool pdcm: 1; bool pcide: 1; bool dca: 1; bool sse4_1: 1; bool sse4_2: 1; bool x2APIC: 1; bool movbe: 1; bool popcnt: 1; bool reserved2: 1; bool aes: 1; bool xsave: 1; bool osxsave: 1; bool avx: 1; } cpu_features_ecx; typedef struct { bool fpu: 1; bool vme: 1; bool de: 1; bool pse: 1; bool tsc: 1; bool msr: 1; bool pae: 1; bool mce: 1; bool cx8: 1; bool apic: 1; bool reserved: 1; bool sep: 1; bool mtrr: 1; bool pge: 1; bool mca: 1; bool cmov: 1; bool pat: 1; bool pse36: 1; bool psn: 1; bool clf: 1; bool reserved2: 1; bool dtes: 1; bool acpi: 1; bool mmx: 1; bool fxsr: 1; bool sse: 1; bool sse2: 1; bool ss: 1; bool htt: 1; bool tm1: 1; bool ia64: 1; bool pbe: 1; } cpu_features_edx; enum cpu_features { CPUID_FEAT_ECX_SSE3 = 1 << 0, CPUID_FEAT_ECX_PCLMUL = 1 << 1, CPUID_FEAT_ECX_DTES64 = 1 << 2, CPUID_FEAT_ECX_MONITOR = 1 << 3, CPUID_FEAT_ECX_DS_CPL = 1 << 4, CPUID_FEAT_ECX_VMX = 1 << 5, CPUID_FEAT_ECX_SMX = 1 << 6, CPUID_FEAT_ECX_EST = 1 << 7, CPUID_FEAT_ECX_TM2 = 1 << 8, CPUID_FEAT_ECX_SSSE3 = 1 << 9, CPUID_FEAT_ECX_CID = 1 << 10, CPUID_FEAT_ECX_FMA = 1 << 12, CPUID_FEAT_ECX_CX16 = 1 << 13, CPUID_FEAT_ECX_ETPRD = 1 << 14, CPUID_FEAT_ECX_PDCM = 1 << 15, CPUID_FEAT_ECX_PCIDE = 1 << 17, CPUID_FEAT_ECX_DCA = 1 << 18, CPUID_FEAT_ECX_SSE4_1 = 1 << 19, CPUID_FEAT_ECX_SSE4_2 = 1 << 20, CPUID_FEAT_ECX_x2APIC = 1 << 21, CPUID_FEAT_ECX_MOVBE = 1 << 22, CPUID_FEAT_ECX_POPCNT = 1 << 23, CPUID_FEAT_ECX_AES = 1 << 25, CPUID_FEAT_ECX_XSAVE = 1 << 26, CPUID_FEAT_ECX_OSXSAVE = 1 << 27, CPUID_FEAT_ECX_AVX = 1 << 28, CPUID_FEAT_EDX_FPU = 1 << 0, CPUID_FEAT_EDX_VME = 1 << 1, CPUID_FEAT_EDX_DE = 1 << 2, CPUID_FEAT_EDX_PSE = 1 << 3, CPUID_FEAT_EDX_TSC = 1 << 4, CPUID_FEAT_EDX_MSR = 1 << 5, CPUID_FEAT_EDX_PAE = 1 << 6, CPUID_FEAT_EDX_MCE = 1 << 7, CPUID_FEAT_EDX_CX8 = 1 << 8, CPUID_FEAT_EDX_APIC = 1 << 9, CPUID_FEAT_EDX_SEP = 1 << 11, CPUID_FEAT_EDX_MTRR = 1 << 12, CPUID_FEAT_EDX_PGE = 1 << 13, CPUID_FEAT_EDX_MCA = 1 << 14, CPUID_FEAT_EDX_CMOV = 1 << 15, CPUID_FEAT_EDX_PAT = 1 << 16, CPUID_FEAT_EDX_PSE36 = 1 << 17, CPUID_FEAT_EDX_PSN = 1 << 18, CPUID_FEAT_EDX_CLF = 1 << 19, CPUID_FEAT_EDX_DTES = 1 << 21, CPUID_FEAT_EDX_ACPI = 1 << 22, CPUID_FEAT_EDX_MMX = 1 << 23, CPUID_FEAT_EDX_FXSR = 1 << 24, CPUID_FEAT_EDX_SSE = 1 << 25, CPUID_FEAT_EDX_SSE2 = 1 << 26, CPUID_FEAT_EDX_SS = 1 << 27, CPUID_FEAT_EDX_HTT = 1 << 28, CPUID_FEAT_EDX_TM1 = 1 << 29, CPUID_FEAT_EDX_IA64 = 1 << 30, CPUID_FEAT_EDX_PBE = 1 << 31 }; void cpuidx_print_info(); #endif //NEW_KERNEL_CPUIDX_H