adding stm32f3 support
This commit is contained in:
		
							
								
								
									
										403
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f301x8.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										403
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f301x8.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,403 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f301x8.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F301x6/STM32F301x8 devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_IRQHandler | ||||
| 	.thumb_set ADC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler | ||||
|      | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										427
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302x8.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										427
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302x8.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,427 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f302x8.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F302x6/STM32F302x8 devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_IRQHandler | ||||
| 	.word	USB_HP_CAN_TX_IRQHandler | ||||
| 	.word	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_RMP_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_IRQHandler | ||||
| 	.thumb_set ADC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_HP_CAN_TX_IRQHandler | ||||
| 	.thumb_set USB_HP_CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.thumb_set USB_LP_CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
|    | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler   | ||||
| 	 | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_RMP_IRQHandler | ||||
| 	.thumb_set USBWakeUp_RMP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										451
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302xc.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										451
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302xc.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,451 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f302xc.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F302xB/STM32F302xC devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	USB_HP_CAN_TX_IRQHandler | ||||
| 	.word	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_RMP_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_HP_CAN_TX_IRQHandler | ||||
| 	.thumb_set USB_HP_CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.thumb_set USB_LP_CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP1_2_IRQHandler | ||||
| 	.thumb_set COMP1_2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_RMP_IRQHandler | ||||
| 	.thumb_set USBWakeUp_RMP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										478
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302xe.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										478
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f302xe.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,478 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f302xe.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F302xE devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	USB_HP_CAN_TX_IRQHandler | ||||
| 	.word	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FMC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_RMP_IRQHandler | ||||
| 	.word	TIM20_BRK_IRQHandler | ||||
| 	.word	TIM20_UP_IRQHandler | ||||
| 	.word	TIM20_TRG_COM_IRQHandler | ||||
| 	.word	TIM20_CC_IRQHandler | ||||
| 	.word	FPU_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI4_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_HP_CAN_TX_IRQHandler | ||||
| 	.thumb_set USB_HP_CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.thumb_set USB_LP_CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FMC_IRQHandler | ||||
| 	.thumb_set FMC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	COMP1_2_IRQHandler | ||||
| 	.thumb_set COMP1_2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_RMP_IRQHandler | ||||
| 	.thumb_set USBWakeUp_RMP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_BRK_IRQHandler | ||||
| 	.thumb_set TIM20_BRK_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_UP_IRQHandler | ||||
| 	.thumb_set TIM20_UP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM20_TRG_COM_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_CC_IRQHandler | ||||
| 	.thumb_set TIM20_CC_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	SPI4_IRQHandler | ||||
| 	.thumb_set SPI4_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										406
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303x8.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										406
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303x8.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,406 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f303x8.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F303x6/STM32F303x8 devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC1_IRQHandler | ||||
| 	.word	TIM7_DAC2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC1_IRQHandler | ||||
| 	.thumb_set TIM6_DAC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_DAC2_IRQHandler | ||||
| 	.thumb_set TIM7_DAC2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										475
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303xc.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										475
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303xc.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,475 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f303xc.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F303xB/STM32F303xC devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	USB_HP_CAN_TX_IRQHandler | ||||
| 	.word	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	TIM8_BRK_IRQHandler | ||||
| 	.word	TIM8_UP_IRQHandler | ||||
| 	.word	TIM8_TRG_COM_IRQHandler | ||||
| 	.word	TIM8_CC_IRQHandler | ||||
| 	.word	ADC3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	ADC4_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_3_IRQHandler | ||||
| 	.word	COMP4_5_6_IRQHandler | ||||
| 	.word	COMP7_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_RMP_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_HP_CAN_TX_IRQHandler | ||||
| 	.thumb_set USB_HP_CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.thumb_set USB_LP_CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_BRK_IRQHandler | ||||
| 	.thumb_set TIM8_BRK_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_UP_IRQHandler | ||||
| 	.thumb_set TIM8_UP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_CC_IRQHandler | ||||
| 	.thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC3_IRQHandler | ||||
| 	.thumb_set ADC3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC4_IRQHandler | ||||
| 	.thumb_set ADC4_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	COMP1_2_3_IRQHandler | ||||
| 	.thumb_set COMP1_2_3_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_5_6_IRQHandler | ||||
| 	.thumb_set COMP4_5_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP7_IRQHandler | ||||
| 	.thumb_set COMP7_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_RMP_IRQHandler | ||||
| 	.thumb_set USBWakeUp_RMP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										502
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303xe.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										502
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f303xe.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,502 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f303xe.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F303xE devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	USB_HP_CAN_TX_IRQHandler | ||||
| 	.word	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	TIM8_BRK_IRQHandler | ||||
| 	.word	TIM8_UP_IRQHandler | ||||
| 	.word	TIM8_TRG_COM_IRQHandler | ||||
| 	.word	TIM8_CC_IRQHandler | ||||
| 	.word	ADC3_IRQHandler | ||||
| 	.word	FMC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	ADC4_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_3_IRQHandler | ||||
| 	.word	COMP4_5_6_IRQHandler | ||||
| 	.word	COMP7_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_RMP_IRQHandler | ||||
| 	.word	TIM20_BRK_IRQHandler | ||||
| 	.word	TIM20_UP_IRQHandler | ||||
| 	.word	TIM20_TRG_COM_IRQHandler | ||||
| 	.word	TIM20_CC_IRQHandler | ||||
| 	.word	FPU_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI4_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_HP_CAN_TX_IRQHandler | ||||
| 	.thumb_set USB_HP_CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USB_LP_CAN_RX0_IRQHandler | ||||
| 	.thumb_set USB_LP_CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_BRK_IRQHandler | ||||
| 	.thumb_set TIM8_BRK_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_UP_IRQHandler | ||||
| 	.thumb_set TIM8_UP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_CC_IRQHandler | ||||
| 	.thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC3_IRQHandler | ||||
| 	.thumb_set ADC3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FMC_IRQHandler | ||||
| 	.thumb_set FMC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC4_IRQHandler | ||||
| 	.thumb_set ADC4_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	COMP1_2_3_IRQHandler | ||||
| 	.thumb_set COMP1_2_3_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_5_6_IRQHandler | ||||
| 	.thumb_set COMP4_5_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP7_IRQHandler | ||||
| 	.thumb_set COMP7_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_RMP_IRQHandler | ||||
| 	.thumb_set USBWakeUp_RMP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_BRK_IRQHandler | ||||
| 	.thumb_set TIM20_BRK_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_UP_IRQHandler | ||||
| 	.thumb_set TIM20_UP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM20_TRG_COM_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_CC_IRQHandler | ||||
| 	.thumb_set TIM20_CC_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	SPI4_IRQHandler | ||||
| 	.thumb_set SPI4_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										400
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f318xx.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										400
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f318xx.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,400 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f318xx.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F318xx device vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_IRQHandler | ||||
| 	.thumb_set ADC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler | ||||
|      | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										403
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f328xx.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										403
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f328xx.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,403 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f328xx.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F328xx device vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC1_IRQHandler | ||||
| 	.word	TIM7_DAC2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC1_IRQHandler | ||||
| 	.thumb_set TIM6_DAC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_DAC2_IRQHandler | ||||
| 	.thumb_set TIM7_DAC2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 		 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										427
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f334x8.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										427
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f334x8.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,427 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f334x8.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F334x4/STM32F334x6/STM32F334x8 devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC1_IRQHandler | ||||
| 	.word	TIM7_DAC2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP2_IRQHandler | ||||
| 	.word	COMP4_6_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	HRTIM1_Master_IRQHandler | ||||
| 	.word	HRTIM1_TIMA_IRQHandler | ||||
| 	.word	HRTIM1_TIMB_IRQHandler | ||||
| 	.word	HRTIM1_TIMC_IRQHandler | ||||
| 	.word	HRTIM1_TIMD_IRQHandler | ||||
| 	.word	HRTIM1_TIME_IRQHandler | ||||
| 	.word	HRTIM1_FLT_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC1_IRQHandler | ||||
| 	.thumb_set TIM6_DAC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_DAC2_IRQHandler | ||||
| 	.thumb_set TIM7_DAC2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP2_IRQHandler | ||||
| 	.thumb_set COMP2_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_6_IRQHandler | ||||
| 	.thumb_set COMP4_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	HRTIM1_Master_IRQHandler | ||||
| 	.thumb_set HRTIM1_Master_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	HRTIM1_TIMA_IRQHandler | ||||
| 	.thumb_set HRTIM1_TIMA_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	HRTIM1_TIMB_IRQHandler | ||||
| 	.thumb_set HRTIM1_TIMB_IRQHandler,Default_Handler   | ||||
|    | ||||
| 	.weak	HRTIM1_TIMC_IRQHandler | ||||
| 	.thumb_set HRTIM1_TIMC_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	HRTIM1_TIMD_IRQHandler | ||||
| 	.thumb_set HRTIM1_TIMD_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	HRTIM1_TIME_IRQHandler | ||||
| 	.thumb_set HRTIM1_TIME_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	HRTIM1_FLT_IRQHandler | ||||
| 	.thumb_set HRTIM1_FLT_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										460
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f358xx.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										460
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f358xx.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,460 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f358xx.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F358xx device vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TIM8_BRK_IRQHandler | ||||
| 	.word	TIM8_UP_IRQHandler | ||||
| 	.word	TIM8_TRG_COM_IRQHandler | ||||
| 	.word	TIM8_CC_IRQHandler | ||||
| 	.word	ADC3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	ADC4_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_3_IRQHandler | ||||
| 	.word	COMP4_5_6_IRQHandler | ||||
| 	.word	COMP7_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_BRK_IRQHandler | ||||
| 	.thumb_set TIM8_BRK_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_UP_IRQHandler | ||||
| 	.thumb_set TIM8_UP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_CC_IRQHandler | ||||
| 	.thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC3_IRQHandler | ||||
| 	.thumb_set ADC3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC4_IRQHandler | ||||
| 	.thumb_set ADC4_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	COMP1_2_3_IRQHandler | ||||
| 	.thumb_set COMP1_2_3_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_5_6_IRQHandler | ||||
| 	.thumb_set COMP4_5_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP7_IRQHandler | ||||
| 	.thumb_set COMP7_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										469
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f373xc.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										469
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f373xc.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,469 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f373xc.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F373xB/STM32F373xC devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	PVD_IRQHandler | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM15_IRQHandler | ||||
| 	.word	TIM16_IRQHandler | ||||
| 	.word	TIM17_IRQHandler | ||||
| 	.word	TIM18_DAC2_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	CEC_IRQHandler | ||||
| 	.word	TIM12_IRQHandler | ||||
| 	.word	TIM13_IRQHandler | ||||
| 	.word	TIM14_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM5_IRQHandler | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC1_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	SDADC1_IRQHandler | ||||
| 	.word	SDADC2_IRQHandler | ||||
| 	.word	SDADC3_IRQHandler | ||||
| 	.word	COMP1_2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	USB_HP_IRQHandler | ||||
| 	.word	USB_LP_IRQHandler | ||||
| 	.word	USBWakeUp_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TIM19_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	PVD_IRQHandler | ||||
| 	.thumb_set PVD_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_IRQHandler | ||||
| 	.thumb_set ADC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM15_IRQHandler | ||||
| 	.thumb_set TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM16_IRQHandler | ||||
| 	.thumb_set TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM17_IRQHandler | ||||
| 	.thumb_set TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM18_DAC2_IRQHandler | ||||
| 	.thumb_set TIM18_DAC2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CEC_IRQHandler | ||||
| 	.thumb_set CEC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM12_IRQHandler | ||||
| 	.thumb_set TIM12_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM13_IRQHandler | ||||
| 	.thumb_set TIM13_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM14_IRQHandler | ||||
| 	.thumb_set TIM14_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM5_IRQHandler | ||||
| 	.thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC1_IRQHandler | ||||
| 	.thumb_set TIM6_DAC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SDADC1_IRQHandler | ||||
| 	.thumb_set SDADC1_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	SDADC2_IRQHandler | ||||
| 	.thumb_set SDADC2_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	SDADC3_IRQHandler | ||||
| 	.thumb_set SDADC3_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	COMP1_2_IRQHandler | ||||
| 	.thumb_set COMP1_2_IRQHandler,Default_Handler	 | ||||
| 		 | ||||
| 	.weak	USB_HP_IRQHandler | ||||
| 	.thumb_set USB_HP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USB_LP_IRQHandler | ||||
| 	.thumb_set USB_LP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	USBWakeUp_IRQHandler | ||||
| 	.thumb_set USBWakeUp_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM19_IRQHandler | ||||
| 	.thumb_set TIM19_IRQHandler,Default_Handler | ||||
|   	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										457
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f378xx.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										457
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f378xx.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,457 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f378xx.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F378xx device vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM15_IRQHandler | ||||
| 	.word	TIM16_IRQHandler | ||||
| 	.word	TIM17_IRQHandler | ||||
| 	.word	TIM18_DAC2_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	CEC_IRQHandler | ||||
| 	.word	TIM12_IRQHandler | ||||
| 	.word	TIM13_IRQHandler | ||||
| 	.word	TIM14_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM5_IRQHandler | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM6_DAC1_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	SDADC1_IRQHandler | ||||
| 	.word	SDADC2_IRQHandler | ||||
| 	.word	SDADC3_IRQHandler | ||||
| 	.word	COMP1_2_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM19_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	FPU_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_IRQHandler | ||||
| 	.thumb_set ADC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM15_IRQHandler | ||||
| 	.thumb_set TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM16_IRQHandler | ||||
| 	.thumb_set TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM17_IRQHandler | ||||
| 	.thumb_set TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM18_DAC2_IRQHandler | ||||
| 	.thumb_set TIM18_DAC2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CEC_IRQHandler | ||||
| 	.thumb_set CEC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM12_IRQHandler | ||||
| 	.thumb_set TIM12_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM13_IRQHandler | ||||
| 	.thumb_set TIM13_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM14_IRQHandler | ||||
| 	.thumb_set TIM14_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM5_IRQHandler | ||||
| 	.thumb_set TIM5_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC1_IRQHandler | ||||
| 	.thumb_set TIM6_DAC1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SDADC1_IRQHandler | ||||
| 	.thumb_set SDADC1_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	SDADC2_IRQHandler | ||||
| 	.thumb_set SDADC2_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	SDADC3_IRQHandler | ||||
| 	.thumb_set SDADC3_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	COMP1_2_IRQHandler | ||||
| 	.thumb_set COMP1_2_IRQHandler,Default_Handler	 | ||||
|  | ||||
| 	.weak	TIM19_IRQHandler | ||||
| 	.thumb_set TIM19_IRQHandler,Default_Handler | ||||
|   	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										487
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f398xx.s
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										487
									
								
								hw/mcu/st/startup/stm32f3/startup_stm32f398xx.s
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,487 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file      startup_stm32f398xx.s | ||||
|   * @author    MCD Application Team | ||||
|   * @brief     STM32F398xx devices vector table for GCC toolchain. | ||||
|   *            This module performs: | ||||
|   *                - Set the initial SP | ||||
|   *                - Set the initial PC == Reset_Handler, | ||||
|   *                - Set the vector table entries with the exceptions ISR address, | ||||
|   *                - Configure the clock system   | ||||
|   *                - Branches to main in the C library (which eventually | ||||
|   *                  calls main()). | ||||
|   *            After Reset the Cortex-M4 processor is in Thread mode, | ||||
|   *            priority is Privileged, and the Stack is set to Main. | ||||
|   ****************************************************************************** | ||||
|   *  | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
|   .syntax unified | ||||
| 	.cpu cortex-m4 | ||||
| 	.fpu softvfp | ||||
| 	.thumb | ||||
|  | ||||
| .global	g_pfnVectors | ||||
| .global	Default_Handler | ||||
|  | ||||
| /* start address for the initialization values of the .data section. | ||||
| defined in linker script */ | ||||
| .word	_sidata | ||||
| /* start address for the .data section. defined in linker script */ | ||||
| .word	_sdata | ||||
| /* end address for the .data section. defined in linker script */ | ||||
| .word	_edata | ||||
| /* start address for the .bss section. defined in linker script */ | ||||
| .word	_sbss | ||||
| /* end address for the .bss section. defined in linker script */ | ||||
| .word	_ebss | ||||
|  | ||||
| .equ  BootRAM,        0xF1E0F85F | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor first | ||||
|  *          starts execution following a reset event. Only the absolutely | ||||
|  *          necessary set is performed, after which the application | ||||
|  *          supplied main() routine is called. | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|  | ||||
|     .section	.text.Reset_Handler | ||||
| 	.weak	Reset_Handler | ||||
| 	.type	Reset_Handler, %function | ||||
| Reset_Handler: | ||||
|   ldr   sp, =_estack    /* Atollic update: set stack pointer */ | ||||
|  | ||||
| /* Copy the data segment initializers from flash to SRAM */ | ||||
|   movs	r1, #0 | ||||
|   b	LoopCopyDataInit | ||||
|  | ||||
| CopyDataInit: | ||||
| 	ldr	r3, =_sidata | ||||
| 	ldr	r3, [r3, r1] | ||||
| 	str	r3, [r0, r1] | ||||
| 	adds	r1, r1, #4 | ||||
|  | ||||
| LoopCopyDataInit: | ||||
| 	ldr	r0, =_sdata | ||||
| 	ldr	r3, =_edata | ||||
| 	adds	r2, r0, r1 | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	CopyDataInit | ||||
| 	ldr	r2, =_sbss | ||||
| 	b	LoopFillZerobss | ||||
| /* Zero fill the bss segment. */ | ||||
| FillZerobss: | ||||
| 	movs	r3, #0 | ||||
| 	str	r3, [r2], #4 | ||||
|  | ||||
| LoopFillZerobss: | ||||
| 	ldr	r3, = _ebss | ||||
| 	cmp	r2, r3 | ||||
| 	bcc	FillZerobss | ||||
|  | ||||
| /* Call the clock system intitialization function.*/ | ||||
|     bl  SystemInit | ||||
| /* Call static constructors */ | ||||
|     bl __libc_init_array | ||||
| /* Call the application's entry point.*/ | ||||
| 	bl	main | ||||
|  | ||||
| LoopForever: | ||||
|     b LoopForever | ||||
|      | ||||
| .size	Reset_Handler, .-Reset_Handler | ||||
|  | ||||
| /** | ||||
|  * @brief  This is the code that gets called when the processor receives an | ||||
|  *         unexpected interrupt.  This simply enters an infinite loop, preserving | ||||
|  *         the system state for examination by a debugger. | ||||
|  * | ||||
|  * @param  None | ||||
|  * @retval : None | ||||
| */ | ||||
|     .section	.text.Default_Handler,"ax",%progbits | ||||
| Default_Handler: | ||||
| Infinite_Loop: | ||||
| 	b	Infinite_Loop | ||||
| 	.size	Default_Handler, .-Default_Handler | ||||
| /****************************************************************************** | ||||
| * | ||||
| * The minimal vector table for a Cortex-M4.  Note that the proper constructs | ||||
| * must be placed on this to ensure that it ends up at physical address | ||||
| * 0x0000.0000. | ||||
| * | ||||
| ******************************************************************************/ | ||||
|  	.section	.isr_vector,"a",%progbits | ||||
| 	.type	g_pfnVectors, %object | ||||
| 	.size	g_pfnVectors, .-g_pfnVectors | ||||
|  | ||||
|  | ||||
| g_pfnVectors: | ||||
| 	.word	_estack | ||||
| 	.word	Reset_Handler | ||||
| 	.word	NMI_Handler | ||||
| 	.word	HardFault_Handler | ||||
| 	.word	MemManage_Handler | ||||
| 	.word	BusFault_Handler | ||||
| 	.word	UsageFault_Handler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SVC_Handler | ||||
| 	.word	DebugMon_Handler | ||||
| 	.word	0 | ||||
| 	.word	PendSV_Handler | ||||
| 	.word	SysTick_Handler | ||||
| 	.word	WWDG_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TAMP_STAMP_IRQHandler | ||||
| 	.word	RTC_WKUP_IRQHandler | ||||
| 	.word	FLASH_IRQHandler | ||||
| 	.word	RCC_IRQHandler | ||||
| 	.word	EXTI0_IRQHandler | ||||
| 	.word	EXTI1_IRQHandler | ||||
| 	.word	EXTI2_TSC_IRQHandler | ||||
| 	.word	EXTI3_IRQHandler | ||||
| 	.word	EXTI4_IRQHandler | ||||
| 	.word	DMA1_Channel1_IRQHandler | ||||
| 	.word	DMA1_Channel2_IRQHandler | ||||
| 	.word	DMA1_Channel3_IRQHandler | ||||
| 	.word	DMA1_Channel4_IRQHandler | ||||
| 	.word	DMA1_Channel5_IRQHandler | ||||
| 	.word	DMA1_Channel6_IRQHandler | ||||
| 	.word	DMA1_Channel7_IRQHandler | ||||
| 	.word	ADC1_2_IRQHandler | ||||
| 	.word	CAN_TX_IRQHandler | ||||
| 	.word	CAN_RX0_IRQHandler | ||||
| 	.word	CAN_RX1_IRQHandler | ||||
| 	.word	CAN_SCE_IRQHandler | ||||
| 	.word	EXTI9_5_IRQHandler | ||||
| 	.word	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.word	TIM1_UP_TIM16_IRQHandler | ||||
| 	.word	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.word	TIM1_CC_IRQHandler | ||||
| 	.word	TIM2_IRQHandler | ||||
| 	.word	TIM3_IRQHandler | ||||
| 	.word	TIM4_IRQHandler | ||||
| 	.word	I2C1_EV_IRQHandler | ||||
| 	.word	I2C1_ER_IRQHandler | ||||
| 	.word	I2C2_EV_IRQHandler | ||||
| 	.word	I2C2_ER_IRQHandler | ||||
| 	.word	SPI1_IRQHandler | ||||
| 	.word	SPI2_IRQHandler | ||||
| 	.word	USART1_IRQHandler | ||||
| 	.word	USART2_IRQHandler | ||||
| 	.word	USART3_IRQHandler | ||||
| 	.word	EXTI15_10_IRQHandler | ||||
| 	.word	RTC_Alarm_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	TIM8_BRK_IRQHandler | ||||
| 	.word	TIM8_UP_IRQHandler | ||||
| 	.word	TIM8_TRG_COM_IRQHandler | ||||
| 	.word	TIM8_CC_IRQHandler | ||||
| 	.word	ADC3_IRQHandler | ||||
| 	.word	FMC_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI3_IRQHandler | ||||
| 	.word	UART4_IRQHandler | ||||
| 	.word	UART5_IRQHandler | ||||
| 	.word	TIM6_DAC_IRQHandler | ||||
| 	.word	TIM7_IRQHandler | ||||
| 	.word	DMA2_Channel1_IRQHandler | ||||
| 	.word	DMA2_Channel2_IRQHandler | ||||
| 	.word	DMA2_Channel3_IRQHandler | ||||
| 	.word	DMA2_Channel4_IRQHandler | ||||
| 	.word	DMA2_Channel5_IRQHandler | ||||
| 	.word	ADC4_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	COMP1_2_3_IRQHandler | ||||
| 	.word	COMP4_5_6_IRQHandler | ||||
| 	.word	COMP7_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	I2C3_EV_IRQHandler | ||||
| 	.word	I2C3_ER_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	TIM20_BRK_IRQHandler | ||||
| 	.word	TIM20_UP_IRQHandler | ||||
| 	.word	TIM20_TRG_COM_IRQHandler | ||||
| 	.word	TIM20_CC_IRQHandler | ||||
| 	.word	FPU_IRQHandler | ||||
| 	.word	0 | ||||
| 	.word	0 | ||||
| 	.word	SPI4_IRQHandler | ||||
|  | ||||
| /******************************************************************************* | ||||
| * | ||||
| * Provide weak aliases for each Exception handler to the Default_Handler. | ||||
| * As they are weak aliases, any function with the same name will override | ||||
| * this definition. | ||||
| * | ||||
| *******************************************************************************/ | ||||
|  | ||||
|   .weak	NMI_Handler | ||||
| 	.thumb_set NMI_Handler,Default_Handler | ||||
|  | ||||
|   .weak	HardFault_Handler | ||||
| 	.thumb_set HardFault_Handler,Default_Handler | ||||
|  | ||||
|   .weak	MemManage_Handler | ||||
| 	.thumb_set MemManage_Handler,Default_Handler | ||||
|  | ||||
|   .weak	BusFault_Handler | ||||
| 	.thumb_set BusFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	UsageFault_Handler | ||||
| 	.thumb_set UsageFault_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SVC_Handler | ||||
| 	.thumb_set SVC_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	DebugMon_Handler | ||||
| 	.thumb_set DebugMon_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	PendSV_Handler | ||||
| 	.thumb_set PendSV_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	SysTick_Handler | ||||
| 	.thumb_set SysTick_Handler,Default_Handler | ||||
|  | ||||
| 	.weak	WWDG_IRQHandler | ||||
| 	.thumb_set WWDG_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TAMP_STAMP_IRQHandler | ||||
| 	.thumb_set TAMP_STAMP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_WKUP_IRQHandler | ||||
| 	.thumb_set RTC_WKUP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FLASH_IRQHandler | ||||
| 	.thumb_set FLASH_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RCC_IRQHandler | ||||
| 	.thumb_set RCC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI0_IRQHandler | ||||
| 	.thumb_set EXTI0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI1_IRQHandler | ||||
| 	.thumb_set EXTI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI2_TSC_IRQHandler | ||||
| 	.thumb_set EXTI2_TSC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI3_IRQHandler | ||||
| 	.thumb_set EXTI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI4_IRQHandler | ||||
| 	.thumb_set EXTI4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel1_IRQHandler | ||||
| 	.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel2_IRQHandler | ||||
| 	.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel3_IRQHandler | ||||
| 	.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel4_IRQHandler | ||||
| 	.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel5_IRQHandler | ||||
| 	.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel6_IRQHandler | ||||
| 	.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA1_Channel7_IRQHandler | ||||
| 	.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC1_2_IRQHandler | ||||
| 	.thumb_set ADC1_2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_TX_IRQHandler | ||||
| 	.thumb_set CAN_TX_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX0_IRQHandler | ||||
| 	.thumb_set CAN_RX0_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_RX1_IRQHandler | ||||
| 	.thumb_set CAN_RX1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	CAN_SCE_IRQHandler | ||||
| 	.thumb_set CAN_SCE_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI9_5_IRQHandler | ||||
| 	.thumb_set EXTI9_5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_BRK_TIM15_IRQHandler | ||||
| 	.thumb_set TIM1_BRK_TIM15_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_UP_TIM16_IRQHandler | ||||
| 	.thumb_set TIM1_UP_TIM16_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_TRG_COM_TIM17_IRQHandler | ||||
| 	.thumb_set TIM1_TRG_COM_TIM17_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM1_CC_IRQHandler | ||||
| 	.thumb_set TIM1_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM2_IRQHandler | ||||
| 	.thumb_set TIM2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM3_IRQHandler | ||||
| 	.thumb_set TIM3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM4_IRQHandler | ||||
| 	.thumb_set TIM4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_EV_IRQHandler | ||||
| 	.thumb_set I2C1_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C1_ER_IRQHandler | ||||
| 	.thumb_set I2C1_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_EV_IRQHandler | ||||
| 	.thumb_set I2C2_EV_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	I2C2_ER_IRQHandler | ||||
| 	.thumb_set I2C2_ER_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI1_IRQHandler | ||||
| 	.thumb_set SPI1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI2_IRQHandler | ||||
| 	.thumb_set SPI2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART1_IRQHandler | ||||
| 	.thumb_set USART1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART2_IRQHandler | ||||
| 	.thumb_set USART2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	USART3_IRQHandler | ||||
| 	.thumb_set USART3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	EXTI15_10_IRQHandler | ||||
| 	.thumb_set EXTI15_10_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	RTC_Alarm_IRQHandler | ||||
| 	.thumb_set RTC_Alarm_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_BRK_IRQHandler | ||||
| 	.thumb_set TIM8_BRK_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_UP_IRQHandler | ||||
| 	.thumb_set TIM8_UP_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM8_TRG_COM_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM8_CC_IRQHandler | ||||
| 	.thumb_set TIM8_CC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC3_IRQHandler | ||||
| 	.thumb_set ADC3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	FMC_IRQHandler | ||||
| 	.thumb_set FMC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	SPI3_IRQHandler | ||||
| 	.thumb_set SPI3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART4_IRQHandler | ||||
| 	.thumb_set UART4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	UART5_IRQHandler | ||||
| 	.thumb_set UART5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM6_DAC_IRQHandler | ||||
| 	.thumb_set TIM6_DAC_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	TIM7_IRQHandler | ||||
| 	.thumb_set TIM7_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel1_IRQHandler | ||||
| 	.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel2_IRQHandler | ||||
| 	.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel3_IRQHandler | ||||
| 	.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel4_IRQHandler | ||||
| 	.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	DMA2_Channel5_IRQHandler | ||||
| 	.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | ||||
|  | ||||
| 	.weak	ADC4_IRQHandler | ||||
| 	.thumb_set ADC4_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	COMP1_2_3_IRQHandler | ||||
| 	.thumb_set COMP1_2_3_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP4_5_6_IRQHandler | ||||
| 	.thumb_set COMP4_5_6_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	COMP7_IRQHandler | ||||
| 	.thumb_set COMP7_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	I2C3_EV_IRQHandler | ||||
| 	.thumb_set I2C3_EV_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	I2C3_ER_IRQHandler | ||||
| 	.thumb_set I2C3_ER_IRQHandler,Default_Handler	 | ||||
| 	 | ||||
| 	.weak	TIM20_BRK_IRQHandler | ||||
| 	.thumb_set TIM20_BRK_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_UP_IRQHandler | ||||
| 	.thumb_set TIM20_UP_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_TRG_COM_IRQHandler | ||||
| 	.thumb_set TIM20_TRG_COM_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	TIM20_CC_IRQHandler | ||||
| 	.thumb_set TIM20_CC_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	FPU_IRQHandler | ||||
| 	.thumb_set FPU_IRQHandler,Default_Handler | ||||
| 	 | ||||
| 	.weak	SPI4_IRQHandler | ||||
| 	.thumb_set SPI4_IRQHandler,Default_Handler | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
							
								
								
									
										314
									
								
								hw/mcu/st/system-init/system_stm32f3xx.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										314
									
								
								hw/mcu/st/system-init/system_stm32f3xx.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,314 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32f3xx.c | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   CMSIS Cortex-M4 Device Peripheral Access Layer System Source File. | ||||
