mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	Commit f9886bc60f42 ("Added arm64 assembly for examples/api crt0") tried to
add arm64 support to the examples but crt0.S does not even build for
qemu_arm64_defconfig with CONFIG_API=y, CONFIG_EXAMPLES=y:
    examples/api/crt0.S: Assembler messages:
    examples/api/crt0.S:32: Error:
        expected a register at operand 1 -- `ldr ip,=search_hint'
    examples/api/crt0.S:33: Error:
        unexpected register type at operand 1 -- `str sp,[ip]'
    make[2]: *** [scripts/Makefile.build:292: examples/api/crt0.o] Error 1
Do not define _start twice.
Use valid register names.
Move syscall_ptr and search_hint to the data section to avoid an invalid
relocation.
Fixes: f9886bc60f42 ("Added arm64 assembly for examples/api crt0")
Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
		
	
			
		
			
				
	
	
		
			97 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			1.2 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
 | |
| #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
 |