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
This commit is contained in:
parent
a3455d2a77
commit
e0f2dd1408
@ -41,12 +41,14 @@
|
|||||||
# CONFIG_DRAM_END - the size of installed DRAM.
|
# CONFIG_DRAM_END - the size of installed DRAM.
|
||||||
# Unique to c5471
|
# Unique to c5471
|
||||||
# CONFIG_C5471_LEDS - Use LEDs to show state. 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
|
||||||
CONFIG_ARCH_C5471=y
|
CONFIG_ARCH_C5471=y
|
||||||
CONFIG_ROM_VECTORS=n
|
CONFIG_ROM_VECTORS=n
|
||||||
CONFIG_DRAM_END=0x11000000
|
CONFIG_DRAM_END=0x11000000
|
||||||
CONFIG_C5471_LEDS=y
|
CONFIG_C5471_LEDS=y
|
||||||
|
CONFIG_C5471_STACKDUMP=y
|
||||||
|
|
||||||
#
|
#
|
||||||
# C5471 specific device driver settings
|
# C5471 specific device driver settings
|
||||||
@ -107,7 +109,7 @@ CONFIG_UART_MODEM_2STOP=0
|
|||||||
# provides /dev/console. Enables stdout, stderr, stdin.
|
# provides /dev/console. Enables stdout, stderr, stdin.
|
||||||
#
|
#
|
||||||
CONFIG_EXAMPLE=ostest
|
CONFIG_EXAMPLE=ostest
|
||||||
CONFIG_DEBUG=y
|
CONFIG_DEBUG=n
|
||||||
CONFIG_DEBUG_VERBOSE=n
|
CONFIG_DEBUG_VERBOSE=n
|
||||||
CONFIG_MM_REGIONS=1
|
CONFIG_MM_REGIONS=1
|
||||||
CONFIG_ARCH_LOWPUTC=y
|
CONFIG_ARCH_LOWPUTC=y
|
||||||
|
@ -50,10 +50,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#undef CONFIG_SUPPRESS_INTERRUPTS /* Do not enable interrupts */
|
#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 */
|
#define CONFIG_SUPPRESS_SERIAL_INTS 1 /* Console will poll */
|
||||||
#undef CONFIG_SUPPRESS_UART_CONFIG /* Do not reconfig UART */
|
#undef CONFIG_SUPPRESS_UART_CONFIG /* Do not reconfig UART */
|
||||||
#define CONFIG_C5471_STACKDUMP 1 /* Dump stack on assertion */
|
|
||||||
|
|
||||||
/* LED definitions */
|
/* LED definitions */
|
||||||
|
|
||||||
|
@ -102,16 +102,27 @@ up_vectorirq:
|
|||||||
|
|
||||||
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
||||||
orr lr, lr, #I_BIT | SVC_MODE
|
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
|
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 */
|
ldr r0, .Lirqtmp /* Points to temp storage */
|
||||||
ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
||||||
add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
|
|
||||||
stmia r0, {r1, r2}
|
add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
|
||||||
|
stmia r0, {r1-r4}
|
||||||
|
|
||||||
/* Now decode the interrupt */
|
/* Now decode the interrupt */
|
||||||
|
|
||||||
@ -179,14 +190,23 @@ up_vectorswi:
|
|||||||
|
|
||||||
ldr r14, [sp,#-0x4] /* rrload workaround */
|
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
|
sub sp, sp, #XCPTCONTEXT_SIZE
|
||||||
stmia sp, {r0-r14} /* Save the SVC mode regs */
|
stmia sp, {r0-r12} /* Save the SVC mode regs */
|
||||||
mrs r2, spsr /* Get the saved CPSR */
|
|
||||||
mov r1, r14 /* Save r14 as the PC */
|
/* Get the correct values of r13(sp), r14(lr), r15(pc)
|
||||||
add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
|
* and CPSR in r1-r4 */
|
||||||
stmia r0, {r1, r2}
|
|
||||||
|
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.
|
/* Then call the SWI handler with interrupt disabled.
|
||||||
* void up_syscall(struct xcptcontext *xcp)
|
* void up_syscall(struct xcptcontext *xcp)
|
||||||
@ -231,16 +251,27 @@ up_vectordata:
|
|||||||
|
|
||||||
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
||||||
orr lr, lr, #I_BIT | SVC_MODE
|
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
|
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 */
|
ldr r0, .Ldaborttmp /* Points to temp storage */
|
||||||
ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
||||||
add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
|
|
||||||
stmia r0, {r1, r2}
|
add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
|
||||||
|
stmia r0, {r1-r4}
|
||||||
|
|
||||||
/* Then call the data abort handler with interrupt disabled.
|
/* Then call the data abort handler with interrupt disabled.
|
||||||
* void up_dataabort(struct xcptcontext *xcp)
|
* void up_dataabort(struct xcptcontext *xcp)
|
||||||
@ -253,7 +284,7 @@ up_vectordata:
|
|||||||
/* Restore the CPSR, SVC modr registers and return */
|
/* Restore the CPSR, SVC modr registers and return */
|
||||||
|
|
||||||
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
||||||
msr spsr, r0
|
msr spsr_cxsf, r0
|
||||||
ldmia sp, {r0-r15}^ /* Return */
|
ldmia sp, {r0-r15}^ /* Return */
|
||||||
|
|
||||||
.Ldaborttmp:
|
.Ldaborttmp:
|
||||||
@ -286,16 +317,27 @@ up_vectorprefetch:
|
|||||||
|
|
||||||
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
||||||
orr lr, lr, #I_BIT | SVC_MODE
|
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
|
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 */
|
ldr r0, .Lpaborttmp /* Points to temp storage */
|
||||||
ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
||||||
add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
|
|
||||||
stmia r0, {r1, r2}
|
add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
|
||||||
|
stmia r0, {r1-r4}
|
||||||
|
|
||||||
/* Then call the prefetch abort handler with interrupt disabled.
|
/* Then call the prefetch abort handler with interrupt disabled.
|
||||||
* void up_prefetchabort(struct xcptcontext *xcp)
|
* void up_prefetchabort(struct xcptcontext *xcp)
|
||||||
@ -308,7 +350,7 @@ up_vectorprefetch:
|
|||||||
/* Restore the CPSR, SVC modr registers and return */
|
/* Restore the CPSR, SVC modr registers and return */
|
||||||
|
|
||||||
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
||||||
msr spsr, r0
|
msr spsr_cxsf, r0
|
||||||
ldmia sp, {r0-r15}^ /* Return */
|
ldmia sp, {r0-r15}^ /* Return */
|
||||||
|
|
||||||
.Lpaborttmp:
|
.Lpaborttmp:
|
||||||
@ -341,16 +383,27 @@ up_vectorundefinsn:
|
|||||||
|
|
||||||
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
bic lr, lr, #MODE_MASK /* Keep F and T bits */
|
||||||
orr lr, lr, #I_BIT | SVC_MODE
|
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
|
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 */
|
ldr r0, .Lundeftmp /* Points to temp storage */
|
||||||
ldmia r0, {r1, r2} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
ldmia r0, {r3, r4} /* Recover r1=lr_IRQ, r2=spsr_IRQ */
|
||||||
add r0, sp, #(4*REG_PC) /* Offset to pc, cpsr storage */
|
|
||||||
stmia r0, {r1, r2}
|
add r0, sp, #(4*REG_SP) /* Offset to pc, cpsr storage */
|
||||||
|
stmia r0, {r1-r4}
|
||||||
|
|
||||||
/* Then call the undef insn handler with interrupt disabled.
|
/* Then call the undef insn handler with interrupt disabled.
|
||||||
* void up_undefinedinsn(struct xcptcontext *xcp)
|
* void up_undefinedinsn(struct xcptcontext *xcp)
|
||||||
@ -363,7 +416,7 @@ up_vectorundefinsn:
|
|||||||
/* Restore the CPSR, SVC modr registers and return */
|
/* Restore the CPSR, SVC modr registers and return */
|
||||||
|
|
||||||
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
ldr r0, [sp, #(4*REG_CPSR)] /* Setup the SVC mode SPSR */
|
||||||
msr spsr, r0
|
msr spsr_cxsf, r0
|
||||||
ldmia sp, {r0-r15}^ /* Return */
|
ldmia sp, {r0-r15}^ /* Return */
|
||||||
|
|
||||||
.Lundeftmp:
|
.Lundeftmp:
|
||||||
|
Loading…
Reference in New Issue
Block a user