Commit cda6618d authored by Mahesh Salgaonkar's avatar Mahesh Salgaonkar Committed by Michael Ellerman

powerpc/powernv/mce: Print correct severity for MCE error.

Currently all machine check errors are printed as severe errors which
isn't correct. Print soft errors as warning instead of severe errors.
Signed-off-by: default avatarMahesh Salgaonkar <mahesh@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent d6e8a150
...@@ -31,7 +31,7 @@ enum MCE_Version { ...@@ -31,7 +31,7 @@ enum MCE_Version {
enum MCE_Severity { enum MCE_Severity {
MCE_SEV_NO_ERROR = 0, MCE_SEV_NO_ERROR = 0,
MCE_SEV_WARNING = 1, MCE_SEV_WARNING = 1,
MCE_SEV_ERROR_SYNC = 2, MCE_SEV_SEVERE = 2,
MCE_SEV_FATAL = 3, MCE_SEV_FATAL = 3,
}; };
...@@ -110,73 +110,74 @@ enum MCE_LinkErrorType { ...@@ -110,73 +110,74 @@ enum MCE_LinkErrorType {
}; };
struct machine_check_event { struct machine_check_event {
enum MCE_Version version:8; /* 0x00 */ enum MCE_Version version:8;
uint8_t in_use; /* 0x01 */ u8 in_use;
enum MCE_Severity severity:8; /* 0x02 */ enum MCE_Severity severity:8;
enum MCE_Initiator initiator:8; /* 0x03 */ enum MCE_Initiator initiator:8;
enum MCE_ErrorType error_type:8; /* 0x04 */ enum MCE_ErrorType error_type:8;
enum MCE_Disposition disposition:8; /* 0x05 */ enum MCE_Disposition disposition:8;
uint16_t cpu; /* 0x06 */ bool sync_error;
uint64_t gpr3; /* 0x08 */ u16 cpu;
uint64_t srr0; /* 0x10 */ u64 gpr3;
uint64_t srr1; /* 0x18 */ u64 srr0;
union { /* 0x20 */ u64 srr1;
union {
struct { struct {
enum MCE_UeErrorType ue_error_type:8; enum MCE_UeErrorType ue_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t physical_address_provided; u8 physical_address_provided;
uint8_t reserved_1[5]; u8 reserved_1[5];
uint64_t effective_address; u64 effective_address;
uint64_t physical_address; u64 physical_address;
uint8_t reserved_2[8]; u8 reserved_2[8];
} ue_error; } ue_error;
struct { struct {
enum MCE_SlbErrorType slb_error_type:8; enum MCE_SlbErrorType slb_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} slb_error; } slb_error;
struct { struct {
enum MCE_EratErrorType erat_error_type:8; enum MCE_EratErrorType erat_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} erat_error; } erat_error;
struct { struct {
enum MCE_TlbErrorType tlb_error_type:8; enum MCE_TlbErrorType tlb_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} tlb_error; } tlb_error;
struct { struct {
enum MCE_UserErrorType user_error_type:8; enum MCE_UserErrorType user_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} user_error; } user_error;
struct { struct {
enum MCE_RaErrorType ra_error_type:8; enum MCE_RaErrorType ra_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} ra_error; } ra_error;
struct { struct {
enum MCE_LinkErrorType link_error_type:8; enum MCE_LinkErrorType link_error_type:8;
uint8_t effective_address_provided; u8 effective_address_provided;
uint8_t reserved_1[6]; u8 reserved_1[6];
uint64_t effective_address; u64 effective_address;
uint8_t reserved_2[16]; u8 reserved_2[16];
} link_error; } link_error;
} u; } u;
}; };
...@@ -194,6 +195,7 @@ struct mce_error_info { ...@@ -194,6 +195,7 @@ struct mce_error_info {
} u; } u;
enum MCE_Severity severity:8; enum MCE_Severity severity:8;
enum MCE_Initiator initiator:8; enum MCE_Initiator initiator:8;
bool sync_error;
}; };
#define MAX_MC_EVT 100 #define MAX_MC_EVT 100
......
...@@ -122,6 +122,7 @@ void save_mce_event(struct pt_regs *regs, long handled, ...@@ -122,6 +122,7 @@ void save_mce_event(struct pt_regs *regs, long handled,
mce->initiator = mce_err->initiator; mce->initiator = mce_err->initiator;
mce->severity = mce_err->severity; mce->severity = mce_err->severity;
mce->sync_error = mce_err->sync_error;
/* /*
* Populate the mce error_type and type-specific error_type. * Populate the mce error_type and type-specific error_type.
...@@ -376,9 +377,9 @@ void machine_check_print_event_info(struct machine_check_event *evt, ...@@ -376,9 +377,9 @@ void machine_check_print_event_info(struct machine_check_event *evt,
break; break;
case MCE_SEV_WARNING: case MCE_SEV_WARNING:
level = KERN_WARNING; level = KERN_WARNING;
sevstr = ""; sevstr = "Warning";
break; break;
case MCE_SEV_ERROR_SYNC: case MCE_SEV_SEVERE:
level = KERN_ERR; level = KERN_ERR;
sevstr = "Severe"; sevstr = "Severe";
break; break;
......
This diff is collapsed.
...@@ -505,7 +505,7 @@ static int opal_recover_mce(struct pt_regs *regs, ...@@ -505,7 +505,7 @@ static int opal_recover_mce(struct pt_regs *regs,
recovered = 0; recovered = 0;
} }
if (!recovered && evt->severity == MCE_SEV_ERROR_SYNC) { if (!recovered && evt->sync_error) {
/* /*
* Try to kill processes if we get a synchronous machine check * Try to kill processes if we get a synchronous machine check
* (e.g., one caused by execution of this instruction). This * (e.g., one caused by execution of this instruction). This
......
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