plat_trampoline.S 2.43 KB
Newer Older
1
/*
2
 * Copyright (c) 2016-2019, ARM Limited and Contributors. All rights reserved.
3
 * Copyright (c) 2020, NVIDIA Corporation. All rights reserved.
4
 *
dp-arm's avatar
dp-arm committed
5
 * SPDX-License-Identifier: BSD-3-Clause
6
7
8
9
 */

#include <arch.h>
#include <asm_macros.S>
10
#include <common/bl_common.h>
11
#include <memctrl_v2.h>
12
#include <plat/common/common_def.h>
13
14
#include <tegra_def.h>

15
#define TEGRA186_MC_CTX_SIZE		0x93
16
17
18
19

	.globl	tegra186_cpu_reset_handler

/* CPU reset handler routine */
20
func tegra186_cpu_reset_handler _align=4
21
	/* prepare to relocate to TZSRAM */
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
	mov	x0, #BL31_BASE
	adr	x1, __tegra186_cpu_reset_handler_end
	adr	x2, __tegra186_cpu_reset_handler_data
	ldr	x2, [x2, #8]

	/* memcpy16 */
m_loop16:
	cmp	x2, #16
	b.lt	m_loop1
	ldp	x3, x4, [x1], #16
	stp	x3, x4, [x0], #16
	sub	x2, x2, #16
	b	m_loop16
	/* copy byte per byte */
m_loop1:
	cbz	x2, boot_cpu
	ldrb	w3, [x1], #1
	strb	w3, [x0], #1
	subs	x2, x2, #1
	b.ne	m_loop1

boot_cpu:
	adr	x0, __tegra186_cpu_reset_handler_data
	ldr	x0, [x0]
	br	x0
endfunc tegra186_cpu_reset_handler

	/*
	 * Tegra186 reset data (offset 0x0 - 0x430)
	 *
	 * 0x000: secure world's entrypoint
	 * 0x008: BL31 size (RO + RW)
54
55
	 * 0x00C: MC context start
	 * 0x42C: MC context end
56
57
58
59
60
61
62
63
	 */

	.align 4
	.type	__tegra186_cpu_reset_handler_data, %object
	.globl	__tegra186_cpu_reset_handler_data
__tegra186_cpu_reset_handler_data:
	.quad	tegra_secure_entrypoint
	.quad	__BL31_END__ - BL31_BASE
64

65
66
67
68
	.globl	__tegra186_system_suspend_state
__tegra186_system_suspend_state:
	.quad	0

69
	.align 4
70
71
72
	.globl	__tegra186_mc_context
__tegra186_mc_context:
	.rept	TEGRA186_MC_CTX_SIZE
73
74
75
76
77
78
79
80
	.quad	0
	.endr
	.size	__tegra186_cpu_reset_handler_data, \
		. - __tegra186_cpu_reset_handler_data

	.align 4
	.globl	__tegra186_cpu_reset_handler_end
__tegra186_cpu_reset_handler_end:
81
82
83

	.globl tegra186_get_cpu_reset_handler_size
	.globl tegra186_get_cpu_reset_handler_base
84
	.globl tegra186_get_mc_ctx_offset
85
86
87
88
89
90
91
92
93
94
95
96
97
98

/* return size of the CPU reset handler */
func tegra186_get_cpu_reset_handler_size
	adr	x0, __tegra186_cpu_reset_handler_end
	adr	x1, tegra186_cpu_reset_handler
	sub	x0, x0, x1
	ret
endfunc tegra186_get_cpu_reset_handler_size

/* return the start address of the CPU reset handler */
func tegra186_get_cpu_reset_handler_base
	adr	x0, tegra186_cpu_reset_handler
	ret
endfunc tegra186_get_cpu_reset_handler_base
99

100
101
102
/* return the size of the MC context */
func tegra186_get_mc_ctx_offset
	adr	x0, __tegra186_mc_context
103
104
105
	adr	x1, tegra186_cpu_reset_handler
	sub	x0, x0, x1
	ret
106
endfunc tegra186_get_mc_ctx_offset