407 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			407 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /**
 | |
|   ******************************************************************************
 | |
|   * @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****/
 | 
