MNRS-BM-BSP/env/start.S

67 lines
962 B
ArmAsm
Raw Normal View History

2024-12-20 14:27:45 +01:00
#include "encoding.h"
2020-06-18 12:15:52 +02:00
// See LICENSE for license details.
.section .init
.globl _start
.type _start,@function
_start:
2023-08-20 15:00:51 +02:00
.option push
.option norelax
2024-08-11 17:29:13 +02:00
.option norvc
j 1f
.2byte 0x4e4d
.2byte 0x5352
.4byte 0x669
1:
2023-08-20 15:00:51 +02:00
la gp, __global_pointer$
.option pop
2020-06-18 12:15:52 +02:00
la sp, _sp
2024-08-11 17:29:13 +02:00
la t0, trap_entry
csrw mtvec, t0
2020-06-18 12:15:52 +02:00
/* Load data section */
la a0, _data_lma
la a1, _data
la a2, _edata
bgeu a1, a2, 2f
1:
lw t0, (a0)
addi a0, a0, 4
2023-08-28 10:01:06 +02:00
sw t0, (a1)
2020-06-18 12:15:52 +02:00
addi a1, a1, 4
bltu a1, a2, 1b
2:
/* Clear bss section */
la a0, __bss_start
la a1, _end
bgeu a0, a1, 2f
1:
sw zero, (a0)
addi a0, a0, 4
bltu a0, a1, 1b
2:
/* Call global constructors */
2024-06-10 10:13:07 +02:00
#ifndef HAVE_NO_INIT_FINI
2020-06-18 12:15:52 +02:00
la a0, __libc_fini_array
call atexit
call __libc_init_array
2024-06-10 10:13:07 +02:00
#endif
2020-06-18 12:15:52 +02:00
#ifndef __riscv_float_abi_soft
/* Enable FPU */
li t0, MSTATUS_FS
csrs mstatus, t0
csrr t1, mstatus
and t1, t1, t0
beqz t1, 1f
fssr x0
1:
#endif
/* argc = argv = 0 */
li a0, 0
li a1, 0
call main
2023-08-20 15:00:51 +02:00
tail _exit