| // SPDX-License-Identifier: GPL-2.0-or-later |
| /* |
| */ |
| |
| #include <linux/kernel.h> |
| #include <linux/printk.h> |
| #include <linux/ptrace.h> |
| |
| #include <asm/reg.h> |
| |
| int machine_check_8xx(struct pt_regs *regs) |
| { |
| unsigned long reason = regs->msr; |
| |
| pr_err("Machine check in kernel mode.\n"); |
| pr_err("Caused by (from SRR1=%lx): ", reason); |
| if (reason & 0x40000000) |
| pr_cont("Fetch error at address %lx\n", regs->nip); |
| else |
| pr_cont("Data access error at address %lx\n", regs->dar); |
| |
| #ifdef CONFIG_PCI |
| /* the qspan pci read routines can cause machine checks -- Cort |
| * |
| * yuck !!! that totally needs to go away ! There are better ways |
| * to deal with that than having a wart in the mcheck handler. |
| * -- BenH |
| */ |
| bad_page_fault(regs, SIGBUS); |
| return 1; |
| #else |
| return 0; |
| #endif |
| } |