summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Intel/bluesmoke.c67
1 files changed, 38 insertions, 29 deletions
diff --git a/Intel/bluesmoke.c b/Intel/bluesmoke.c
index e1813e6..5efd606 100644
--- a/Intel/bluesmoke.c
+++ b/Intel/bluesmoke.c
@@ -23,34 +23,13 @@
#define MC_STATUS 0x0401
#define MC_ADDR 0x402
-void decode_Intel_bluesmoke(int cpunum, int family)
+static int nr_msr_banks;
+
+static void decode_mcg_ctl(int cpunum)
{
unsigned long long val, val2;
- int banks, i, extcount = 0, ctlp = 0;
-
- if (!user_is_root)
- return;
- if (read_msr(cpunum, MCG_CAP, &val) != 1)
- return;
-
- banks = val & 0xff;
-
- printf("\nNumber of reporting banks : %d\n\n", banks);
-
- if (family == 0xf) {
- if ((val & (1<<MCG_EXT_PBIT))) {
- extcount = (val >> 16) & 0xff;
- printf("Number of extended MC registers : %d\n\n", extcount);
- }
- else
- printf("Erk, MCG_EXT not present! :%016llx:\n", val);
- }
- else
- ctlp = val & (1<<MCG_CTL_PBIT);
- if (ctlp == 0)
- printf("Erk, MCG_CTL not present! :%016llx:\n", val);
- else if (read_msr(cpunum, MCG_CTL, &val) == 1) {
+ if (read_msr(cpunum, MCG_CTL, &val) == 1) {
printf("MCG_CTL:\n");
printf(" Data cache check %sabled\n", val & (1<<0) ? "en" : "dis");
@@ -67,7 +46,7 @@ void decode_Intel_bluesmoke(int cpunum, int family)
}
printf(" Instruction cache check %sabled\n", val & (1<<1) ? "en" : "dis");
- if (((val & (1<<1)) == 2) && (banks>1)) {
+ if (((val & (1<<1)) == 2) && (nr_msr_banks>1)) {
if (read_msr(cpunum, MC_CTL+4, &val2) == 1) {
printf(" ECC 1 bit error reporting %sabled\n", val2 & (1<<0) ? "en" : "dis");
printf(" ECC multi bit error reporting %sabled\n", val2 & (1<<1) ? "en" : "dis");
@@ -83,7 +62,7 @@ void decode_Intel_bluesmoke(int cpunum, int family)
}
printf(" Bus unit check %sabled\n", val & (1<<2) ? "en" : "dis");
- if ((val & (1<<2)) == 4 && (banks>2)) {
+ if ((val & (1<<2)) == 4 && (nr_msr_banks>2)) {
if (read_msr(cpunum, MC_CTL+8, &val2) == 1) {
printf(" External L2 tag parity error %sabled\n", val2 & (1<<0) ? "en" : "dis");
printf(" L2 partial tag parity error %sabled\n", val2 & (1<<1) ? "en" : "dis");
@@ -96,7 +75,7 @@ void decode_Intel_bluesmoke(int cpunum, int family)
}
printf(" Load/Store unit check %sabled\n", val & (1<<3) ? "en" : "dis");
- if ((val & (1<<3)) == 8 && (banks>3)) {
+ if ((val & (1<<3)) == 8 && (nr_msr_banks>3)) {
if (read_msr(cpunum, MC_CTL+12, &val2) == 1) {
printf(" Read data error enable (loads) %sabled\n", val2 & (1<<0) ? "en" : "dis");
printf(" Read data error enable (stores) %sabled\n", val2 & (1<<1) ? "en" : "dis");
@@ -104,8 +83,38 @@ void decode_Intel_bluesmoke(int cpunum, int family)
}
}
printf("\n");
+}
+
+
+void decode_Intel_bluesmoke(int cpunum, int family)
+{
+ unsigned long long val;
+ int i, extcount = 0;
+
+ if (!user_is_root)
+ return;
+
+ if (read_msr(cpunum, MCG_CAP, &val) != 1)
+ return;
+
+ nr_msr_banks = val & 0xff;
+
+ printf("Machine check MSRs:\n");
+ printf("Number of reporting banks : %d\n\n", nr_msr_banks);
+
+ if (family == 0xf) {
+ if ((val & (1<<MCG_EXT_PBIT))) {
+ extcount = (val >> 16) & 0xff;
+ printf("Number of extended MC registers : %d\n\n", extcount);
+ }
+ else
+ printf("Erk, MCG_EXT not present! :%016llx:\n", val);
+ }
+ else
+ if (val & (1<<MCG_CTL_PBIT))
+ decode_mcg_ctl(cpunum);
- for (i=0; i<banks; i++) {
+ for (i=0; i < nr_msr_banks; i++) {
printf("Bank: %d (0x%x)\n", i, (unsigned int)MC_CTL+i*4);
printf("MC%dCTL: ", i);
dumpmsr_bin (cpunum, MC_CTL+i*4, 64);