1 /* SPDX-License-Identifier: BSD-3-Clause */
3 /****************************************************************************
4 * Copyright (c) 2006 by Michael Fischer. All rights reserved.
5 ****************************************************************************
9 * 18.12.06 mifi First Version
10 * The hardware initialization is based on the startup file
11 * crtat91sam7x256_rom.S from NutOS 4.2.1.
12 * Therefore partial copyright by egnite Software GmbH.
13 ****************************************************************************/
16 * Some defines for the program status registers
18 ARM_MODE_USER = 0x10 /* Normal User Mode */
19 ARM_MODE_FIQ = 0x11 /* FIQ Fast Interrupts Mode */
20 ARM_MODE_IRQ = 0x12 /* IRQ Standard Interrupts Mode */
21 ARM_MODE_SVC = 0x13 /* Supervisor Interrupts Mode */
22 ARM_MODE_ABORT = 0x17 /* Abort Processing memory Faults Mode */
23 ARM_MODE_UNDEF = 0x1B /* Undefined Instructions Mode */
24 ARM_MODE_SYS = 0x1F /* System Running in Privileged Operating Mode */
27 I_BIT = 0x80 /* disable IRQ when I bit is set */
28 F_BIT = 0x40 /* disable IRQ when I bit is set */
31 * Register Base Address
39 RSTC_URSTEN = 0x00000001
42 WDT_MR_OFF = 0x00000004
43 WDT_WDDIS = 0x00008000
46 MC_FMR_OFF = 0x00000060
47 MC_FWS_1FWS = 0x00480100
49 .section .vectors,"ax"
52 /****************************************************************************/
53 /* Vector table and reset entry */
54 /****************************************************************************/
56 ldr pc, ResetAddr /* Reset */
57 ldr pc, UndefAddr /* Undefined instruction */
58 ldr pc, SWIAddr /* Software interrupt */
59 ldr pc, PAbortAddr /* Prefetch abort */
60 ldr pc, DAbortAddr /* Data abort */
61 ldr pc, ReservedAddr /* Reserved */
62 ldr pc, IRQAddr /* IRQ interrupt */
63 ldr pc, FIQAddr /* FIQ interrupt */
66 ResetAddr: .word ResetHandler
67 UndefAddr: .word UndefHandler
68 SWIAddr: .word SWIHandler
69 PAbortAddr: .word PAbortHandler
70 DAbortAddr: .word DAbortHandler
72 IRQAddr: .word IRQHandler
73 FIQAddr: .word FIQHandler
83 /****************************************************************************/
85 /****************************************************************************/
88 * The watchdog is enabled after processor reset. Disable it.
92 str r0, [r1, #WDT_MR_OFF]
96 * Enable user reset: assertion length programmed to 1ms
98 ldr r0, =(RSTC_KEY | RSTC_URSTEN | (4 << 8))
104 * Use 2 cycles for flash access.
108 str r0, [r1, #MC_FMR_OFF]
112 * Disable all interrupts. Useful for debugging w/o target reset.
116 str r0, [r1, #AIC_EOICR_OFF]
117 str r0, [r1, #AIC_IDCR_OFF]
121 * Setup a stack for each mode
123 msr CPSR_c, #ARM_MODE_UNDEF | I_BIT | F_BIT /* Undefined Instruction Mode */
124 ldr sp, =__stack_und_end
126 msr CPSR_c, #ARM_MODE_ABORT | I_BIT | F_BIT /* Abort Mode */
127 ldr sp, =__stack_abt_end
129 msr CPSR_c, #ARM_MODE_FIQ | I_BIT | F_BIT /* FIQ Mode */
130 ldr sp, =__stack_fiq_end
132 msr CPSR_c, #ARM_MODE_IRQ | I_BIT | F_BIT /* IRQ Mode */
133 ldr sp, =__stack_irq_end
135 msr CPSR_c, #ARM_MODE_SVC | I_BIT | F_BIT /* Supervisor Mode */
136 ldr sp, =__stack_svc_end
155 bic r0, r0, #I_BIT | F_BIT /* Enable FIQ and IRQ interrupt */
158 mov r0, #0 /* No arguments */
159 mov r1, #0 /* No arguments */
162 bx r2 /* And jump... */
171 /****************************************************************************/
172 /* Default interrupt handler */
173 /****************************************************************************/
194 .weak UndefHandler, PAbortHandler, DAbortHandler
195 .weak IRQHandler, FIQHandler