summaryrefslogtreecommitdiff
path: root/nuttx/arch/arm/src/armv7-m/up_assert.c
diff options
context:
space:
mode:
authorpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2013-03-19 16:11:23 +0000
committerpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2013-03-19 16:11:23 +0000
commita48a83271d371fd33201e3bba10967531ad32419 (patch)
treec58b80885bb66dbe6eda976a83caea2eae93e7fe /nuttx/arch/arm/src/armv7-m/up_assert.c
parentc79e92ceffd9665632b58a6fb884178a4f4c71a2 (diff)
downloadpx4-nuttx-a48a83271d371fd33201e3bba10967531ad32419.tar.gz
px4-nuttx-a48a83271d371fd33201e3bba10967531ad32419.tar.bz2
px4-nuttx-a48a83271d371fd33201e3bba10967531ad32419.zip
If the PRIMASK is used to disable interrupts, then additional logic is required to handle hard faults in the kernel build
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@5761 42af7a65-404d-4744-a932-0658087f49c3
Diffstat (limited to 'nuttx/arch/arm/src/armv7-m/up_assert.c')
-rw-r--r--nuttx/arch/arm/src/armv7-m/up_assert.c40
1 files changed, 26 insertions, 14 deletions
diff --git a/nuttx/arch/arm/src/armv7-m/up_assert.c b/nuttx/arch/arm/src/armv7-m/up_assert.c
index a4a58639c..b0df6d729 100644
--- a/nuttx/arch/arm/src/armv7-m/up_assert.c
+++ b/nuttx/arch/arm/src/armv7-m/up_assert.c
@@ -147,12 +147,19 @@ static inline void up_registerdump(void)
current_regs[REG_R10], current_regs[REG_R11],
current_regs[REG_R12], current_regs[REG_R13],
current_regs[REG_R14], current_regs[REG_R15]);
+
#ifdef CONFIG_ARMV7M_USEBASEPRI
- lldbg("xPSR: %08x BASEPRI: %08x\n",
- current_regs[REG_XPSR], current_regs[REG_BASEPRI]);
+ lldbg("xPSR: %08x BASEPRI: %08x CONTROL: %08x\n",
+ current_regs[REG_XPSR], current_regs[REG_BASEPRI],
+ getcontrol());
#else
- lldbg("xPSR: %08x PRIMASK: %08x\n",
- current_regs[REG_XPSR], current_regs[REG_PRIMASK]);
+ lldbg("xPSR: %08x PRIMASK: %08x CONTROL: %08x\n",
+ current_regs[REG_XPSR], current_regs[REG_PRIMASK],
+ getcontrol());
+#endif
+
+#ifdef REG_EXC_RETURN
+ lldbg("EXC_RETURN: %08x\n", current_regs[REG_EXC_RETURN]);
#endif
}
}
@@ -189,9 +196,9 @@ static void up_dumpstate(void)
ustacksize = (uint32_t)rtcb->adj_stack_size;
}
+#if CONFIG_ARCH_INTERRUPTSTACK > 3
/* Get the limits on the interrupt stack memory */
-#if CONFIG_ARCH_INTERRUPTSTACK > 3
istackbase = (uint32_t)&g_intstackbase;
istacksize = (CONFIG_ARCH_INTERRUPTSTACK & ~3) - 4;
@@ -236,7 +243,11 @@ static void up_dumpstate(void)
{
up_stackdump(sp, ustackbase);
}
+
#else
+
+ /* Show user stack info */
+
lldbg("sp: %08x\n", sp);
lldbg("stack base: %08x\n", ustackbase);
lldbg("stack size: %08x\n", ustacksize);
@@ -247,12 +258,13 @@ static void up_dumpstate(void)
if (sp > ustackbase || sp <= ustackbase - ustacksize)
{
- lldbg("ERROR: Stack pointer is not within allocated stack\n");
+ lldbg("ERROR: Stack pointer is not within the allocated stack\n");
}
else
{
up_stackdump(sp, ustackbase);
}
+
#endif
/* Then dump the registers (if available) */
@@ -274,16 +286,16 @@ static void _up_assert(int errorcode)
if (current_regs || ((struct tcb_s*)g_readytorun.head)->pid == 0)
{
- (void)irqsave();
- for(;;)
- {
+ (void)irqsave();
+ for(;;)
+ {
#ifdef CONFIG_ARCH_LEDS
- up_ledon(LED_PANIC);
- up_mdelay(250);
- up_ledoff(LED_PANIC);
- up_mdelay(250);
+ up_ledon(LED_PANIC);
+ up_mdelay(250);
+ up_ledoff(LED_PANIC);
+ up_mdelay(250);
#endif
- }
+ }
}
else
{