|   * | ||||
|   * 1. This file provides two functions and one global variable to be called from | ||||
|   *    user application: | ||||
|   *      - SystemInit(): This function is called at startup just after reset and  | ||||
|   *                      before branch to main program. This call is made inside | ||||
|   *                      the "startup_stm32f3xx.s" file. | ||||
|   * | ||||
|   *      - SystemCoreClock variable: Contains the core clock (HCLK), it can be used | ||||
|   *                                  by the user application to setup the SysTick | ||||
|   *                                  timer or configure other parameters. | ||||
|   * | ||||
|   *      - SystemCoreClockUpdate(): Updates the variable SystemCoreClock and must | ||||
|   *                                 be called whenever the core clock is changed | ||||
|   *                                 during program execution. | ||||
|   * | ||||
|   * 2. After each device reset the HSI (8 MHz) is used as system clock source. | ||||
|   *    Then SystemInit() function is called, in "startup_stm32f3xx.s" file, to | ||||
|   *    configure the system clock before to branch to main program. | ||||
|   * | ||||
|   * 3. This file configures the system clock as follows: | ||||
|   *============================================================================= | ||||
|   *                         Supported STM32F3xx device | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        System Clock source                    | HSI | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        SYSCLK(Hz)                             | 8000000 | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        HCLK(Hz)                               | 8000000 | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        AHB Prescaler                          | 1 | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        APB2 Prescaler                         | 1 | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        APB1 Prescaler                         | 1 | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *        USB Clock                              | DISABLE | ||||
|   *----------------------------------------------------------------------------- | ||||
|   *============================================================================= | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT(c) 2016 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Redistribution and use in source and binary forms, with or without modification, | ||||
|   * are permitted provided that the following conditions are met: | ||||
|   *   1. Redistributions of source code must retain the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer. | ||||
|   *   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|   *      this list of conditions and the following disclaimer in the documentation | ||||
|   *      and/or other materials provided with the distribution. | ||||
|   *   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
|   *      may be used to endorse or promote products derived from this software | ||||
|   *      without specific prior written permission. | ||||
|   * | ||||
|   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
|   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
|   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
|   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
|   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
|   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
|   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup CMSIS | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup stm32f3xx_system | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_Includes | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #include "stm32f3xx.h" | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_TypesDefinitions | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_Defines | ||||
|   * @{ | ||||
|   */ | ||||
| #if !defined  (HSE_VALUE)  | ||||
|   #define HSE_VALUE    ((uint32_t)8000000) /*!< Default value of the External oscillator in Hz. | ||||
|                                                 This value can be provided and adapted by the user application. */ | ||||
| #endif /* HSE_VALUE */ | ||||
|  | ||||
| #if !defined  (HSI_VALUE) | ||||
|   #define HSI_VALUE    ((uint32_t)8000000) /*!< Default value of the Internal oscillator in Hz. | ||||
|                                                 This value can be provided and adapted by the user application. */ | ||||
| #endif /* HSI_VALUE */ | ||||
|  | ||||
| /*!< Uncomment the following line if you need to relocate your vector Table in | ||||
|      Internal SRAM. */ | ||||
| /* #define VECT_TAB_SRAM */ | ||||
| #define VECT_TAB_OFFSET  0x0 /*!< Vector Table base offset field. | ||||
|                                   This value must be a multiple of 0x200. */ | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_Macros | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_Variables | ||||
|   * @{ | ||||
|   */ | ||||
|   /* This variable is updated in three ways: | ||||
|       1) by calling CMSIS function SystemCoreClockUpdate() | ||||
|       2) by calling HAL API function HAL_RCC_GetHCLKFreq() | ||||
|       3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency | ||||
|          Note: If you use this function to configure the system clock there is no need to | ||||
|                call the 2 first functions listed above, since SystemCoreClock variable is  | ||||
|                updated automatically. | ||||
|   */ | ||||
| uint32_t SystemCoreClock = 8000000; | ||||
|  | ||||
| const uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; | ||||
| const uint8_t APBPrescTable[8]  = {0, 0, 0, 0, 1, 2, 3, 4}; | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_FunctionPrototypes | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F3xx_System_Private_Functions | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @brief  Setup the microcontroller system | ||||
|   *         Initialize the FPU setting, vector table location and the PLL configuration is reset. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemInit(void) | ||||
| { | ||||
|   /* FPU settings ------------------------------------------------------------*/ | ||||
|   #if (__FPU_PRESENT == 1) && (__FPU_USED == 1) | ||||
|     SCB->CPACR |= ((3UL << 10*2)|(3UL << 11*2));  /* set CP10 and CP11 Full Access */ | ||||
|   #endif | ||||
|  | ||||
|   /* Reset the RCC clock configuration to the default reset state ------------*/ | ||||
|   /* Set HSION bit */ | ||||
|   RCC->CR |= 0x00000001U; | ||||
|  | ||||
|   /* Reset CFGR register */ | ||||
|   RCC->CFGR &= 0xF87FC00CU; | ||||
|  | ||||
|   /* Reset HSEON, CSSON and PLLON bits */ | ||||
|   RCC->CR &= 0xFEF6FFFFU; | ||||
|  | ||||
|   /* Reset HSEBYP bit */ | ||||
|   RCC->CR &= 0xFFFBFFFFU; | ||||
|  | ||||
|   /* Reset PLLSRC, PLLXTPRE, PLLMUL and USBPRE bits */ | ||||
|   RCC->CFGR &= 0xFF80FFFFU; | ||||
|  | ||||
|   /* Reset PREDIV1[3:0] bits */ | ||||
|   RCC->CFGR2 &= 0xFFFFFFF0U; | ||||
|  | ||||
|   /* Reset USARTSW[1:0], I2CSW and TIMs bits */ | ||||
|   RCC->CFGR3 &= 0xFF00FCCCU; | ||||
|  | ||||
|   /* Disable all interrupts */ | ||||
|   RCC->CIR = 0x00000000U; | ||||
|  | ||||
| #ifdef VECT_TAB_SRAM | ||||
|   SCB->VTOR = SRAM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM */ | ||||
| #else | ||||
|   SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH */ | ||||
| #endif | ||||
| } | ||||
|  | ||||
| /** | ||||
|    * @brief  Update SystemCoreClock variable according to Clock Register Values. | ||||
|   *         The SystemCoreClock variable contains the core clock (HCLK), it can | ||||
|   *         be used by the user application to setup the SysTick timer or configure | ||||
|   *         other parameters. | ||||
|   * | ||||
|   * @note   Each time the core clock (HCLK) changes, this function must be called | ||||
|   *         to update SystemCoreClock variable value. Otherwise, any configuration | ||||
|   *         based on this variable will be incorrect. | ||||
|   * | ||||
|   * @note   - The system frequency computed by this function is not the real | ||||
|   *           frequency in the chip. It is calculated based on the predefined | ||||
|   *           constant and the selected clock source: | ||||
|   * | ||||
|   *           - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*) | ||||
|   * | ||||
|   *           - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**) | ||||
|   * | ||||
|   *           - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**) | ||||
|   *             or HSI_VALUE(*) multiplied/divided by the PLL factors. | ||||
|   * | ||||
|   *         (*) HSI_VALUE is a constant defined in stm32f3xx_hal.h file (default value | ||||
|   *             8 MHz) but the real value may vary depending on the variations | ||||
|   *             in voltage and temperature. | ||||
|   * | ||||
|   *         (**) HSE_VALUE is a constant defined in stm32f3xx_hal.h file (default value | ||||
|   *              8 MHz), user has to ensure that HSE_VALUE is same as the real | ||||
|   *              frequency of the crystal used. Otherwise, this function may | ||||
|   *              have wrong result. | ||||
|   * | ||||
|   *         - The result of this function could be not correct when using fractional | ||||
|   *           value for HSE crystal. | ||||
|   * | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemCoreClockUpdate (void) | ||||
| { | ||||
|   uint32_t tmp = 0, pllmull = 0, pllsource = 0, predivfactor = 0; | ||||
|  | ||||
|   /* Get SYSCLK source -------------------------------------------------------*/ | ||||
|   tmp = RCC->CFGR & RCC_CFGR_SWS; | ||||
|  | ||||
|   switch (tmp) | ||||
|   { | ||||
|     case RCC_CFGR_SWS_HSI:  /* HSI used as system clock */ | ||||
|       SystemCoreClock = HSI_VALUE; | ||||
|       break; | ||||
|     case RCC_CFGR_SWS_HSE:  /* HSE used as system clock */ | ||||
|       SystemCoreClock = HSE_VALUE; | ||||
|       break; | ||||
|     case RCC_CFGR_SWS_PLL:  /* PLL used as system clock */ | ||||
|       /* Get PLL clock source and multiplication factor ----------------------*/ | ||||
|       pllmull = RCC->CFGR & RCC_CFGR_PLLMUL; | ||||
|       pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; | ||||
|       pllmull = ( pllmull >> 18) + 2; | ||||
|  | ||||
| #if defined (STM32F302xE) || defined (STM32F303xE) || defined (STM32F398xx) | ||||
|         predivfactor = (RCC->CFGR2 & RCC_CFGR2_PREDIV) + 1; | ||||
|       if (pllsource == RCC_CFGR_PLLSRC_HSE_PREDIV) | ||||
|       { | ||||
|         /* HSE oscillator clock selected as PREDIV1 clock entry */ | ||||
|         SystemCoreClock = (HSE_VALUE / predivfactor) * pllmull; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         /* HSI oscillator clock selected as PREDIV1 clock entry */ | ||||
|         SystemCoreClock = (HSI_VALUE / predivfactor) * pllmull; | ||||
|       } | ||||
| #else       | ||||
|       if (pllsource == RCC_CFGR_PLLSRC_HSI_DIV2) | ||||
|       { | ||||
|         /* HSI oscillator clock divided by 2 selected as PLL clock entry */ | ||||
|         SystemCoreClock = (HSI_VALUE >> 1) * pllmull; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         predivfactor = (RCC->CFGR2 & RCC_CFGR2_PREDIV) + 1; | ||||
|         /* HSE oscillator clock selected as PREDIV1 clock entry */ | ||||
|         SystemCoreClock = (HSE_VALUE / predivfactor) * pllmull; | ||||
|       } | ||||
| #endif /* STM32F302xE || STM32F303xE || STM32F398xx */ | ||||
|       break; | ||||
|     default: /* HSI used as system clock */ | ||||
|       SystemCoreClock = HSI_VALUE; | ||||
|       break; | ||||
|   } | ||||
|   /* Compute HCLK clock frequency ----------------*/ | ||||
|   /* Get HCLK prescaler */ | ||||
|   tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4)]; | ||||
|   /* HCLK clock frequency */ | ||||
|   SystemCoreClock >>= tmp; | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach