4ac9754f5b
1: If IAP has set mstatus to other value, using csrs will not change old value of mstatus in IAP. It should using csrw instead. 2: Reduce the flash size of undefined irq functions.
176 lines
3.6 KiB
ArmAsm
176 lines
3.6 KiB
ArmAsm
/********************************** (C) COPYRIGHT *******************************
|
|
* File Name : startup_gcc.s
|
|
* Author : WCH
|
|
* Version : V1.0
|
|
* Date : 2020/07/31
|
|
* Description : CH56x vector table for eclipse toolchain.
|
|
*******************************************************************************/
|
|
|
|
.section .init,"ax",@progbits
|
|
.global _start
|
|
.align 1
|
|
_start:
|
|
j handle_reset
|
|
|
|
.section .vector,"ax",@progbits
|
|
.align 1
|
|
_vector_base:
|
|
.option norvc;
|
|
.word 0
|
|
.word 0
|
|
j nmi_handler
|
|
j hardfault_handler
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
.word 0
|
|
j systick_handler
|
|
.word 0
|
|
j swi_handler
|
|
.word 0
|
|
/* External Interrupts */
|
|
j wdog_irq_handler
|
|
j tmr0_irq_handler
|
|
j gpio_irq_handler
|
|
j spi0_irq_handler
|
|
j usbss_irq_handler
|
|
j link_irq_handler
|
|
j tmr1_irq_handler
|
|
j tmr2_irq_handler
|
|
j uart0_irq_handler
|
|
j usbhs_irq_handler
|
|
j emmc_irq_handler
|
|
j dvp_irq_handler
|
|
j hspi_irq_handler
|
|
j spi1_irq_handler
|
|
j uart1_irq_handler
|
|
j uart2_irq_handler
|
|
j uart3_irq_handler
|
|
j serdes_irq_handler
|
|
j eth_irq_handler
|
|
j pmt_irq_handler
|
|
j ecdc_irq_handler
|
|
|
|
.option rvc;
|
|
|
|
.section .text.vector_handler,"ax", @prsocogbits
|
|
|
|
.weak nmi_handler
|
|
.weak hardfault_handler
|
|
.weak systick_handler
|
|
.weak swi_handler
|
|
.weak wdog_irq_handler
|
|
.weak tmr0_irq_handler
|
|
.weak gpio_irq_handler
|
|
.weak spi0_irq_handler
|
|
.weak usbss_irq_handler
|
|
.weak link_irq_handler
|
|
.weak tmr1_irq_handler
|
|
.weak tmr2_irq_handler
|
|
.weak uart0_irq_handler
|
|
.weak usbhs_irq_handler
|
|
.weak emmc_irq_handler
|
|
.weak dvp_irq_handler
|
|
.weak hspi_irq_handler
|
|
.weak spi1_irq_handler
|
|
.weak uart1_irq_handler
|
|
.weak uart2_irq_handler
|
|
.weak uart3_irq_handler
|
|
.weak serdes_irq_handler
|
|
.weak eth_irq_handler
|
|
.weak pmt_irq_handler
|
|
.weak ecdc_irq_handler
|
|
|
|
nmi_handler:
|
|
hardfault_handler:
|
|
systick_handler:
|
|
swi_handler:
|
|
wdog_irq_handler:
|
|
tmr0_irq_handler:
|
|
gpio_irq_handler:
|
|
spi0_irq_handler:
|
|
usbss_irq_handler:
|
|
link_irq_handler:
|
|
tmr1_irq_handler:
|
|
tmr2_irq_handler:
|
|
uart0_irq_handler:
|
|
usbhs_irq_handler:
|
|
emmc_irq_handler:
|
|
dvp_irq_handler:
|
|
hspi_irq_handler:
|
|
spi1_irq_handler:
|
|
uart1_irq_handler:
|
|
uart2_irq_handler:
|
|
uart3_irq_handler:
|
|
serdes_irq_handler:
|
|
eth_irq_handler:
|
|
pmt_irq_handler:
|
|
ecdc_irq_handler:
|
|
j .L_rip
|
|
|
|
.L_rip:
|
|
csrr t0, mepc
|
|
csrr t1, mstatus
|
|
csrr t2, mcause
|
|
csrr t3, mtval
|
|
csrr t4, mscratch
|
|
1: j 1b
|
|
|
|
.section .text.handle_reset,"ax",@progbits
|
|
.weak handle_reset
|
|
.align 1
|
|
handle_reset:
|
|
.option push
|
|
.option norelax
|
|
la gp, __global_pointer$
|
|
.option pop
|
|
1:
|
|
la sp, _eusrstack
|
|
|
|
/* Load data section from flash to RAM */
|
|
2:
|
|
la a0, _data_lma
|
|
la a1, _data_vma
|
|
la a2, _edata
|
|
bgeu a1, a2, 2f
|
|
1:
|
|
lw t0, (a0)
|
|
sw t0, (a1)
|
|
addi a0, a0, 4
|
|
addi a1, a1, 4
|
|
bltu a1, a2, 1b
|
|
/* clear bss section */
|
|
2:
|
|
la a0, _sbss
|
|
la a1, _ebss
|
|
bgeu a0, a1, 2f
|
|
1:
|
|
sw zero, (a0)
|
|
addi a0, a0, 4
|
|
bltu a0, a1, 1b
|
|
|
|
/* clear dmadata section */
|
|
2:
|
|
la a0, _dmadata_start
|
|
la a1, _dmadata_end
|
|
bgeu a0, a1, 2f
|
|
1:
|
|
sw zero, (a0)
|
|
addi a0, a0, 4
|
|
bltu a0, a1, 1b
|
|
|
|
2:
|
|
/* leave all interrupt disabled */
|
|
li t0, 0x1800
|
|
csrw mstatus, t0
|
|
la t0, _vector_base
|
|
ori t0, t0, 1
|
|
csrw mtvec, t0
|
|
la t0, entry
|
|
csrw mepc, t0
|
|
mret
|