Commit c9345f68 authored by Ahmed Samy's avatar Ahmed Samy

cpuid: parse CPU L1 cache and TLB identifications

Signed-off-by: default avatarAhmed Samy <f.fallen45@gmail.com>
parent 2df53ae1
......@@ -260,6 +260,10 @@ void cpuid(cpuid_t info, uint32_t *buf)
buf[1] = ecx;
break;
case CPU_L1_CACHE_AND_TLB_IDS:
buf[0] = eax;
buf[1] = ebx;
buf[2] = ecx;
buf[3] = edx;
break;
case CPU_EXTENDED_L2_CACHE_FEATURES:
*buf = ecx;
......
......@@ -182,6 +182,23 @@ uint32_t cpuid_highest_ext_func_supported(void);
* buf[3]:
* Additional feature information.
*
* For CPU_L1_CACHE_AND_TLB_IDS:
* buf[0]: (eax):
* - 7..0 Number of times to exec cpuid to get all descriptors.
* - 15..8 Instruction TLB: 4K Pages, 4-way set associtive, 128 entries.
* - 23..16 Data TLB: 4k Pages, 4-way set associtive, 128 entries.
* - 24..31 Instruction TLB: 4K Pages, 4-way set associtive, 2 entries.
* buf[1]: (ebx):
* - 7..0 64-byte prefetching
* - 8..31 Null descriptor
* buf[2]: (ecx):
* - 0..31 Null descriptor
* buf[3]: (edx):
* - 7..0 2nd-level cache, 2M, 8-way set associtive, 64-byte line size
* - 15..8 1st-level instruction cache: 32K, 8-way set associtive, 64 byte line size
* - 16..23 Data TLB: 4M Pages, 4-way set associtive, 8 entires.
* - 24..31 1st-level data cache: 32K, 8-way set associtive, 64 byte line size
*
* For CPU_HIGHEST_EXTENDED_FUNCTION_SUPPORTED:
* Returns the highest supported function in *buf (expects an integer ofc)
*
......@@ -194,6 +211,9 @@ uint32_t cpuid_highest_ext_func_supported(void);
* For CPU_PROC_BRAND_STRING:
* Have a char array with at least 48 bytes assigned to it.
*
* Here's a page which will help you parse the data provided by this function.
* http://www.flounder.com/cpuid_explorer2.htm
*
* If an invalid flag has been passed a 0xbaadf00d is returned in *buf.
*/
void cpuid(cpuid_t info, uint32_t *buf);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment