cpu.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #pragma once
  2. #include "glib.h"
  3. #define MAX_CPU_NUM 32 // 操作系统支持的最大处理器数量
  4. // cpu支持的最大cpuid指令的基础主功能号
  5. uint Cpu_cpuid_max_Basic_mop;
  6. // cpu支持的最大cpuid指令的扩展主功能号
  7. uint Cpu_cpuid_max_Extended_mop;
  8. // cpu制造商信息
  9. char Cpu_Manufacturer_Name[17]={0};
  10. // 处理器名称信息
  11. char Cpu_BrandName[49] = {0};
  12. // 处理器家族ID
  13. uint Cpu_Family_ID;
  14. // 处理器扩展家族ID
  15. uint Cpu_Extended_Family_ID;
  16. // 处理器模式ID
  17. uint Cpu_Model_ID;
  18. // 处理器扩展模式ID
  19. uint Cpu_Extended_Model_ID;
  20. // 处理器步进ID
  21. uint Cpu_Stepping_ID;
  22. // 处理器类型
  23. uint Cpu_Processor_Type;
  24. // 处理器支持的最大物理地址可寻址地址线宽度
  25. uint Cpu_max_phys_addrline_size;
  26. // 处理器支持的最大线性地址可寻址地址线宽度
  27. uint Cpu_max_linear_addrline_size;
  28. /**
  29. * @brief 执行cpuid指令
  30. *
  31. * @param mop 主功能号
  32. * @param sop 子功能号
  33. * @param eax 结果的eax值
  34. * @param ebx 结果的ebx值
  35. * @param ecx 结果的ecx值
  36. * @param edx 结果的edx值
  37. *
  38. * cpuid指令参考英特尔开发手册卷2A Chapter3 3.2 Instruction
  39. */
  40. void cpu_cpuid(uint mop, uint sop, uint *eax, uint*ebx, uint*ecx, uint*edx)
  41. {
  42. // 向eax和ecx分别输入主功能号和子功能号
  43. // 结果输出到eax, ebx, ecx, edx
  44. __asm__ __volatile__("cpuid \n\t":"=a"(*eax),"=b"(*ebx), "=c"(*ecx), "=d"(*edx):"0"(mop),"2"(sop):"memory");
  45. }
  46. /**
  47. * @brief 初始化获取处理器信息模块
  48. *
  49. */
  50. void cpu_init(void);
  51. struct cpu_core_info
  52. {
  53. uint64_t stack_start; // 栈基地址
  54. uint64_t ist_stack_start; // IST栈基地址
  55. uint64_t tss_vaddr; // tss地址
  56. }cpu_core_info[MAX_CPU_NUM];