1 #pragma once 2 3 #include "glib.h" 4 5 #define MAX_CPU_NUM 32 // 操作系统支持的最大处理器数量 6 7 // cpu支持的最大cpuid指令的基础主功能号 8 extern uint32_t Cpu_cpuid_max_Basic_mop; 9 // cpu支持的最大cpuid指令的扩展主功能号 10 extern uint32_t Cpu_cpuid_max_Extended_mop; 11 // cpu制造商信息 12 extern char Cpu_Manufacturer_Name[17]; 13 // 处理器名称信息 14 extern char Cpu_BrandName[49]; 15 // 处理器家族ID 16 extern uint32_t Cpu_Family_ID; 17 // 处理器扩展家族ID 18 extern uint32_t Cpu_Extended_Family_ID; 19 // 处理器模式ID 20 extern uint32_t Cpu_Model_ID; 21 // 处理器扩展模式ID 22 extern uint32_t Cpu_Extended_Model_ID; 23 // 处理器步进ID 24 extern uint32_t Cpu_Stepping_ID; 25 // 处理器类型 26 extern uint32_t Cpu_Processor_Type; 27 // 处理器支持的最大物理地址可寻址地址线宽度 28 extern uint32_t Cpu_max_phys_addrline_size; 29 // 处理器支持的最大线性地址可寻址地址线宽度 30 extern uint32_t Cpu_max_linear_addrline_size; 31 32 // 处理器的tsc频率(单位:hz)(HPET定时器在测定apic频率时,顺便测定了这个值) 33 extern uint64_t Cpu_tsc_freq; 34 35 /** 36 * @brief 执行cpuid指令 37 * 38 * @param mop 主功能号 39 * @param sop 子功能号 40 * @param eax 结果的eax值 41 * @param ebx 结果的ebx值 42 * @param ecx 结果的ecx值 43 * @param edx 结果的edx值 44 * 45 * cpuid指令参考英特尔开发手册卷2A Chapter3 3.2 Instruction 46 */ 47 void cpu_cpuid(uint32_t mop, uint32_t sop, uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx); 48 49 /** 50 * @brief 初始化获取处理器信息模块 51 * 52 */ 53 void cpu_init(void); 54 55 struct cpu_core_info_t 56 { 57 uint64_t stack_start; // 栈基地址 58 uint64_t ist_stack_start; // IST栈基地址 59 uint64_t tss_vaddr; // tss地址 60 }; 61 62 extern struct cpu_core_info_t cpu_core_info[MAX_CPU_NUM]; 63 64 /** 65 * @brief 获取当前cpu核心晶振频率 66 * 67 * @return uint32_t 当前cpu核心晶振频率 68 */ 69 uint32_t cpu_get_core_crysral_freq(); 70 71 /** 72 * @brief 获取处理器的tsc频率(单位:hz) 73 * 74 * @return uint64_t 75 */ 76 uint64_t cpu_get_tsc_freq();