You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
433 lines
18 KiB
433 lines
18 KiB
; **************************************************************************** |
|
; Copyright (c) 2019, Nations Technologies Inc. |
|
; |
|
; All rights reserved. |
|
; **************************************************************************** |
|
; |
|
; Redistribution and use in source and binary forms, with or without |
|
; modification, are permitted provided that the following conditions are met: |
|
; |
|
; - Redistributions of source code must retain the above copyright notice, |
|
; this list of conditions and the disclaimer below. |
|
; |
|
; Nations' name may not be used to endorse or promote products derived from |
|
; this software without specific prior written permission. |
|
; |
|
; DISCLAIMER: THIS SOFTWARE IS PROVIDED BY NATIONS "AS IS" AND ANY EXPRESS OR |
|
; IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
|
; MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE |
|
; DISCLAIMED. IN NO EVENT SHALL NATIONS 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. |
|
; **************************************************************************** |
|
|
|
; Amount of memory (in bytes) allocated for Stack |
|
; Tailor this value to your application needs |
|
; <h> Stack Configuration |
|
; <o> Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> |
|
; </h> |
|
|
|
Stack_Size EQU 0x00001500 |
|
|
|
AREA STACK, NOINIT, READWRITE, ALIGN=3 |
|
Stack_Mem SPACE Stack_Size |
|
__initial_sp |
|
|
|
; <h> Heap Configuration |
|
; <o> Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> |
|
; </h> |
|
|
|
Heap_Size EQU 0x00000300 |
|
|
|
AREA HEAP, NOINIT, READWRITE, ALIGN=3 |
|
__heap_base |
|
Heap_Mem SPACE Heap_Size |
|
__heap_limit |
|
|
|
PRESERVE8 |
|
THUMB |
|
|
|
|
|
; Vector Table Mapped to Address 0 at Reset |
|
AREA RESET, DATA, READONLY |
|
EXPORT __Vectors |
|
EXPORT __Vectors_End |
|
EXPORT __Vectors_Size |
|
|
|
__Vectors DCD __initial_sp ; Top of Stack |
|
DCD Reset_Handler ; Reset Handler |
|
DCD NMI_Handler ; NMI Handler |
|
DCD HardFault_Handler ; Hard Fault Handler |
|
DCD MemManage_Handler ; MPU Fault Handler |
|
DCD BusFault_Handler ; Bus Fault Handler |
|
DCD UsageFault_Handler ; Usage Fault Handler |
|
DCD 0 ; Reserved |
|
DCD 0 ; Reserved |
|
DCD 0 ; Reserved |
|
DCD 0 ; Reserved |
|
DCD SVC_Handler ; SVCall Handler |
|
DCD DebugMon_Handler ; Debug Monitor Handler |
|
DCD 0 ; Reserved |
|
DCD PendSV_Handler ; PendSV Handler |
|
DCD SysTick_Handler ; SysTick Handler |
|
|
|
; External Interrupts |
|
DCD WWDG_IRQHandler ; Window Watchdog |
|
DCD PVD_IRQHandler ; PVD through EXTI Line detect |
|
DCD TAMPER_IRQHandler ; Tamper |
|
DCD RTC_WKUP_IRQHandler ; RTC_WKUP |
|
DCD FLASH_IRQHandler ; Flash |
|
DCD RCC_IRQHandler ; RCC |
|
DCD EXTI0_IRQHandler ; EXTI Line 0 |
|
DCD EXTI1_IRQHandler ; EXTI Line 1 |
|
DCD EXTI2_IRQHandler ; EXTI Line 2 |
|
DCD EXTI3_IRQHandler ; EXTI Line 3 |
|
DCD EXTI4_IRQHandler ; EXTI Line 4 |
|
DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 |
|
DCD DMA1_Channel2_IRQHandler ; DMA1 Channel 2 |
|
DCD DMA1_Channel3_IRQHandler ; DMA1 Channel 3 |
|
DCD DMA1_Channel4_IRQHandler ; DMA1 Channel 4 |
|
DCD DMA1_Channel5_IRQHandler ; DMA1 Channel 5 |
|
DCD DMA1_Channel6_IRQHandler ; DMA1 Channel 6 |
|
DCD DMA1_Channel7_IRQHandler ; DMA1 Channel 7 |
|
DCD ADC1_2_IRQHandler ; ADC1 & ADC2 |
|
DCD USB_HP_CAN1_TX_IRQHandler ; USB High Priority or CAN1 TX |
|
DCD USB_LP_CAN1_RX0_IRQHandler ; USB Low Priority or CAN1 RX0 |
|
DCD CAN1_RX1_IRQHandler ; CAN1 RX1 |
|
DCD CAN1_SCE_IRQHandler ; CAN1 SCE |
|
DCD EXTI9_5_IRQHandler ; EXTI Line 9..5 |
|
DCD TIM1_BRK_IRQHandler ; TIM1 Break |
|
DCD TIM1_UP_IRQHandler ; TIM1 Update |
|
DCD TIM1_TRG_COM_IRQHandler ; TIM1 Trigger and Commutation |
|
DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare |
|
DCD TIM2_IRQHandler ; TIM2 |
|
DCD TIM3_IRQHandler ; TIM3 |
|
DCD TIM4_IRQHandler ; TIM4 |
|
DCD I2C1_EV_IRQHandler ; I2C1 Event |
|
DCD I2C1_ER_IRQHandler ; I2C1 Error |
|
DCD I2C2_EV_IRQHandler ; I2C2 Event |
|
DCD I2C2_ER_IRQHandler ; I2C2 Error |
|
DCD SPI1_IRQHandler ; SPI1 |
|
DCD SPI2_IRQHandler ; SPI2 |
|
DCD USART1_IRQHandler ; USART1 |
|
DCD USART2_IRQHandler ; USART2 |
|
DCD USART3_IRQHandler ; USART3 |
|
DCD EXTI15_10_IRQHandler ; EXTI Line 15..10 |
|
DCD RTCAlarm_IRQHandler ; RTC Alarm through EXTI Line |
|
DCD USBWakeUp_IRQHandler ; USB Wakeup from suspend |
|
DCD TIM8_BRK_IRQHandler ; TIM8 Break |
|
DCD TIM8_UP_IRQHandler ; TIM8 Update |
|
DCD TIM8_TRG_COM_IRQHandler ; TIM8 Trigger and Commutation |
|
DCD TIM8_CC_IRQHandler ; TIM8 Capture Compare |
|
DCD ADC3_4_IRQHandler ; ADC3 & ADC4 |
|
DCD XFMC_IRQHandler ; XFMC |
|
DCD SDIO_IRQHandler ; SDIO |
|
DCD TIM5_IRQHandler ; TIM5 |
|
DCD SPI3_IRQHandler ; SPI3 |
|
DCD UART4_IRQHandler ; UART4 |
|
DCD UART5_IRQHandler ; UART5 |
|
DCD TIM6_IRQHandler ; TIM6 |
|
DCD TIM7_IRQHandler ; TIM7 |
|
DCD DMA2_Channel1_IRQHandler ; DMA2 Channel1 |
|
DCD DMA2_Channel2_IRQHandler ; DMA2 Channel2 |
|
DCD DMA2_Channel3_IRQHandler ; DMA2 Channel3 |
|
DCD DMA2_Channel4_IRQHandler ; DMA2 Channel4 |
|
DCD DMA2_Channel5_IRQHandler ; DMA2 Channel5 |
|
DCD ETH_IRQHandler ; Ethernet global interrupt |
|
DCD ETH_WKUP_IRQHandler ; Ethernet Wakeup through EXTI line interrupt |
|
DCD CAN2_TX_IRQHandler ; CAN2 TX |
|
DCD CAN2_RX0_IRQHandler ; CAN2 RX0 |
|
DCD CAN2_RX1_IRQHandler ; CAN2 RX1 |
|
DCD CAN2_SCE_IRQHandler ; CAN2 SCE |
|
DCD QSPI_IRQHandler ; QSPI |
|
DCD DMA2_Channel6_IRQHandler ; DMA2 Channel6 |
|
DCD DMA2_Channel7_IRQHandler ; DMA2 Channel7 |
|
DCD I2C3_EV_IRQHandler ; I2C3 event |
|
DCD I2C3_ER_IRQHandler ; I2C3 error |
|
DCD I2C4_EV_IRQHandler ; I2C4 event |
|
DCD I2C4_ER_IRQHandler ; I2C4 error |
|
DCD UART6_IRQHandler ; UART6 |
|
DCD UART7_IRQHandler ; UART7 |
|
DCD DMA1_Channel8_IRQHandler ; DMA1 Channel8 |
|
DCD DMA2_Channel8_IRQHandler ; DMA2 Channel8 |
|
DCD DVP_IRQHandler ; DVP |
|
DCD SAC_IRQHandler ; SAC |
|
DCD MMU_IRQHandler ; MMU |
|
DCD TSC_IRQHandler ; TSC |
|
DCD COMP_1_2_3_IRQHandler ; COMP1 & COMP2 & COMP3 |
|
DCD COMP_4_5_6_IRQHandler ; COMP4 & COMP5 & COMP6 |
|
DCD COMP7_IRQHandler ; COMP7 |
|
DCD RSRAM_IRQHandler ; R-SRAM parity error interrupt |
|
__Vectors_End |
|
|
|
__Vectors_Size EQU __Vectors_End - __Vectors |
|
|
|
AREA |.text|, CODE, READONLY |
|
|
|
; Reset handler |
|
Reset_Handler PROC |
|
EXPORT Reset_Handler [WEAK] |
|
IMPORT __main |
|
IMPORT SystemInit |
|
LDR R0, =SystemInit |
|
BLX R0 |
|
LDR R0, =__main |
|
BX R0 |
|
ENDP |
|
|
|
; Dummy Exception Handlers (infinite loops which can be modified) |
|
|
|
NMI_Handler PROC |
|
EXPORT NMI_Handler [WEAK] |
|
B . |
|
ENDP |
|
HardFault_Handler\ |
|
PROC |
|
EXPORT HardFault_Handler [WEAK] |
|
B . |
|
ENDP |
|
MemManage_Handler\ |
|
PROC |
|
EXPORT MemManage_Handler [WEAK] |
|
B . |
|
ENDP |
|
BusFault_Handler\ |
|
PROC |
|
EXPORT BusFault_Handler [WEAK] |
|
B . |
|
ENDP |
|
UsageFault_Handler\ |
|
PROC |
|
EXPORT UsageFault_Handler [WEAK] |
|
B . |
|
ENDP |
|
SVC_Handler PROC |
|
EXPORT SVC_Handler [WEAK] |
|
B . |
|
ENDP |
|
DebugMon_Handler\ |
|
PROC |
|
EXPORT DebugMon_Handler [WEAK] |
|
B . |
|
ENDP |
|
PendSV_Handler PROC |
|
EXPORT PendSV_Handler [WEAK] |
|
B . |
|
ENDP |
|
SysTick_Handler PROC |
|
EXPORT SysTick_Handler [WEAK] |
|
B . |
|
ENDP |
|
|
|
Default_Handler PROC |
|
|
|
EXPORT WWDG_IRQHandler [WEAK] |
|
EXPORT PVD_IRQHandler [WEAK] |
|
EXPORT TAMPER_IRQHandler [WEAK] |
|
EXPORT RTC_WKUP_IRQHandler [WEAK] |
|
EXPORT FLASH_IRQHandler [WEAK] |
|
EXPORT RCC_IRQHandler [WEAK] |
|
EXPORT EXTI0_IRQHandler [WEAK] |
|
EXPORT EXTI1_IRQHandler [WEAK] |
|
EXPORT EXTI2_IRQHandler [WEAK] |
|
EXPORT EXTI3_IRQHandler [WEAK] |
|
EXPORT EXTI4_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel1_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel2_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel3_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel4_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel5_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel6_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel7_IRQHandler [WEAK] |
|
EXPORT ADC1_2_IRQHandler [WEAK] |
|
EXPORT USB_HP_CAN1_TX_IRQHandler [WEAK] |
|
EXPORT USB_LP_CAN1_RX0_IRQHandler [WEAK] |
|
EXPORT CAN1_RX1_IRQHandler [WEAK] |
|
EXPORT CAN1_SCE_IRQHandler [WEAK] |
|
EXPORT EXTI9_5_IRQHandler [WEAK] |
|
EXPORT TIM1_BRK_IRQHandler [WEAK] |
|
EXPORT TIM1_UP_IRQHandler [WEAK] |
|
EXPORT TIM1_TRG_COM_IRQHandler [WEAK] |
|
EXPORT TIM1_CC_IRQHandler [WEAK] |
|
EXPORT TIM2_IRQHandler [WEAK] |
|
EXPORT TIM3_IRQHandler [WEAK] |
|
EXPORT TIM4_IRQHandler [WEAK] |
|
EXPORT I2C1_EV_IRQHandler [WEAK] |
|
EXPORT I2C1_ER_IRQHandler [WEAK] |
|
EXPORT I2C2_EV_IRQHandler [WEAK] |
|
EXPORT I2C2_ER_IRQHandler [WEAK] |
|
EXPORT SPI1_IRQHandler [WEAK] |
|
EXPORT SPI2_IRQHandler [WEAK] |
|
EXPORT USART1_IRQHandler [WEAK] |
|
EXPORT USART2_IRQHandler [WEAK] |
|
EXPORT USART3_IRQHandler [WEAK] |
|
EXPORT EXTI15_10_IRQHandler [WEAK] |
|
EXPORT RTCAlarm_IRQHandler [WEAK] |
|
EXPORT USBWakeUp_IRQHandler [WEAK] |
|
EXPORT TIM8_BRK_IRQHandler [WEAK] |
|
EXPORT TIM8_UP_IRQHandler [WEAK] |
|
EXPORT TIM8_TRG_COM_IRQHandler [WEAK] |
|
EXPORT TIM8_CC_IRQHandler [WEAK] |
|
EXPORT ADC3_4_IRQHandler [WEAK] |
|
EXPORT XFMC_IRQHandler [WEAK] |
|
EXPORT SDIO_IRQHandler [WEAK] |
|
EXPORT TIM5_IRQHandler [WEAK] |
|
EXPORT SPI3_IRQHandler [WEAK] |
|
EXPORT UART4_IRQHandler [WEAK] |
|
EXPORT UART5_IRQHandler [WEAK] |
|
EXPORT TIM6_IRQHandler [WEAK] |
|
EXPORT TIM7_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel1_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel2_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel3_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel4_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel5_IRQHandler [WEAK] |
|
EXPORT ETH_IRQHandler [WEAK] |
|
EXPORT ETH_WKUP_IRQHandler [WEAK] |
|
EXPORT CAN2_TX_IRQHandler [WEAK] |
|
EXPORT CAN2_RX0_IRQHandler [WEAK] |
|
EXPORT CAN2_RX1_IRQHandler [WEAK] |
|
EXPORT CAN2_SCE_IRQHandler [WEAK] |
|
EXPORT QSPI_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel6_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel7_IRQHandler [WEAK] |
|
EXPORT I2C3_EV_IRQHandler [WEAK] |
|
EXPORT I2C3_ER_IRQHandler [WEAK] |
|
EXPORT I2C4_EV_IRQHandler [WEAK] |
|
EXPORT I2C4_ER_IRQHandler [WEAK] |
|
EXPORT UART6_IRQHandler [WEAK] |
|
EXPORT UART7_IRQHandler [WEAK] |
|
EXPORT DMA1_Channel8_IRQHandler [WEAK] |
|
EXPORT DMA2_Channel8_IRQHandler [WEAK] |
|
EXPORT DVP_IRQHandler [WEAK] |
|
EXPORT SAC_IRQHandler [WEAK] |
|
EXPORT MMU_IRQHandler [WEAK] |
|
EXPORT TSC_IRQHandler [WEAK] |
|
EXPORT COMP_1_2_3_IRQHandler [WEAK] |
|
EXPORT COMP_4_5_6_IRQHandler [WEAK] |
|
EXPORT COMP7_IRQHandler [WEAK] |
|
EXPORT RSRAM_IRQHandler [WEAK] |
|
|
|
WWDG_IRQHandler |
|
PVD_IRQHandler |
|
TAMPER_IRQHandler |
|
RTC_WKUP_IRQHandler |
|
FLASH_IRQHandler |
|
RCC_IRQHandler |
|
EXTI0_IRQHandler |
|
EXTI1_IRQHandler |
|
EXTI2_IRQHandler |
|
EXTI3_IRQHandler |
|
EXTI4_IRQHandler |
|
DMA1_Channel1_IRQHandler |
|
DMA1_Channel2_IRQHandler |
|
DMA1_Channel3_IRQHandler |
|
DMA1_Channel4_IRQHandler |
|
DMA1_Channel5_IRQHandler |
|
DMA1_Channel6_IRQHandler |
|
DMA1_Channel7_IRQHandler |
|
ADC1_2_IRQHandler |
|
USB_HP_CAN1_TX_IRQHandler |
|
USB_LP_CAN1_RX0_IRQHandler |
|
CAN1_RX1_IRQHandler |
|
CAN1_SCE_IRQHandler |
|
EXTI9_5_IRQHandler |
|
TIM1_BRK_IRQHandler |
|
TIM1_UP_IRQHandler |
|
TIM1_TRG_COM_IRQHandler |
|
TIM1_CC_IRQHandler |
|
TIM2_IRQHandler |
|
TIM3_IRQHandler |
|
TIM4_IRQHandler |
|
I2C1_EV_IRQHandler |
|
I2C1_ER_IRQHandler |
|
I2C2_EV_IRQHandler |
|
I2C2_ER_IRQHandler |
|
SPI1_IRQHandler |
|
SPI2_IRQHandler |
|
USART1_IRQHandler |
|
USART2_IRQHandler |
|
USART3_IRQHandler |
|
EXTI15_10_IRQHandler |
|
RTCAlarm_IRQHandler |
|
USBWakeUp_IRQHandler |
|
TIM8_BRK_IRQHandler |
|
TIM8_UP_IRQHandler |
|
TIM8_TRG_COM_IRQHandler |
|
TIM8_CC_IRQHandler |
|
ADC3_4_IRQHandler |
|
XFMC_IRQHandler |
|
SDIO_IRQHandler |
|
TIM5_IRQHandler |
|
SPI3_IRQHandler |
|
UART4_IRQHandler |
|
UART5_IRQHandler |
|
TIM6_IRQHandler |
|
TIM7_IRQHandler |
|
DMA2_Channel1_IRQHandler |
|
DMA2_Channel2_IRQHandler |
|
DMA2_Channel3_IRQHandler |
|
DMA2_Channel4_IRQHandler |
|
DMA2_Channel5_IRQHandler |
|
ETH_IRQHandler |
|
ETH_WKUP_IRQHandler |
|
CAN2_TX_IRQHandler |
|
CAN2_RX0_IRQHandler |
|
CAN2_RX1_IRQHandler |
|
CAN2_SCE_IRQHandler |
|
QSPI_IRQHandler |
|
DMA2_Channel6_IRQHandler |
|
DMA2_Channel7_IRQHandler |
|
I2C3_EV_IRQHandler |
|
I2C3_ER_IRQHandler |
|
I2C4_EV_IRQHandler |
|
I2C4_ER_IRQHandler |
|
UART6_IRQHandler |
|
UART7_IRQHandler |
|
DMA1_Channel8_IRQHandler |
|
DMA2_Channel8_IRQHandler |
|
DVP_IRQHandler |
|
SAC_IRQHandler |
|
MMU_IRQHandler |
|
TSC_IRQHandler |
|
COMP_1_2_3_IRQHandler |
|
COMP_4_5_6_IRQHandler |
|
COMP7_IRQHandler |
|
RSRAM_IRQHandler |
|
B . |
|
|
|
ENDP |
|
|
|
ALIGN |
|
|
|
;******************************************************************************* |
|
; User Stack and Heap initialization |
|
;******************************************************************************* |
|
IF :DEF:__MICROLIB |
|
|
|
EXPORT __initial_sp |
|
EXPORT __heap_base |
|
EXPORT __heap_limit |
|
|
|
ELSE |
|
|
|
IMPORT __use_two_region_memory |
|
EXPORT __user_initial_stackheap |
|
|
|
__user_initial_stackheap |
|
|
|
LDR R0, = Heap_Mem |
|
LDR R1, =(Stack_Mem + Stack_Size) |
|
LDR R2, = (Heap_Mem + Heap_Size) |
|
LDR R3, = Stack_Mem |
|
BX LR |
|
|
|
ALIGN |
|
|
|
ENDIF |
|
|
|
END
|
|
|