cortex_a78.S 4.41 KB
Newer Older
1
/*
2
 * Copyright (c) 2019-2021, ARM Limited. All rights reserved.
3
4
5
6
7
8
9
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#include <arch.h>
#include <asm_macros.S>
#include <common/bl_common.h>
10
#include <cortex_a78.h>
11
12
13
14
15
#include <cpu_macros.S>
#include <plat_macros.S>

/* Hardware handled coherency */
#if HW_ASSISTED_COHERENCY == 0
16
#error "cortex_a78 must be compiled with HW_ASSISTED_COHERENCY enabled"
17
18
#endif

19
20

/* --------------------------------------------------
21
22
 * Errata Workaround for A78 Erratum 1688305.
 * This applies to revision r0p0 and r1p0 of A78.
23
24
25
26
27
 * Inputs:
 * x0: variant[4:7] and revision[0:3] of current cpu.
 * Shall clobber: x0-x17
 * --------------------------------------------------
 */
28
func errata_a78_1688305_wa
29
30
31
32
	/* Compare x0 against revision r1p0 */
	mov	x17, x30
	bl	check_errata_1688305
	cbz	x0, 1f
33
	mrs     x1, CORTEX_A78_ACTLR2_EL1
34
	orr	x1, x1, #CORTEX_A78_ACTLR2_EL1_BIT_1
35
	msr     CORTEX_A78_ACTLR2_EL1, x1
36
37
38
	isb
1:
	ret	x17
39
endfunc errata_a78_1688305_wa
40
41
42
43
44
45
46

func check_errata_1688305
	/* Applies to r0p0 and r1p0 */
	mov	x1, #0x10
	b	cpu_rev_var_ls
endfunc check_errata_1688305

47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
	/* --------------------------------------------------
	 * Errata Workaround for Cortex A78 Errata #1941498.
	 * This applies to revisions r0p0, r1p0, and r1p1.
	 * x0: variant[4:7] and revision[0:3] of current cpu.
	 * Shall clobber: x0-x17
	 * --------------------------------------------------
	 */
func errata_a78_1941498_wa
	/* Compare x0 against revision <= r1p1 */
	mov	x17, x30
	bl	check_errata_1941498
	cbz	x0, 1f

	/* Set bit 8 in ECTLR_EL1 */
	mrs	x1, CORTEX_A78_CPUECTLR_EL1
	orr	x1, x1, #CORTEX_A78_CPUECTLR_EL1_BIT_8
	msr	CORTEX_A78_CPUECTLR_EL1, x1
	isb
1:
	ret	x17
endfunc errata_a78_1941498_wa

func check_errata_1941498
	/* Check for revision <= r1p1, might need to be updated later. */
	mov	x1, #0x11
	b	cpu_rev_var_ls
endfunc check_errata_1941498

75
	/* -------------------------------------------------
76
	 * The CPU Ops reset function for Cortex-A78
77
78
	 * -------------------------------------------------
	 */
79
func cortex_a78_reset_func
80
81
82
83
	mov	x19, x30
	bl	cpu_get_rev_var
	mov	x18, x0

84
#if ERRATA_A78_1688305
85
	mov     x0, x18
86
	bl	errata_a78_1688305_wa
87
88
#endif

89
90
91
92
93
#if ERRATA_A78_1941498
	mov     x0, x18
	bl	errata_a78_1941498_wa
#endif

94
#if ENABLE_AMU
95
96
	/* Make sure accesses from EL0/EL1 and EL2 are not trapped to EL3 */
	mrs	x0, actlr_el3
97
	bic	x0, x0, #CORTEX_A78_ACTLR_TAM_BIT
98
99
100
101
	msr	actlr_el3, x0

	/* Make sure accesses from non-secure EL0/EL1 are not trapped to EL2 */
	mrs	x0, actlr_el2
102
	bic	x0, x0, #CORTEX_A78_ACTLR_TAM_BIT
103
104
105
	msr	actlr_el2, x0

	/* Enable group0 counters */
106
	mov	x0, #CORTEX_A78_AMU_GROUP0_MASK
107
108
109
	msr	CPUAMCNTENSET0_EL0, x0

	/* Enable group1 counters */
110
	mov	x0, #CORTEX_A78_AMU_GROUP1_MASK
111
	msr	CPUAMCNTENSET1_EL0, x0
112
#endif
113

114
115
	isb
	ret	x19
116
endfunc cortex_a78_reset_func
117
118
119
120
121

	/* ---------------------------------------------
	 * HW will do the cache maintenance while powering down
	 * ---------------------------------------------
	 */
122
func cortex_a78_core_pwr_dwn
123
124
125
126
	/* ---------------------------------------------
	 * Enable CPU power down bit in power control register
	 * ---------------------------------------------
	 */
127
128
129
	mrs	x0, CORTEX_A78_CPUPWRCTLR_EL1
	orr	x0, x0, #CORTEX_A78_CPUPWRCTLR_EL1_CORE_PWRDN_EN_BIT
	msr	CORTEX_A78_CPUPWRCTLR_EL1, x0
130
131
	isb
	ret
132
endfunc cortex_a78_core_pwr_dwn
133
134

	/*
135
	 * Errata printing function for cortex_a78. Must follow AAPCS.
136
137
	 */
#if REPORT_ERRATA
138
func cortex_a78_errata_report
139
140
141
142
143
144
145
146
147
	stp	x8, x30, [sp, #-16]!

	bl	cpu_get_rev_var
	mov	x8, x0

	/*
	 * Report all errata. The revision-variant information is passed to
	 * checking functions of each errata.
	 */
148
	report_errata ERRATA_A78_1688305, cortex_a78, 1688305
149
	report_errata ERRATA_A78_1941498, cortex_a78, 1941498
150
151

	ldp	x8, x30, [sp], #16
152
	ret
153
endfunc cortex_a78_errata_report
154
155
156
#endif

	/* ---------------------------------------------
157
	 * This function provides cortex_a78 specific
158
159
160
161
162
163
164
	 * register information for crash reporting.
	 * It needs to return with x6 pointing to
	 * a list of register names in ascii and
	 * x8 - x15 having values of registers to be
	 * reported.
	 * ---------------------------------------------
	 */
165
166
.section .rodata.cortex_a78_regs, "aS"
cortex_a78_regs:  /* The ascii list of register names to be reported */
167
168
	.asciz	"cpuectlr_el1", ""

169
170
171
func cortex_a78_cpu_reg_dump
	adr	x6, cortex_a78_regs
	mrs	x8, CORTEX_A78_CPUECTLR_EL1
172
	ret
173
endfunc cortex_a78_cpu_reg_dump
174

175
176
177
declare_cpu_ops cortex_a78, CORTEX_A78_MIDR, \
	cortex_a78_reset_func, \
	cortex_a78_core_pwr_dwn