summaryrefslogtreecommitdiff
path: root/util/ec_panicinfo.c
diff options
context:
space:
mode:
Diffstat (limited to 'util/ec_panicinfo.c')
-rw-r--r--util/ec_panicinfo.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/util/ec_panicinfo.c b/util/ec_panicinfo.c
index 47de4b2a4c..296774021f 100644
--- a/util/ec_panicinfo.c
+++ b/util/ec_panicinfo.c
@@ -23,6 +23,26 @@ static void print_panic_reg(int regnum, const uint32_t *regs, int index)
printf((regnum & 3) == 3 ? "\n" : " ");
}
+static void panic_show_extra_cm(const struct panic_data *pdata)
+{
+ enum {
+ CPU_NVIC_CFSR_BFARVALID = 1 << 15,
+ CPU_NVIC_CFSR_MFARVALID = 1 << 7,
+ };
+
+ printf("\n");
+ if (pdata->cm.cfsr & CPU_NVIC_CFSR_BFARVALID)
+ printf("bfar=%08x, ", pdata->cm.bfar);
+ if (pdata->cm.cfsr & CPU_NVIC_CFSR_MFARVALID)
+ printf("mfar=%08x, ", pdata->cm.mfar);
+ printf("cfsr=%08x, ", pdata->cm.cfsr);
+ printf("shcsr=%08x, ", pdata->cm.shcsr);
+ printf("hfsr=%08x, ", pdata->cm.hfsr);
+ printf("dfsr=%08x, ", pdata->cm.dfsr);
+ printf("ipsr=%08x", pdata->cm.regs[CORTEX_PANIC_REGISTER_IPSR]);
+ printf("\n");
+}
+
static int parse_panic_info_cm(const struct panic_data *pdata)
{
const uint32_t *lregs = pdata->cm.regs;
@@ -65,6 +85,8 @@ static int parse_panic_info_cm(const struct panic_data *pdata)
print_panic_reg(14, sregs, 5);
print_panic_reg(15, sregs, 6);
+ panic_show_extra_cm(pdata);
+
return 0;
}