123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #include "sys.h"
- #include "sections.h"
- #include "picorv32.h"
- #define GP_IS_ZERO 1
-
-
- .option norvc
-
-
-
-
-
-
-
- .section ".null","a"
- .globl _NULL
- _NULL:
- .space 8
- .type _NULL, @object
- .size _NULL, . - _NULL
- .globl __dram_checksum
- __dram_checksum:
- .long 0
- .type __dram_checksum, @object
- .size __dram_checksum, . - __dram_checksum
- .globl __rom_offset
- __rom_offset:
- .long ROM_OFFSET
- .type __rom_offset, @object
- .size __rom_offset, . - __rom_offset
-
- .section ".init.reset","ax"
- .globl _reset
- _reset:
- .option push
- .option norvc
- .option norelax
- rdtime s0
- lui sp,%hi(___stack_top)
- addi sp,sp,%lo(___stack_top)
- j __start
- .option pop
- .type _reset, @function
- .size _reset, . - _reset
- .section ".text.hot","ax"
- .globl __start
- .balign 4
- __start:
- .option push
- .option norvc
- .option norelax
- not t0,zero
- maskirq zero,t0,zero
-
- lui t0,%hi(___irqstack_top)
- addqxi sp,t0,%lo(___irqstack_top)
-
- #if GP_IS_ZERO
- li gp, 0
- #else
- la gp, __global_pointer$
- #endif
- .option pop
- addqxi gp,gp,0
-
- sw zero,esplink_head,a0
-
- la a0,__BSS_START__
- la a1,__BSS_END__
- .L_clear_bss_loop:
- sw zero,(a0)
- sw zero,4(a0)
- sw zero,8(a0)
- sw zero,12(a0)
- sw zero,16(a0)
- sw zero,20(a0)
- sw zero,24(a0)
- sw zero,28(a0)
- addi a0,a0,32
- bltu a0,a1,.L_clear_bss_loop
- sw s0, time_zero, t0
- j main
- .type __start, @function
- .size __start, . - __start
- __sbss
- .balign 4
- .globl time_zero
- time_zero:
- .space 4
- .type time_zero, @object
- .size time_zero, . - time_zero
- .popsection
-
- .section ".datestamp","a"
- .globl __datestamp
- __datestamp:
- .space 32
- .type __datestamp, @object
- .size __datestamp, . - __datestamp
-
- .section ".stack","aw",@nobits
- .balign 4
- .globl __irqstack_bottom
- ___irqstack:
- .space IRQSTACK_SIZE
- .type ___irqstack, @object
- .size ___irqstack, IRQSTACK_SIZE
- .globl ___irqstack_top
- ___irqstack_top:
- .balign 4
- .globl ___stack
- ___stack:
- .space STACK_SIZE
- .type ___stack, @object
- .size ___stack, STACK_SIZE
- .globl ___stack_top
- ___stack_top:
|