mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	Refer to the commit a3c101a61348 ("examples: fix building on arm64")
fix for arm32. crt0.S does not even build with:
    operating system and architecture:
        5.15.0-130-generic x86_64
    installed version of gcc and binutils:
        gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04.3)
    GNU ld (GNU Binutils for Ubuntu) 2.34
    used defconfig:
        stm32h750-art-pi_defconfig
    used commands for building:
        export CROSS_COMPILE=arm-none-eabi- ARCH=arm
        make stm32h750-art-pi_defconfig
        make menuconfig # to add
        make
    examples/api/crt0.S: Assembler messages:
    examples/api/crt0.S:32: Error: lo register required -- `ldr ip,=search_hint'
    examples/api/crt0.S:33: Error: lo register required -- `str sp,[ip]'
    examples/api/crt0.S:39: Error: lo register required -- `ldr ip,=syscall_ptr'
    examples/api/crt0.S:40: Error: lo register required -- `ldr pc,[ip]'
    make[2]: *** [scripts/Makefile.build:292:examples/api/crt0.o] Error 1
Use valid register names and instructions.
Signed-off-by: Liya Huang <1425075683@qq.com>
		
	
			
		
			
				
	
	
		
			131 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			131 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	r4, =search_hint
 | 
						|
	mov	r5, sp
 | 
						|
	str	r5, [r4]
 | 
						|
	b	main
 | 
						|
 | 
						|
 | 
						|
	.globl syscall
 | 
						|
syscall:
 | 
						|
	ldr	r4, =syscall_ptr
 | 
						|
	ldr	r4, [r4]
 | 
						|
	bx	r4
 | 
						|
 | 
						|
#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
 |