mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 08:52:45 +01:00
b3d04d8270
`addi` with 20 bit immediate does not have a compressed representation, so using `jalr` with immediate offset uncompressed is smaller than using `addi`+`c.jr`
72 lines
1.2 KiB
ArmAsm
72 lines
1.2 KiB
ArmAsm
/*
|
|
* Copyright (C) 2017 JP Bonn, Ken Rabold
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
#include "vendor/riscv_csr.h"
|
|
|
|
.section .init
|
|
|
|
.globl _start
|
|
.type _start,@function
|
|
|
|
_start:
|
|
.cfi_startproc
|
|
.cfi_undefined ra
|
|
.option push
|
|
.option norelax
|
|
csrc CSR_MSTATUS, MSTATUS_MIE
|
|
lui a0, %hi(_start_real)
|
|
jalr x0, a0, %lo(_start_real)
|
|
|
|
_start_real:
|
|
la gp, __global_pointer$
|
|
.option pop
|
|
la sp, _sp
|
|
|
|
#ifdef MODULE_PUF_SRAM
|
|
/* PUF */
|
|
call riscv_puf_sram_init
|
|
#endif
|
|
|
|
/* Load data section */
|
|
la a0, _data_lma
|
|
la a1, _data
|
|
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
|
|
2:
|
|
|
|
|
|
/* Clear bss section */
|
|
la a0, __bss_start
|
|
la a1, __bss_end
|
|
bgeu a0, a1, 2f
|
|
1:
|
|
sw zero, (a0)
|
|
addi a0, a0, 4
|
|
bltu a0, a1, 1b
|
|
2:
|
|
|
|
/* Call global constructors */
|
|
call __libc_init_array
|
|
|
|
|
|
/* Initialize CPU, board and start kernel */
|
|
call cpu_init
|
|
call board_init
|
|
call kernel_init
|
|
|
|
/* Loop forever (should never get here) */
|
|
1:
|
|
j 1b
|
|
|
|
.cfi_endproc
|