123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- #include "cpu.h"
- #include "kprint.h"
- #include "printk.h"
- uint Cpu_cpuid_max_Basic_mop;
- uint Cpu_cpuid_max_Extended_mop;
- char Cpu_Manufacturer_Name[17] = {0};
- char Cpu_BrandName[49] = {0};
- uint Cpu_Family_ID;
- uint Cpu_Extended_Family_ID;
- uint Cpu_Model_ID;
- uint Cpu_Extended_Model_ID;
- uint Cpu_Stepping_ID;
- uint Cpu_Processor_Type;
- uint Cpu_max_phys_addrline_size;
- uint Cpu_max_linear_addrline_size;
- struct cpu_core_info_t cpu_core_info[MAX_CPU_NUM];
- void cpu_init(void)
- {
-
- uint tmp_info[4] = {0};
- cpu_cpuid(0, 0, &tmp_info[0], &tmp_info[1], &tmp_info[2], &tmp_info[3]);
-
- Cpu_cpuid_max_Basic_mop = tmp_info[0];
-
- *(uint *)&Cpu_Manufacturer_Name[0] = tmp_info[1];
- *(uint *)&Cpu_Manufacturer_Name[4] = tmp_info[3];
- *(uint *)&Cpu_Manufacturer_Name[8] = tmp_info[2];
- Cpu_Manufacturer_Name[12] = '\0';
- kinfo("CPU manufacturer: %s", Cpu_Manufacturer_Name);
-
- int count = 0;
- for (uint i = 0x80000002; i < 0x80000005; ++i)
- {
- cpu_cpuid(i, 0, &tmp_info[0], &tmp_info[1], &tmp_info[2], &tmp_info[3]);
- for (int j = 0; j <= 3; ++j)
- {
- *(uint *)&Cpu_BrandName[4 * count] = tmp_info[j];
- ++count;
- }
- }
- Cpu_BrandName[48] = '\0';
- kinfo("CPU Brand Name: %s", Cpu_BrandName);
-
- cpu_cpuid(1, 0, &tmp_info[0], &tmp_info[1], &tmp_info[2], &tmp_info[3]);
-
- Cpu_Stepping_ID = tmp_info[0] & 0xf;
- Cpu_Model_ID = (tmp_info[0] >> 4) & 0xf;
- Cpu_Family_ID = (tmp_info[0] >> 8) & 0xf;
- Cpu_Processor_Type = (tmp_info[0] >> 12) & 0x3;
-
- Cpu_Extended_Model_ID = (tmp_info[0] >> 16) & 0xf;
- Cpu_Extended_Family_ID = (tmp_info[0] >> 20) & 0xff;
-
- kinfo("Family ID=%#03lx\t Extended Family ID=%#03lx\t Processor Type=%#03lx\t", Cpu_Family_ID, Cpu_Extended_Family_ID, Cpu_Processor_Type);
- kinfo("Model ID=%#03lx\t Extended Model ID=%#03lx\tStepping ID=%#03lx\t", Cpu_Model_ID, Cpu_Extended_Model_ID, Cpu_Stepping_ID);
-
- cpu_cpuid(0x80000008, 0, &tmp_info[0], &tmp_info[1], &tmp_info[2], &tmp_info[3]);
- Cpu_max_phys_addrline_size = tmp_info[0] & 0xff;
- Cpu_max_linear_addrline_size = (tmp_info[0] >> 8) & 0xff;
- kinfo("Cpu_max_phys_addrline_size = %d", Cpu_max_phys_addrline_size);
- kinfo("Cpu_max_linear_addrline_size = %d", Cpu_max_linear_addrline_size);
- cpu_cpuid(0x80000000, 0, &tmp_info[0], &tmp_info[1], &tmp_info[2], &tmp_info[3]);
- Cpu_cpuid_max_Extended_mop = tmp_info[0];
- kinfo("Max basic mop=%#05lx", Cpu_cpuid_max_Basic_mop);
- kinfo("Max extended mop=%#05lx", Cpu_cpuid_max_Extended_mop);
- return;
- }
- void cpu_cpuid(uint32_t mop, uint32_t sop, uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx)
- {
-
-
- __asm__ __volatile__("cpuid \n\t"
- : "=a"(*eax), "=b"(*ebx), "=c"(*ecx), "=d"(*edx)
- : "0"(mop), "2"(sop)
- : "memory");
- }
- uint32_t cpu_get_core_crysral_freq()
- {
- uint32_t a = 0, b = 0, c = 0, d = 0;
-
- __asm__ __volatile__("cpuid \n\t"
- : "=a"(a), "=b"(b), "=c"(c), "=d"(d)
- : "0"(0x15), "2"(0)
- : "memory");
-
-
- return c;
- }
|