Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/winsup
diff options
context:
space:
mode:
authorBrian Inglis <Brian.Inglis@SystematicSW.ab.ca>2020-07-22 22:22:54 +0300
committerCorinna Vinschen <corinna@vinschen.de>2020-07-24 11:10:47 +0300
commit0947efb859110d0bbe4b6f1ddc9a762613e662a8 (patch)
tree5ae9040b13140dff5841c965eb8355d9dcd04767 /winsup
parent1c803a6d8864d6f7b2696099f44734914657aa7c (diff)
fhandler_proc.cc(format_proc_cpuinfo): add flags and TLB size
update to Linux-next 5.8 order fields and flags: add amd_dcm, arch_lbr, arch_perfmon, art, cpuid, extd_apicid, ibpb, ibrs, ibrs_enhanced, nonstop_tsc_s3, nopl, rep_good, ring3mwait, ssbd, stibp, tsc_known_freq, tsc_reliable, xtopology flags; add TLB size line; add ftuprint macro for feature test unconditional flag print; add commented out flags requiring CR or MSR access in print order with comment explaining issue; make cpuid leaf numbers consistent 8 hex digits for searching
Diffstat (limited to 'winsup')
-rw-r--r--winsup/cygwin/fhandler_proc.cc297
1 files changed, 255 insertions, 42 deletions
diff --git a/winsup/cygwin/fhandler_proc.cc b/winsup/cygwin/fhandler_proc.cc
index 2396bfe57..4bb8bea17 100644
--- a/winsup/cygwin/fhandler_proc.cc
+++ b/winsup/cygwin/fhandler_proc.cc
@@ -609,8 +609,10 @@ format_proc_stat (void *, char *&destbuf)
}
#define print(x) { bufptr = stpcpy (bufptr, (x)); }
+/* feature test unconditional print */
+#define ftuprint(msg) print (" " msg)
/* feature test bit position (0-32) and conditional print */
-#define ftcprint(feat,bitno,msg) if ((feat) & (1 << (bitno))) { print (" " msg); }
+#define ftcprint(feat,bitno,msg) if ((feat) & (1 << (bitno))) { ftuprint (msg); }
static inline uint32_t
get_msb (uint32_t in)
@@ -1021,8 +1023,8 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features1, 22, "acpi"); /* ACPI via MSR */
ftcprint (features1, 23, "mmx"); /* multimedia extensions */
ftcprint (features1, 24, "fxsr"); /* fxsave/fxrstor */
- ftcprint (features1, 25, "sse"); /* xmm */
- ftcprint (features1, 26, "sse2"); /* xmm2 */
+ ftcprint (features1, 25, "sse"); /* xmm sse */
+ ftcprint (features1, 26, "sse2"); /* xmm2 sse2 */
ftcprint (features1, 27, "ss"); /* CPU self snoop */
ftcprint (features1, 28, "ht"); /* hyper threading */
ftcprint (features1, 29, "tm"); /* acc automatic clock control */
@@ -1041,27 +1043,171 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features1, 25, "fxsr_opt"); /* fxsave/fxrstor optims */
ftcprint (features1, 26, "pdpe1gb"); /* GB large pages */
ftcprint (features1, 27, "rdtscp"); /* rdtscp */
- ftcprint (features1, 29, "lm"); /* long mode (x86 64) */
+ ftcprint (features1, 29, "lm"); /* long mode (x86-64 amd64) */
ftcprint (features1, 30, "3dnowext"); /* 3DNow extensions */
ftcprint (features1, 31, "3dnow"); /* 3DNow */
}
+
+ /* cpuid 0x80000007 edx */
+ if (maxe >= 0x80000007)
+ {
+ cpuid (&unused, &unused, &unused, &features1, 0x80000007);
+
+ ftcprint (features1, 8, "constant_tsc"); /* TSC ticks at a constant rate */
+ }
+
+/* ftcprint (features2, 9, "up"); *//* SMP kernel running on UP N/A */
+
+ /* cpuid 0x00000007 ebx */
+ if (maxf >= 0x00000007)
+ cpuid (&unused, &features1, &unused, &unused, 0x00000007, 0);
+ else
+ features1 = 0;
+ /* cpuid 0x80000007 edx */
+ if (maxe >= 0x80000007)
+ cpuid (&unused, &unused, &unused, &features2, 0x80000007);
+ else
+ features2 = 0;
+ uint32_t cr_den, cr_num, Hz;
+ /* cpuid 0x00000015 eax ebx ecx clock ratios optional Hz */
+ if (is_intel && maxf >= 0x00000015)
+ cpuid (&cr_den, &cr_num, &Hz, &unused, 0x00000015);
+ else
+ cr_den = 0;
+ /* TSC requires adjustment, nonstop, and clock ratio divider min */
+ if ((features1 & (1 << 1)) && /* TSC adjustment MSR 0x3B */
+ (features2 & (1 << 8)) && /* nonstop C states */
+ (cr_den > 1)) /* clock ratio denominator > min */
+ ftuprint ("art"); /* Always running timer (ART) */
+
+ /* Intel cpuid 0x0000000a eax Arch Perf Mon */
+ if (is_intel && maxf >= 0x0000000a)
+ {
+ cpuid (&features2, &unused, &unused, &unused, 0x0000000a);
+
+ /* rev > 0 and # counters/cpu > 1 */
+ if ((features2 & 0xff) > 0 && (((features2 >> 8) & 0xff) > 1))
+ ftuprint ("arch_perfmon"); /* Intel Arch Perf Mon */
+ }
+
+/* ftcprint (features2, 12, "pebs");*//* MSR_IA32_MISC_ENABLE 12 Precise-Event Based Sampling */
+/* ftcprint (features2, 13, "bts"); *//* MSR_IA32_MISC_ENABLE 11 Branch Trace Store */
+
+ /* AMD cpuid 0x00000001 eax */
+ if (is_amd && maxf >= 0x00000001)
+ cpuid(&features2, &unused, &unused, &unused, 0x00000001);
+ else
+ features2 = 0;
+
+/* Intel family 6 or AMD family >= x10 or ... */
+/* ... or AMD cpuid 0x00000001 eax in [0x0f58,) or [0x0f48,0x0f50) */
+ if ((is_intel && family == 6) ||
+ (is_amd && (family >= 0x10 ||
+ (features2 >= 0x0f58 ||
+ (features2 >= 0x0f48 && features2 < 0x0f50)))))
+ ftuprint ("rep_good"); /* REP microcode works well */
+
+ /* cpuid 0x80000007 edx Advanced power management */
+ if (maxe >= 0x80000007)
+ {
+ cpuid (&unused, &unused, &unused, &features2, 0x80000007);
+
+ ftcprint (features2, 12, "acc_power"); /* accum power */
+ }
+
+#if __x86_64__
+ ftuprint ("nopl"); /* NOPL (0F 1F) instructions */
+#endif
+
+/* cpuid 0x0000000b ecx[8:15] type */
+#define BAD_TYPE 0
+#define SMT_TYPE 1
+#define CORE_TYPE 2
+ /* cpuid 0x0000000b ebx ecx */
+ if (maxf >= 0x0000000b)
+ {
+ cpuid(&unused, &features1, &features2, &unused, 0x0000000b);
+
+ /* check if SMT implemented */
+ if (features1 != 0 && (((features2 >> 8) & 0xff) == SMT_TYPE))
+ ftuprint ("xtopology"); /* CPU topology enum extensions */
+ }
+
/* AMD cpuid 0x80000007 edx */
if (is_amd && maxe >= 0x80000007)
{
cpuid (&unused, &unused, &unused, &features1, 0x80000007);
- ftcprint (features1, 8, "constant_tsc"); /* TSC constant rate */
+ ftcprint (features1, 8, "tsc_reliable"); /* TSC constant rate */
ftcprint (features1, 8, "nonstop_tsc"); /* nonstop C states */
}
+
+ if (is_amd || is_intel)
+ ftuprint ("cpuid"); /* CPU has CPUID instruction */
+
+ if (is_amd && family > 0x16)
+ ftuprint ("extd_apicid"); /* Extended APICID (8 bits) */
+
+ /* AMD cpuid 0x8000001e ecx */
+ if (is_amd && maxe >= 0x8000001e)
+ {
+ cpuid (&unused, &unused, &features1, &unused, 0x8000001e);
+
+ if (((features1 >> 8) & 7) + 1 > 1) /* nodes/socket */
+ ftuprint ("amd_dcm"); /* AMD multi-node processor */
+ }
+
/* cpuid 0x00000006 ecx */
- if (maxf >= 0x06)
+ if (maxf >= 0x00000006)
{
- cpuid (&unused, &unused, &features1, &unused, 0x06);
+ cpuid (&unused, &unused, &features1, &unused, 0x00000006);
ftcprint (features1, 0, "aperfmperf"); /* P state hw coord fb */
}
+ /* Penwell, Cloverview, ... TSC doesn't sleep on S3 */
+ if (is_intel && family == 6)
+ switch (model)
+ {
+ case 0x27: /* Atom Saltwell Mid Penwell */
+ case 0x35: /* Atom Saltwell Tablet Cloverview */
+ case 0x4a: /* Atom Silvermont Mid Merriefield */
+ case 0x75: /* Atom Airmont NP Lightning Mountain */
+ ftuprint ("nonstop_tsc_s3"); /* TSC doesn't stop in S3 state */
+ break;
+ }
+
+ /* cpuid 0x00000015 eax ebx ecx clock ratios optional Hz */
+ if (is_intel && maxf >= 0x00000015)
+ {
+ uint32_t cr_den, cr_num, Hz, kHz;
+ cpuid (&cr_den, &cr_num, &Hz, &unused, 0x00000015);
+ if (cr_num != 0 && cr_den != 0)
+ {
+ kHz = Hz / 1000;
+ /* Denverton don't report hz nor support cpuid 0x16 so set 25MHz */
+ if (kHz == 0 && model == 0x5F) /* Atom Goldmont D Denverton */
+ kHz = 25000;
+
+ /* cpuid TSC frequency is known */
+ if (kHz != 0)
+ ftuprint ("tsc_known_freq"); /* TSC has known frequency */
+#if 0 /* keep for future and doc */
+ else /* kHz == 0 */
+ /* Skylake and Kabylake don't report clock so use CPU speed and ratio */
+ if (maxf >= 0x00000016)
+ {
+ uint32_t mHz;
+ cpuid(&mHz, &unused, &unused, &unused, 0x00000016);
+ kHz = mHz * 1000 * cr_num / cr_den;
+ }
+#endif
+ }
+ }
+
/* cpuid 0x00000001 ecx */
+ cpuid (&unused, &unused, &features2, &unused, 0x00000001);
+
ftcprint (features2, 0, "pni"); /* xmm3 sse3 */
ftcprint (features2, 1, "pclmuldq"); /* pclmulqdq instruction */
ftcprint (features2, 2, "dtes64"); /* 64-bit debug store */
@@ -1088,7 +1234,7 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features2, 24, "tsc_deadline_timer"); /* TSC deadline timer */
ftcprint (features2, 25, "aes"); /* AES instructions */
ftcprint (features2, 26, "xsave"); /* xsave/xrstor/xsetbv/xgetbv */
-/* ftcprint (features2, 27, "osxsave"); */ /* not output on Linux */
+/* ftcprint (features2, 27, "osxsave");*//* "" XSAVE supported in OS */
ftcprint (features2, 28, "avx"); /* advanced vector extensions */
ftcprint (features2, 29, "f16c"); /* 16 bit FP conversions */
ftcprint (features2, 30, "rdrand"); /* RNG rdrand instruction */
@@ -1133,34 +1279,49 @@ format_proc_cpuinfo (void *, char *&destbuf)
}
}
- /* features scattered in various CPUID levels. */
+ /* ring 3 monitor/mwait */
+ if (is_intel && family == 6)
+ switch (model)
+ {
+ case 0x57: /* Xeon Phi Knights Landing */
+ case 0x85: /* Xeon Phi Knights Mill */
+ ftuprint ("ring3mwait"); /* Ring 3 MONITOR/MWAIT instructions */
+ break;
+ }
+
+/* ftcprint (features1, 1, "cpuid_fault");*//* MSR_PLATFORM_INFO Intel CPUID faulting */
+
+/* features scattered in various CPUID levels. */
/* cpuid 0x80000007 edx */
- if (maxf >= 0x07)
+ if (maxf >= 0x00000007)
{
cpuid (&unused, &unused, &unused, &features1, 0x80000007);
ftcprint (features1, 9, "cpb"); /* core performance boost */
}
/* cpuid 0x00000006 ecx */
- if (maxf >= 0x06)
+ if (maxf >= 0x00000006)
{
- cpuid (&unused, &unused, &features1, &unused, 0x06);
+ cpuid (&unused, &unused, &features1, &unused, 0x00000006);
ftcprint (features1, 3, "epb"); /* energy perf bias */
}
/* cpuid 0x00000010 ebx */
- if (maxf >= 0x10)
+ if (maxf >= 0x00000010)
{
- cpuid (&unused, &features1, &unused, &unused, 0x10);
+ cpuid (&unused, &features1, &unused, &unused, 0x00000010);
ftcprint (features1, 1, "cat_l3"); /* cache alloc tech l3 */
ftcprint (features1, 2, "cat_l2"); /* cache alloc tech l2 */
/* cpuid 0x00000010:1 ecx */
- cpuid (&unused, &unused, &features1, &unused, 0x10, 1);
+ cpuid (&unused, &unused, &features1, &unused, 0x00000010, 1);
ftcprint (features1, 2, "cdp_l3"); /* code data prior l3 */
}
+
+/* ftcprint (features1, 7, "invpcid_single");*//* INVPCID && CR4.PCIDE=1 */
+
/* cpuid 0x80000007 edx */
if (maxe >= 0x80000007)
{
@@ -1176,51 +1337,87 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features1, 0, "sme"); /* secure memory encryption */
}
+
+/* ftcprint (features1, 11, "pti");*//* Page Table Isolation reqd with Meltdown */
+
+/* ftcprint (features1, 14, "intel_ppin");*//* MSR_PPIN_CTL Prot Proc Id No */
+
/* cpuid 0x00000010:2 ecx */
- if (maxf >= 0x10)
+ if (maxf >= 0x00000010)
{
- cpuid (&unused, &unused, &features1, &unused, 0x10, 2);
+ cpuid (&unused, &unused, &features2, &unused, 0x00000010, 2);
- ftcprint (features1, 2, "cdp_l2"); /* code data prior l2 */
+ ftcprint (features2, 2, "cdp_l2"); /* code data prior l2 */
+ }
+ /* cpuid 0x80000008 ebx */
+ if (maxe >= 0x80000008)
+ {
+ cpuid (&unused, &features1, &unused, &unused, 0x80000008, 0);
- /* cpuid 0x00000010 ebx */
- cpuid (&unused, &features1, &unused, &unused, 0x10);
+ ftcprint (features1, 24, "ssbd"); /* spec store byp dis */
+ }
+ /* cpuid 0x00000010 ebx */
+ if (maxf >= 0x00000010)
+ {
+ cpuid (&unused, &features2, &unused, &unused, 0x00000010);
- ftcprint (features1, 3, "mba"); /* memory bandwidth alloc */
+ ftcprint (features2, 3, "mba"); /* memory bandwidth alloc */
}
/* cpuid 0x80000008 ebx */
if (maxe >= 0x80000008)
{
- cpuid (&unused, &features1, &unused, &unused, 0x80000008);
-
+/* cpuid (&unused, &features1, &unused, &unused, 0x80000008, 0); */
+/* from above */
ftcprint (features1, 6, "mba"); /* memory bandwidth alloc */
}
/* cpuid 0x8000001f eax */
if (maxe >= 0x8000001f)
{
- cpuid (&features1, &unused, &unused, &unused, 0x8000001f);
+ cpuid (&features2, &unused, &unused, &unused, 0x8000001f);
- ftcprint (features1, 1, "sev"); /* secure encrypted virt */
+ ftcprint (features2, 1, "sev"); /* secure encrypted virt */
}
+ /* cpuid 0x80000008 ebx */
+ if (maxe >= 0x80000008)
+ {
+/* cpuid (&unused, &features1, &unused, &unused, 0x80000008, 0); */
+/* from above */
+/* ftcprint (features1, 0, "clzero"); *//* clzero instruction */
+/* ftcprint (features1, 1, "irperf"); *//* instr retired count */
+/* ftcprint (features1, 2, "xsaveerptr");*//* save/rest FP err ptrs */
+/* ftcprint (features1, 4, "rdpru"); *//* user level rd proc reg */
+/* ftcprint (features1, 6, "mba"); *//* memory BW alloc */
+/* ftcprint (features1, 9, "wbnoinvd"); *//* wbnoinvd instruction */
+ ftcprint (features1, 14, "ibrs"); /* ind br restricted spec */
+ ftcprint (features1, 12, "ibpb"); /* ind br pred barrier */
+ ftcprint (features1, 15, "stibp"); /* 1 thread ind br pred */
+ ftcprint (features1, 16, "ibrs_enhanced"); /* IBRS_ALL enhanced IBRS always on */
+/* ftcprint (features1, 17, "stibp_always_on"); */ /* stibp always on */
+/* ftcprint (features1, 18, "ibrs_pref");*//* IBRS_PREF IBRS preferred */
+/* ftcprint (features1, 23, "amd_ppin"); *//* protected proc id no */
+/* ftcprint (features1, 24, "ssbd"); *//* spec store byp dis */
+/* ftcprint (features1, 25, "virt_ssbd");*//* vir spec store byp dis */
+/* ftcprint (features1, 26, "ssb_no"); *//* ssb fixed in hardware */
+ }
/* cpuid 0x00000007 ebx */
- if (maxf >= 0x07)
+ if (maxf >= 0x00000007)
{
- cpuid (&unused, &features1, &unused, &unused, 0x07, 0);
+ cpuid (&unused, &features1, &unused, &unused, 0x00000007, 0);
ftcprint (features1, 0, "fsgsbase"); /* rd/wr fs/gs base */
ftcprint (features1, 1, "tsc_adjust"); /* TSC adjustment MSR 0x3B */
ftcprint (features1, 3, "bmi1"); /* bit manip ext group 1 */
ftcprint (features1, 4, "hle"); /* hardware lock elision */
ftcprint (features1, 5, "avx2"); /* AVX ext instructions */
-/* ftcprint (features1, 6, "fpdx"); */ /* FP data ptr upd on exc */
+/* ftcprint (features1, 6, "fpdx"); */ /* "" FP data ptr upd on exc */
ftcprint (features1, 7, "smep"); /* super mode exec prot */
ftcprint (features1, 8, "bmi2"); /* bit manip ext group 2 */
ftcprint (features1, 9, "erms"); /* enh rep movsb/stosb */
ftcprint (features1, 10, "invpcid"); /* inv proc context id */
ftcprint (features1, 11, "rtm"); /* restricted txnal mem */
ftcprint (features1, 12, "cqm"); /* cache QoS monitoring */
-/* ftcprint (features1, 13, "fpcsdsz"); */ /* zero FP cs/ds */
+/* ftcprint (features1, 13, "fpcsdsz"); */ /* "" zero FP cs/ds */
ftcprint (features1, 14, "mpx"); /* mem prot ext */
ftcprint (features1, 15, "rdt_a"); /* rsrc dir tech alloc */
ftcprint (features1, 16, "avx512f"); /* vec foundation */
@@ -1242,9 +1439,9 @@ format_proc_cpuinfo (void *, char *&destbuf)
/* more random feature flags */
/* cpuid 0x0000000d:1 eax */
- if (maxf >= 0x0d)
+ if (maxf >= 0x0000000d)
{
- cpuid (&features1, &unused, &unused, &unused, 0x0d, 1);
+ cpuid (&features1, &unused, &unused, &unused, 0x0000000d, 1);
ftcprint (features1, 0, "xsaveopt"); /* xsaveopt instruction */
ftcprint (features1, 1, "xsavec"); /* xsavec instruction */
@@ -1252,23 +1449,26 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features1, 3, "xsaves"); /* xsaves/xrstors */
}
/* cpuid 0x0000000f edx */
- if (maxf >= 0x0f)
+ if (maxf >= 0x0000000f)
{
- cpuid (&unused, &unused, &unused, &features1, 0x0f);
+ cpuid (&unused, &unused, &unused, &features1, 0x0000000f);
ftcprint (features1, 1, "cqm_llc"); /* llc QoS */
/* cpuid 0x0000000f:1 edx */
- cpuid (&unused, &unused, &unused, &features1, 0x0f, 1);
+ cpuid (&unused, &unused, &unused, &features1, 0x0000000f, 1);
ftcprint (features1, 0, "cqm_occup_llc"); /* llc occup monitor */
ftcprint (features1, 1, "cqm_mbm_total"); /* llc total MBM mon */
ftcprint (features1, 2, "cqm_mbm_local"); /* llc local MBM mon */
}
+
+/* ftcprint (features1, 6, "split_lock_detect");*//* MSR_TEST_CTRL split lock */
+
/* cpuid 0x00000007:1 eax */
- if (maxf >= 0x07)
+ if (maxf >= 0x00000007)
{
- cpuid (&features1, &unused, &unused, &unused, 0x07, 1);
+ cpuid (&features1, &unused, &unused, &unused, 0x00000007, 1);
ftcprint (features1, 5, "avx512_bf16"); /* vec bfloat16 short */
}
@@ -1287,7 +1487,9 @@ format_proc_cpuinfo (void *, char *&destbuf)
/* ftcprint (features1, 12, "ibpb" ); */ /* ind br pred barrier */
/* ftcprint (features1, 14, "ibrs" ); */ /* ind br restricted spec */
/* ftcprint (features1, 15, "stibp"); */ /* 1 thread ind br pred */
+/* ftcprint (features1, 16, "ibrs_enhanced");*//* IBRS_ALL enhanced IBRS always on */
/* ftcprint (features1, 17, "stibp_always_on"); */ /* stibp always on */
+/* ftcprint (features1, 18, "ibrs_pref");*//* IBRS_PREF IBRS preferred */
ftcprint (features1, 23, "amd_ppin"); /* protected proc id no */
/* ftcprint (features1, 24, "ssbd"); */ /* spec store byp dis */
ftcprint (features1, 25, "virt_ssbd"); /* vir spec store byp dis */
@@ -1295,9 +1497,9 @@ format_proc_cpuinfo (void *, char *&destbuf)
}
/* thermal & power cpuid 0x00000006 eax */
- if (maxf >= 0x06)
+ if (maxf >= 0x00000006)
{
- cpuid (&features1, &unused, &features2, &unused, 0x06);
+ cpuid (&features1, &unused, &features2, &unused, 0x00000006);
ftcprint (features1, 0, "dtherm"); /* digital thermal sensor */
ftcprint (features1, 1, "ida"); /* Intel dynamic acceleration */
@@ -1332,9 +1534,9 @@ format_proc_cpuinfo (void *, char *&destbuf)
}
/* Intel cpuid 0x00000007 ecx */
- if (is_intel && maxf >= 0x07)
+ if (is_intel && maxf >= 0x00000007)
{
- cpuid (&unused, &unused, &features1, &unused, 0x07, 0);
+ cpuid (&unused, &unused, &features1, &unused, 0x00000007, 0);
ftcprint (features1, 1, "avx512vbmi"); /* vec bit manip */
ftcprint (features1, 2, "umip"); /* user mode ins prot */
@@ -1367,9 +1569,9 @@ format_proc_cpuinfo (void *, char *&destbuf)
}
/* Intel cpuid 0x00000007 edx */
- if (is_intel && maxf >= 0x07)
+ if (is_intel && maxf >= 0x00000007)
{
- cpuid (&unused, &unused, &unused, &features1, 0x07, 0);
+ cpuid (&unused, &unused, &unused, &features1, 0x00000007, 0);
ftcprint (features1, 2, "avx512_4vnniw"); /* vec dot prod dw */
ftcprint (features1, 3, "avx512_4fmaps"); /* vec 4 FMA single */
@@ -1377,6 +1579,7 @@ format_proc_cpuinfo (void *, char *&destbuf)
ftcprint (features1, 8, "avx512_vp2intersect"); /* vec intcpt d/q */
ftcprint (features1, 10, "md_clear"); /* verw clear buf */
ftcprint (features1, 18, "pconfig"); /* platform config */
+ ftcprint (features1, 19, "arch_lbr"); /* last branch records */
ftcprint (features1, 28, "flush_l1d"); /* flush l1d cache */
ftcprint (features1, 29, "arch_capabilities"); /* arch cap MSR */
}
@@ -1386,6 +1589,16 @@ format_proc_cpuinfo (void *, char *&destbuf)
bufptr += __small_sprintf (bufptr, "bogomips\t: %d.00\n",
bogomips);
+ /* cpuid 0x80000006 ebx TLB size */
+ if (maxe >= 0x80000006)
+ {
+ cpuid( &unused, &features1, &unused, &unused, 0x80000006, 0);
+ uint32_t tlbsize = ((features1 >> 16) & 0xfff) + (features1 & 0xfff);
+ if (tlbsize > 0)
+ bufptr += __small_sprintf (bufptr, "TLB size\t: %d 4K pages\n",
+ tlbsize);
+ }
+
bufptr += __small_sprintf (bufptr, "clflush size\t: %d\n"
"cache_alignment\t: %d\n",
clflush,