summaryrefslogtreecommitdiffstats
path: root/arch/arm/cpu/entry_ll_64.S
blob: 6530bec5ebe456bfdb1c97e40d58ea25320d0b39 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/* SPDX-License-Identifier: GPL-2.0-only */

#include <linux/linkage.h>
#include <asm/sections.h>

/*
 * x0: memory base
 * x1: memory size
 * x2: board data
 * x3: new value for SP
 */
.section .text.__barebox_arm_entry
ENTRY(__barebox_arm_entry)
	mov	sp, x3
	mov	x19, x0
	mov	x20, x1
	mov	x21, x2
	bl	arm_early_mmu_cache_invalidate
	mov	x0, x19
	mov	x1, x20
	mov	x2, x21
#if IS_ENABLED(CONFIG_PBL_IMAGE)
	b	barebox_pbl_start
#else
	b	barebox_non_pbl_start
#endif
ENDPROC(__barebox_arm_entry)