summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2007-03-09 00:58:44 +0000
committerpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2007-03-09 00:58:44 +0000
commit3551ee48a7f52425e953d4a3ea7bc2fd3b2a62ff (patch)
treebe07ed10ce407e0e04b58b094d59d38ab7850806
parent49737fea1face763babc39b5b6a547157d7131f0 (diff)
downloadpx4-nuttx-3551ee48a7f52425e953d4a3ea7bc2fd3b2a62ff.tar.gz
px4-nuttx-3551ee48a7f52425e953d4a3ea7bc2fd3b2a62ff.tar.bz2
px4-nuttx-3551ee48a7f52425e953d4a3ea7bc2fd3b2a62ff.zip
C5471 timer interrupts and timing functions are working
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@46 42af7a65-404d-4744-a932-0658087f49c3
-rw-r--r--nuttx/arch/c5471/defconfig4
-rw-r--r--nuttx/arch/c5471/src/up_internal.h3
-rw-r--r--nuttx/arch/c5471/src/up_vectors.S119
3 files changed, 90 insertions, 36 deletions
diff --git a/nuttx/arch/c5471/defconfig b/nuttx/arch/c5471/defconfig
index dea8e2c0c..91e81a952 100644
--- a/nuttx/arch/c5471/defconfig
+++ b/nuttx/arch/c5471/defconfig
@@ -41,12 +41,14 @@
# CONFIG_DRAM_END - the size of installed DRAM.
# Unique to c5471
# CONFIG_C5471_LEDS - Use LEDs to show state. Unique to c5471.
+# CONFIG_C5471_STACKDUMP - Do stack dumps after assertions
#
CONFIG_ARCH=c5471
CONFIG_ARCH_C5471=y
CONFIG_ROM_VECTORS=n
CONFIG_DRAM_END=0x11000000
CONFIG_C5471_LEDS=y
+CONFIG_C5471_STACKDUMP=y
#
# C5471 specific device driver settings
@@ -107,7 +109,7 @@ CONFIG_UART_MODEM_2STOP=0
# provides /dev/console. Enables stdout, stderr, stdin.
#
CONFIG_EXAMPLE=ostest
-CONFIG_DEBUG=y
+CONFIG_DEBUG=n
CONFIG_DEBUG_VERBOSE=n
CONFIG_MM_REGIONS=1
CONFIG_ARCH_LOWPUTC=y
diff --git a/nuttx/arch/c5471/src/up_internal.h b/nuttx/arch/c5471/src/up_internal.h
index 46f936f25..ef08d36a7 100644
--- a/nuttx/arch/c5471/src/up_internal.h
+++ b/nuttx/arch/c5471/src/up_internal.h
@@ -50,10 +50,9 @@
*/
#undef CONFIG_SUPPRESS_INTERRUPTS /* Do not enable interrupts */
-#define CONFIG_SUPPRESS_TIMER_INTS 1 /* No timer */
+#undef CONFIG_SUPPRESS_TIMER_INTS /* No timer */
#define CONFIG_SUPPRESS_SERIAL_INTS 1 /* Console will poll */
#undef CONFIG_SUPPRESS_UART_CONFIG /* Do not reconfig UART */
-#define CONFIG_C5471_STACKDUMP 1 /* Dump stack on assertion */
/* LED definitions */
diff --git a/nuttx/arch/c5471/src/up_vectors.S b/nuttx/arch/c5471/src/up_vectors.S
index c751cdb4b..302b79b4f 100644
--- a/nuttx/arch/c5471/src/up_vectors.S
+++ b/nuttx/arch/c5471/src/up_vectors.S
@@ -102,16 +102,27 @@ up_vectorirq:
bic lr, lr, #MODE_MASK /* Keep F and T bits */
orr lr, lr, #I_BIT | SVC_MODE
- msr cpsr, lr /* Swith to SVC mode */
+ msr cpsr_c, lr /* Switch to SVC mode */
- /* Create a context structure */
+ /* Create a context structure. First set aside a stack frame
+ * and store r0-r12 into the frame.
+ */
sub sp, sp, #XCPTCONTEXT_SIZE
- stmia sp, {r0-r14} /* Save the SVC mode regs */
+ stmia sp, {r0-r12} /* Save the SVC mode regs */
+
+ /* Get the correct values of r13(sp) and r14(lr) in r1 and r2 */
+
+ add r1, sp, #XCPTCONTEXT_SIZE
+ mov r2, r14
+
+ /* Get the values for r15(pc) and CPSR in r3 and r4 */
+
ldr r0, .Lirqtmp /* Points to temp storage */
- ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
- add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
- stmia r0, {r1, r2}
+ ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
+
+ add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
+ stmia r0, {r1-r4}
/* Now decode the interrupt */
@@ -179,14 +190,23 @@ up_vectorswi:
ldr r14, [sp,#-0x4] /* rrload workaround */
- /* Create a context structure */
+ /* Create a context structure. First set aside a stack frame
+ * and store r0-r12 into the frame.
+ */
sub sp, sp, #XCPTCONTEXT_SIZE
- stmia sp, {r0-r14} /* Save the SVC mode regs */
- mrs r2, spsr /* Get the saved CPSR */
- mov r1, r14 /* Save r14 as the PC */
- add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
- stmia r0, {r1, r2}
+ stmia sp, {r0-r12} /* Save the SVC mode regs */
+
+ /* Get the correct values of r13(sp), r14(lr), r15(pc)
+ * and CPSR in r1-r4 */
+
+ add r1, sp, #XCPTCONTEXT_SIZE
+ mov r2, r14 /* R14 is altered on return from SWI */
+ mov r3, r14 /* Save r14 as the PC as well */
+ mrs r4, spsr /* Get the saved CPSR */
+
+ add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
+ stmia r0, {r1-r4}
/* Then call the SWI handler with interrupt disabled.
* void up_syscall(struct xcptcontext *xcp)
@@ -231,16 +251,27 @@ up_vectordata:
bic lr, lr, #MODE_MASK /* Keep F and T bits */
orr lr, lr, #I_BIT | SVC_MODE
- msr cpsr, lr /* Swith to SVC mode */
+ msr cpsr_c, lr /* Switch to SVC mode */
- /* Create a context structure */
+ /* Create a context structure. First set aside a stack frame
+ * and store r0-r12 into the frame.
+ */
sub sp, sp, #XCPTCONTEXT_SIZE
- stmia sp, {r0-r14} /* Save the SVC mode regs */
+ stmia sp, {r0-r12} /* Save the SVC mode regs */
+
+ /* Get the correct values of r13(sp) and r14(lr) in r1 and r2 */
+
+ add r1, sp, #XCPTCONTEXT_SIZE
+ mov r2, r14
+
+ /* Get the values for r15(pc) and CPSR in r3 and r4 */
+
ldr r0, .Ldaborttmp /* Points to temp storage */
- ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
- add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
- stmia r0, {r1, r2}
+ ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
+
+ add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
+ stmia r0, {r1-r4}
/* Then call the data abort handler with interrupt disabled.
* void up_dataabort(struct xcptcontext *xcp)
@@ -253,7 +284,7 @@ up_vectordata:
/* Restore the CPSR, SVC modr registers and return */
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
- msr spsr, r0
+ msr spsr_cxsf, r0
ldmia sp, {r0-r15}^ /* Return */
.Ldaborttmp:
@@ -286,16 +317,27 @@ up_vectorprefetch:
bic lr, lr, #MODE_MASK /* Keep F and T bits */
orr lr, lr, #I_BIT | SVC_MODE
- msr cpsr, lr /* Swith to SVC mode */
+ msr cpsr_c, lr /* Switch to SVC mode */
- /* Create a context structure */
+ /* Create a context structure. First set aside a stack frame
+ * and store r0-r12 into the frame.
+ */
sub sp, sp, #XCPTCONTEXT_SIZE
- stmia sp, {r0-r14} /* Save the SVC mode regs */
+ stmia sp, {r0-r12} /* Save the SVC mode regs */
+
+ /* Get the correct values of r13(sp) and r14(lr) in r1 and r2 */
+
+ add r1, sp, #XCPTCONTEXT_SIZE
+ mov r2, r14
+
+ /* Get the values for r15(pc) and CPSR in r3 and r4 */
+
ldr r0, .Lpaborttmp /* Points to temp storage */
- ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
- add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
- stmia r0, {r1, r2}
+ ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
+
+ add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
+ stmia r0, {r1-r4}
/* Then call the prefetch abort handler with interrupt disabled.
* void up_prefetchabort(struct xcptcontext *xcp)
@@ -308,7 +350,7 @@ up_vectorprefetch:
/* Restore the CPSR, SVC modr registers and return */
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
- msr spsr, r0
+ msr spsr_cxsf, r0
ldmia sp, {r0-r15}^ /* Return */
.Lpaborttmp:
@@ -341,16 +383,27 @@ up_vectorundefinsn:
bic lr, lr, #MODE_MASK /* Keep F and T bits */
orr lr, lr, #I_BIT | SVC_MODE
- msr cpsr, lr /* Swith to SVC mode */
+ msr cpsr_c, lr /* Switch to SVC mode */
- /* Create a context structure */
+ /* Create a context structure. First set aside a stack frame
+ * and store r0-r12 into the frame.
+ */
sub sp, sp, #XCPTCONTEXT_SIZE
- stmia sp, {r0-r14} /* Save the SVC mode regs */
+ stmia sp, {r0-r12} /* Save the SVC mode regs */
+
+ /* Get the correct values of r13(sp) and r14(lr) in r1 and r2 */
+
+ add r1, sp, #XCPTCONTEXT_SIZE
+ mov r2, r14
+
+ /* Get the values for r15(pc) and CPSR in r3 and r4 */
+
ldr r0, .Lundeftmp /* Points to temp storage */
- ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
- add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
- stmia r0, {r1, r2}
+ ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
+
+ add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
+ stmia r0, {r1-r4}
/* Then call the undef insn handler with interrupt disabled.
* void up_undefinedinsn(struct xcptcontext *xcp)
@@ -363,7 +416,7 @@ up_vectorundefinsn:
/* Restore the CPSR, SVC modr registers and return */
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
- msr spsr, r0
+ msr spsr_cxsf, r0
ldmia sp, {r0-r15}^ /* Return */
.Lundeftmp: