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();