mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-22 20:58:22 +00:00

To build the API examples on RISC-V we need to implement _start and syscall for RISC-V. Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
128 lines
1.6 KiB
ArmAsm
128 lines
1.6 KiB
ArmAsm
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* (C) Copyright 2007 Semihalf
|
|
*
|
|
* Written by: Rafal Jaworowski <raj@semihalf.com>
|
|
*/
|
|
|
|
#if defined(CONFIG_PPC)
|
|
|
|
.text
|
|
.globl _start
|
|
_start:
|
|
lis %r11, search_hint@ha
|
|
addi %r11, %r11, search_hint@l
|
|
stw %r1, 0(%r11)
|
|
b main
|
|
|
|
|
|
.globl syscall
|
|
syscall:
|
|
lis %r11, syscall_ptr@ha
|
|
addi %r11, %r11, syscall_ptr@l
|
|
lwz %r11, 0(%r11)
|
|
mtctr %r11
|
|
bctr
|
|
|
|
#elif defined(CONFIG_ARM) && !defined(CONFIG_ARM64)
|
|
|
|
.text
|
|
.globl _start
|
|
_start:
|
|
ldr ip, =search_hint
|
|
str sp, [ip]
|
|
b main
|
|
|
|
|
|
.globl syscall
|
|
syscall:
|
|
ldr ip, =syscall_ptr
|
|
ldr pc, [ip]
|
|
|
|
#elif defined(CONFIG_ARM64)
|
|
|
|
.text
|
|
.globl _start
|
|
_start:
|
|
ldr x17, =search_hint
|
|
mov x16, sp
|
|
str x16, [x17]
|
|
b main
|
|
|
|
.globl syscall
|
|
syscall:
|
|
ldr x16, =syscall_ptr
|
|
ldr x16, [x16]
|
|
br x16
|
|
|
|
#elif defined(CONFIG_MIPS)
|
|
#include <asm/asm.h>
|
|
.text
|
|
.globl __start
|
|
.ent __start
|
|
__start:
|
|
PTR_S $sp, search_hint
|
|
b main
|
|
.end __start
|
|
|
|
.globl syscall
|
|
.ent syscall
|
|
syscall:
|
|
PTR_S $ra, return_addr
|
|
PTR_L $t9, syscall_ptr
|
|
jalr $t9
|
|
nop
|
|
PTR_L $ra, return_addr
|
|
jr $ra
|
|
nop
|
|
.end syscall
|
|
|
|
return_addr:
|
|
.align 8
|
|
.long 0
|
|
#elif defined(CONFIG_ARCH_RV32I)
|
|
|
|
.text
|
|
.globl _start
|
|
_start:
|
|
la t0, search_hint
|
|
sw sp, 0(t0)
|
|
la t0, main
|
|
jalr x0, t0
|
|
|
|
.globl syscall
|
|
syscall:
|
|
la t0, syscall_ptr
|
|
lw t0, 0(t0)
|
|
jalr x0, t0
|
|
|
|
#elif defined(CONFIG_ARCH_RV64I)
|
|
|
|
.text
|
|
.globl _start
|
|
_start:
|
|
la t0, search_hint
|
|
sd sp, 0(t0)
|
|
la t0, main
|
|
jalr x0, t0
|
|
|
|
.globl syscall
|
|
syscall:
|
|
la t0, syscall_ptr
|
|
ld t0, 0(t0)
|
|
jalr x0, t0
|
|
|
|
#else
|
|
#error No support for this arch!
|
|
#endif
|
|
|
|
.section .data
|
|
|
|
.globl syscall_ptr
|
|
syscall_ptr:
|
|
.align 8
|
|
.long 0
|
|
|
|
.globl search_hint
|
|
search_hint:
|
|
.long 0
|