cpu.h 1.9 KB

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