diff options
-rw-r--r-- | drivers/edac/mce_amd.c | 54 |
1 files changed, 32 insertions, 22 deletions
diff --git a/drivers/edac/mce_amd.c b/drivers/edac/mce_amd.c index 53d4dc0de343..0a19d2626686 100644 --- a/drivers/edac/mce_amd.c +++ b/drivers/edac/mce_amd.c | |||
@@ -723,19 +723,22 @@ wrong_fp_mce: | |||
723 | 723 | ||
724 | static inline void amd_decode_err_code(u16 ec) | 724 | static inline void amd_decode_err_code(u16 ec) |
725 | { | 725 | { |
726 | if (TLB_ERROR(ec)) { | 726 | |
727 | pr_emerg(HW_ERR "Transaction: %s, Cache Level: %s\n", | 727 | pr_emerg(HW_ERR "cache level: %s", LL_MSG(ec)); |
728 | TT_MSG(ec), LL_MSG(ec)); | 728 | |
729 | } else if (MEM_ERROR(ec)) { | 729 | if (BUS_ERROR(ec)) |
730 | pr_emerg(HW_ERR "Transaction: %s, Type: %s, Cache Level: %s\n", | 730 | pr_cont(", mem/io: %s", II_MSG(ec)); |
731 | R4_MSG(ec), TT_MSG(ec), LL_MSG(ec)); | 731 | else |
732 | } else if (BUS_ERROR(ec)) { | 732 | pr_cont(", tx: %s", TT_MSG(ec)); |
733 | pr_emerg(HW_ERR "Transaction: %s (%s), %s, Cache Level: %s, " | 733 | |
734 | "Participating Processor: %s\n", | 734 | if (MEM_ERROR(ec) || BUS_ERROR(ec)) { |
735 | R4_MSG(ec), II_MSG(ec), TO_MSG(ec), LL_MSG(ec), | 735 | pr_cont(", mem-tx: %s", R4_MSG(ec)); |
736 | PP_MSG(ec)); | 736 | |
737 | } else | 737 | if (BUS_ERROR(ec)) |
738 | pr_emerg(HW_ERR "Huh? Unknown MCE error 0x%x\n", ec); | 738 | pr_cont(", part-proc: %s (%s)", PP_MSG(ec), TO_MSG(ec)); |
739 | } | ||
740 | |||
741 | pr_cont("\n"); | ||
739 | } | 742 | } |
740 | 743 | ||
741 | /* | 744 | /* |
@@ -757,25 +760,32 @@ static bool amd_filter_mce(struct mce *m) | |||
757 | int amd_decode_mce(struct notifier_block *nb, unsigned long val, void *data) | 760 | int amd_decode_mce(struct notifier_block *nb, unsigned long val, void *data) |
758 | { | 761 | { |
759 | struct mce *m = (struct mce *)data; | 762 | struct mce *m = (struct mce *)data; |
763 | struct cpuinfo_x86 *c = &boot_cpu_data; | ||
760 | int node, ecc; | 764 | int node, ecc; |
761 | 765 | ||
762 | if (amd_filter_mce(m)) | 766 | if (amd_filter_mce(m)) |
763 | return NOTIFY_STOP; | 767 | return NOTIFY_STOP; |
764 | 768 | ||
765 | pr_emerg(HW_ERR "MC%d_STATUS: ", m->bank); | 769 | pr_emerg(HW_ERR "MC%d_STATUS[%s|%s|%s|%s|%s", |
770 | m->bank, | ||
771 | ((m->status & MCI_STATUS_OVER) ? "Over" : "-"), | ||
772 | ((m->status & MCI_STATUS_UC) ? "UE" : "CE"), | ||
773 | ((m->status & MCI_STATUS_MISCV) ? "MiscV" : "-"), | ||
774 | ((m->status & MCI_STATUS_PCC) ? "PCC" : "-"), | ||
775 | ((m->status & MCI_STATUS_ADDRV) ? "AddrV" : "-")); | ||
766 | 776 | ||
767 | pr_cont("%sorrected error, other errors lost: %s, " | 777 | if (c->x86 == 0x15) |
768 | "CPU context corrupt: %s", | 778 | pr_cont("|%s|%s", |
769 | ((m->status & MCI_STATUS_UC) ? "Unc" : "C"), | 779 | ((m->status & BIT(44)) ? "Deferred" : "-"), |
770 | ((m->status & MCI_STATUS_OVER) ? "yes" : "no"), | 780 | ((m->status & BIT(43)) ? "Poison" : "-")); |
771 | ((m->status & MCI_STATUS_PCC) ? "yes" : "no")); | ||
772 | 781 | ||
773 | /* do the two bits[14:13] together */ | 782 | /* do the two bits[14:13] together */ |
774 | ecc = (m->status >> 45) & 0x3; | 783 | ecc = (m->status >> 45) & 0x3; |
775 | if (ecc) | 784 | if (ecc) |
776 | pr_cont(", %sECC Error", ((ecc == 2) ? "C" : "U")); | 785 | pr_cont("|%sECC", ((ecc == 2) ? "C" : "U")); |
786 | |||
787 | pr_cont("]: 0x%016llx\n", m->status); | ||
777 | 788 | ||
778 | pr_cont("\n"); | ||
779 | 789 | ||
780 | switch (m->bank) { | 790 | switch (m->bank) { |
781 | case 0: | 791 | case 0: |
@@ -787,7 +797,7 @@ int amd_decode_mce(struct notifier_block *nb, unsigned long val, void *data) | |||
787 | break; | 797 | break; |
788 | 798 | ||
789 | case 2: | 799 | case 2: |
790 | if (boot_cpu_data.x86 == 0x15) | 800 | if (c->x86 == 0x15) |
791 | amd_decode_cu_mce(m); | 801 | amd_decode_cu_mce(m); |
792 | else | 802 | else |
793 | amd_decode_bu_mce(m); | 803 | amd_decode_bu_mce(m); |