1/*!
2 * @file       startup_apm32f091.S
3 *
4 * @brief      CMSIS Cortex-M0 PLUS based Core Device Startup File for Device startup_apm32f091
5 *
6 * @version    V1.0.0
7 *
8 * @date       2022-08-30
9 *
10 * @attention
11 *
12 *  Copyright (C) 2022 Geehy Semiconductor
13 *
14 *  You may not use this file except in compliance with the
15 *  GEEHY COPYRIGHT NOTICE (GEEHY SOFTWARE PACKAGE LICENSE).
16 *
17 *  The program is only for reference, which is distributed in the hope
18 *  that it will be useful and instructional for customers to develop
19 *  their software. Unless required by applicable law or agreed to in
20 *  writing, the program is distributed on an "AS IS" BASIS, WITHOUT
21 *  ANY WARRANTY OR CONDITIONS OF ANY KIND, either express or implied.
22 *  See the GEEHY SOFTWARE PACKAGE LICENSE for the governing permissions
23 *  and limitations under the License.
24 */
25
26  .syntax unified
27  .cpu cortex-m0plus
28  .fpu softvfp
29  .thumb
30
31.global g_apm32_Vectors
32.global Default_Handler
33
34.word _start_address_init_data
35.word _start_address_data
36.word _end_address_data
37.word _start_address_bss
38.word _end_address_bss
39
40  .section .text.Reset_Handler
41  .weak Reset_Handler
42  .type Reset_Handler, %function
43
44// Reset handler routine
45Reset_Handler:
46// User Stack and Heap initialization
47  ldr   r0, =_end_stack
48  mov   sp, r0
49
50  ldr r0, =_start_address_data
51  ldr r1, =_end_address_data
52  ldr r2, =_start_address_init_data
53  movs r3, #0
54  b L_loop0_0
55
56L_loop0:
57  ldr r4, [r2, r3]
58  str r4, [r0, r3]
59  adds r3, r3, #4
60
61L_loop0_0:
62  adds r4, r0, r3
63  cmp r4, r1
64  bcc L_loop0
65
66  ldr r2, =_start_address_bss
67  ldr r4, =_end_address_bss
68  movs r3, #0
69  b L_loop1
70
71L_loop2:
72  str  r3, [r2]
73  adds r2, r2, #4
74
75L_loop1:
76  cmp r2, r4
77  bcc L_loop2
78
79  bl  SystemInit
80  bl __libc_init_array
81  bl entry
82
83L_loop3:
84    b L_loop3
85
86.size Reset_Handler, .-Reset_Handler
87
88// This is the code that gets called when the processor receives an unexpected interrupt.
89    .section .text.Default_Handler,"ax",%progbits
90Default_Handler:
91L_Loop_infinite:
92  b L_Loop_infinite
93  .size Default_Handler, .-Default_Handler
94
95// The minimal vector table for a Cortex M0 Plus.
96   .section .isr_vector,"a",%progbits
97  .type g_apm32_Vectors, %object
98  .size g_apm32_Vectors, .-g_apm32_Vectors
99
100// Vector Table Mapped to Address 0 at Reset
101g_apm32_Vectors:
102  .word  _end_stack
103  .word  Reset_Handler                      // Reset Handler
104  .word  NMI_Handler                        // NMI Handler
105  .word  HardFault_Handler                  // Hard Fault Handler
106  .word  0                                  // Reserved
107  .word  0                                  // Reserved
108  .word  0                                  // Reserved
109  .word  0                                  // Reserved
110  .word  0                                  // Reserved
111  .word  0                                  // Reserved
112  .word  0                                  // Reserved
113  .word  SVC_Handler                        // SVCall Handler
114  .word  0                                  // Reserved
115  .word  0                                  // Reserved
116  .word  PendSV_Handler                     // PendSV Handler
117  .word  SysTick_Handler                    // SysTick Handler
118
119  // External Interrupts
120  .word  WWDT_IRQHandler                    // Window Watchdog
121  .word  PVD_VDDIO2_IRQHandler              // PVD and VDDIO2 through EINT Line detect
122  .word  RTC_IRQHandler                     // RTC through EINT Line
123  .word  FLASH_IRQHandler                   // FLASH
124  .word  RCM_CRS_IRQHandler                 // RCM and CRS
125  .word  EINT0_1_IRQHandler                 // EINT Line 0 and 1
126  .word  EINT2_3_IRQHandler                 // EINT Line 2 and 3
127  .word  EINT4_15_IRQHandler                // EINT Line 4 to 15
128  .word  TSC_IRQHandler                     // TSC
129  .word  DMA1_CH1_IRQHandler                // DMA1 Channel 1
130  .word  DMA1_CH2_3_DMA2_CH1_2_IRQHandler   // DMA1 Channel 2 and 3 DMA2 Channel 1 and 2
131  .word  DMA1_CH4_7_DMA2_CH3_5_IRQHandler   // DMA1 Channel 4 to 7  DMA2 Channel 3 to 5 Interrupts
132  .word  ADC1_COMP_IRQHandler               // ADC1 , COMP1 and COMP2
133  .word  TMR1_BRK_UP_TRG_COM_IRQHandler     // TMR1 Break, Update, Trigger and Commutation
134  .word  TMR1_CC_IRQHandler                 // TMR1 Capture Compare
135  .word  TMR2_IRQHandler                    // TMR2
136  .word  TMR3_IRQHandler                    // TMR3
137  .word  TMR6_DAC_IRQHandler                // TMR6 and DAC
138  .word  TMR7_IRQHandler                    // TMR7
139  .word  TMR14_IRQHandler                   // TMR14
140  .word  TMR15_IRQHandler                   // TMR15
141  .word  TMR16_IRQHandler                   // TMR16
142  .word  TMR17_IRQHandler                   // TMR17
143  .word  I2C1_IRQHandler                    // I2C1
144  .word  I2C2_IRQHandler                    // I2C2
145  .word  SPI1_IRQHandler                    // SPI1
146  .word  SPI2_IRQHandler                    // SPI2
147  .word  USART1_IRQHandler                  // USART1
148  .word  USART2_IRQHandler                  // USART2
149  .word  USART3_8_IRQHandler                // USART3, USART4, USART5, USART6, USART7, USART8
150  .word  CEC_CAN_IRQHandler                 // CEC and CAN
151
152// Default exception/interrupt handler
153
154  .weak      NMI_Handler
155  .thumb_set NMI_Handler,Default_Handler
156
157  .weak      HardFault_Handler
158  .thumb_set HardFault_Handler,Default_Handler
159
160  .weak      SVC_Handler
161  .thumb_set SVC_Handler,Default_Handler
162
163  .weak      PendSV_Handler
164  .thumb_set PendSV_Handler,Default_Handler
165
166  .weak      SysTick_Handler
167  .thumb_set SysTick_Handler,Default_Handler
168
169  .weak      WWDT_IRQHandler
170  .thumb_set WWDT_IRQHandler,Default_Handler
171
172  .weak      PVD_VDDIO2_IRQHandler
173  .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler
174
175  .weak      RTC_IRQHandler
176  .thumb_set RTC_IRQHandler,Default_Handler
177
178  .weak      FLASH_IRQHandler
179  .thumb_set FLASH_IRQHandler,Default_Handler
180
181  .weak      RCM_CRS_IRQHandler
182  .thumb_set RCM_CRS_IRQHandler,Default_Handler
183
184  .weak      EINT0_1_IRQHandler
185  .thumb_set EINT0_1_IRQHandler,Default_Handler
186
187  .weak      EINT2_3_IRQHandler
188  .thumb_set EINT2_3_IRQHandler,Default_Handler
189
190  .weak      EINT4_15_IRQHandler
191  .thumb_set EINT4_15_IRQHandler,Default_Handler
192
193  .weak      TSC_IRQHandler
194  .thumb_set TSC_IRQHandler,Default_Handler
195
196  .weak      DMA1_CH1_IRQHandler
197  .thumb_set DMA1_CH1_IRQHandler,Default_Handler
198
199  .weak      DMA1_CH2_3_DMA2_CH1_2_IRQHandler
200  .thumb_set DMA1_CH2_3_DMA2_CH1_2_IRQHandler,Default_Handler
201
202  .weak      DMA1_CH4_7_DMA2_CH3_5_IRQHandler
203  .thumb_set DMA1_CH4_7_DMA2_CH3_5_IRQHandler,Default_Handler
204
205  .weak      ADC1_COMP_IRQHandler
206  .thumb_set ADC1_COMP_IRQHandler,Default_Handler
207
208  .weak      TMR1_BRK_UP_TRG_COM_IRQHandler
209  .thumb_set TMR1_BRK_UP_TRG_COM_IRQHandler,Default_Handler
210
211  .weak      TMR1_CC_IRQHandler
212  .thumb_set TMR1_CC_IRQHandler,Default_Handler
213
214  .weak      TMR2_IRQHandler
215  .thumb_set TMR2_IRQHandler,Default_Handler
216
217
218  .weak      TMR3_IRQHandler
219  .thumb_set TMR3_IRQHandler,Default_Handler
220
221  .weak      TMR6_DAC_IRQHandler
222  .thumb_set TMR6_DAC_IRQHandler,Default_Handler
223
224  .weak      TMR7_IRQHandler
225  .thumb_set TMR7_IRQHandler,Default_Handler
226
227  .weak      TMR14_IRQHandler
228  .thumb_set TMR14_IRQHandler,Default_Handler
229
230  .weak      TMR15_IRQHandler
231  .thumb_set TMR15_IRQHandler,Default_Handler
232
233  .weak      TMR16_IRQHandler
234  .thumb_set TMR16_IRQHandler,Default_Handler
235
236  .weak      TMR17_IRQHandler
237  .thumb_set TMR17_IRQHandler,Default_Handler
238
239  .weak      I2C1_IRQHandler
240  .thumb_set I2C1_IRQHandler,Default_Handler
241
242  .weak      I2C2_IRQHandler
243  .thumb_set I2C2_IRQHandler,Default_Handler
244
245  .weak      SPI1_IRQHandler
246  .thumb_set SPI1_IRQHandler,Default_Handler
247
248  .weak      SPI2_IRQHandler
249  .thumb_set SPI2_IRQHandler,Default_Handler
250
251  .weak      USART1_IRQHandler
252  .thumb_set USART1_IRQHandler,Default_Handler
253
254  .weak      USART2_IRQHandler
255  .thumb_set USART2_IRQHandler,Default_Handler
256
257  .weak      USART3_8_IRQHandler
258  .thumb_set USART3_8_IRQHandler,Default_Handler
259
260  .weak      CEC_CAN_IRQHandler
261  .thumb_set CEC_CAN_IRQHandler,Default_Handler
262