cortex_a53.S 7.16 KB
Newer Older
1
/*
2
 * Copyright (c) 2014-2017, ARM Limited and Contributors. All rights reserved.
3
 *
dp-arm's avatar
dp-arm committed
4
 * SPDX-License-Identifier: BSD-3-Clause
5
6
 */
#include <arch.h>
7
#include <asm_macros.S>
8
#include <bl_common.h>
9
#include <cortex_a53.h>
10
#include <cpu_macros.S>
11
#include <debug.h>
12
#include <plat_macros.S>
13

14
15
16
17
18
#if A53_DISABLE_NON_TEMPORAL_HINT
#undef ERRATA_A53_836870
#define ERRATA_A53_836870	1
#endif

19
20
21
22
23
24
25
26
27
28
	/* ---------------------------------------------
	 * Disable L1 data cache and unified L2 cache
	 * ---------------------------------------------
	 */
func cortex_a53_disable_dcache
	mrs	x1, sctlr_el3
	bic	x1, x1, #SCTLR_C_BIT
	msr	sctlr_el3, x1
	isb
	ret
29
endfunc cortex_a53_disable_dcache
30
31
32
33
34
35
36
37
38
39
40
41

	/* ---------------------------------------------
	 * Disable intra-cluster coherency
	 * ---------------------------------------------
	 */
func cortex_a53_disable_smp
	mrs	x0, CPUECTLR_EL1
	bic	x0, x0, #CPUECTLR_SMP_BIT
	msr	CPUECTLR_EL1, x0
	isb
	dsb	sy
	ret
42
endfunc cortex_a53_disable_smp
43

44
45
46
47
48
	/* --------------------------------------------------
	 * Errata Workaround for Cortex A53 Errata #826319.
	 * This applies only to revision <= r0p2 of Cortex A53.
	 * Inputs:
	 * x0: variant[4:7] and revision[0:3] of current cpu.
49
	 * Shall clobber: x0-x17
50
51
52
53
54
55
	 * --------------------------------------------------
	 */
func errata_a53_826319_wa
	/*
	 * Compare x0 against revision r0p2
	 */
56
57
58
	mov	x17, x30
	bl	check_errata_826319
	cbz	x0, 1f
59
60
61
62
	mrs	x1, L2ACTLR_EL1
	bic	x1, x1, #L2ACTLR_ENABLE_UNIQUECLEAN
	orr	x1, x1, #L2ACTLR_DISABLE_CLEAN_PUSH
	msr	L2ACTLR_EL1, x1
63
64
1:
	ret	x17
65
66
endfunc errata_a53_826319_wa

67
68
69
70
71
func check_errata_826319
	mov	x1, #0x02
	b	cpu_rev_var_ls
endfunc check_errata_826319

72
73
74
75
76
77
78
79
80
81
82
83
	/* ---------------------------------------------------------------------
	 * Disable the cache non-temporal hint.
	 *
	 * This ignores the Transient allocation hint in the MAIR and treats
	 * allocations the same as non-transient allocation types. As a result,
	 * the LDNP and STNP instructions in AArch64 behave the same as the
	 * equivalent LDP and STP instructions.
	 *
	 * This is relevant only for revisions <= r0p3 of Cortex-A53.
	 * From r0p4 and onwards, the bit to disable the hint is enabled by
	 * default at reset.
	 *
84
85
	 * Inputs:
	 * x0: variant[4:7] and revision[0:3] of current cpu.
86
	 * Shall clobber: x0-x17
87
	 * ---------------------------------------------------------------------
88
	 */
89
func a53_disable_non_temporal_hint
90
91
92
	/*
	 * Compare x0 against revision r0p3
	 */
93
94
95
	mov	x17, x30
	bl	check_errata_disable_non_temporal_hint
	cbz	x0, 1f
96
97
98
	mrs	x1, CPUACTLR_EL1
	orr	x1, x1, #CPUACTLR_DTAH
	msr	CPUACTLR_EL1, x1
99
100
1:
	ret	x17
101
endfunc a53_disable_non_temporal_hint
102

103
104
105
106
107
func check_errata_disable_non_temporal_hint
	mov	x1, #0x03
	b	cpu_rev_var_ls
endfunc check_errata_disable_non_temporal_hint

108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
	/* --------------------------------------------------
	 * Errata Workaround for Cortex A53 Errata #855873.
	 *
	 * This applies only to revisions >= r0p3 of Cortex A53.
	 * Earlier revisions of the core are affected as well, but don't
	 * have the chicken bit in the CPUACTLR register. It is expected that
	 * the rich OS takes care of that, especially as the workaround is
	 * shared with other erratas in those revisions of the CPU.
	 * Inputs:
	 * x0: variant[4:7] and revision[0:3] of current cpu.
	 * Shall clobber: x0-x17
	 * --------------------------------------------------
	 */
func errata_a53_855873_wa
	/*
	 * Compare x0 against revision r0p3 and higher
	 */
        mov     x17, x30
        bl      check_errata_855873
        cbz     x0, 1f

	mrs	x1, CPUACTLR_EL1
	orr	x1, x1, #CPUACTLR_ENDCCASCI
	msr	CPUACTLR_EL1, x1
1:
	ret	x17
endfunc errata_a53_855873_wa

func check_errata_855873
	mov	x1, #0x03
	b	cpu_rev_var_hs
endfunc check_errata_855873

141
142
	/* -------------------------------------------------
	 * The CPU Ops reset function for Cortex-A53.
143
	 * Shall clobber: x0-x19
144
145
	 * -------------------------------------------------
	 */
146
func cortex_a53_reset_func
147
	mov	x19, x30
148
149
	bl	cpu_get_rev_var
	mov	x18, x0
150
151
152


#if ERRATA_A53_826319
153
	mov	x0, x18
154
155
156
	bl	errata_a53_826319_wa
#endif

157
158
#if ERRATA_A53_836870
	mov	x0, x18
159
	bl	a53_disable_non_temporal_hint
160
161
#endif

162
163
164
165
166
#if ERRATA_A53_855873
	mov	x0, x18
	bl	errata_a53_855873_wa
#endif

167
	/* ---------------------------------------------
168
	 * Enable the SMP bit.
169
170
	 * ---------------------------------------------
	 */
171
	mrs	x0, CPUECTLR_EL1
172
	orr	x0, x0, #CPUECTLR_SMP_BIT
173
	msr	CPUECTLR_EL1, x0
174
175
	isb
	ret	x19
176
endfunc cortex_a53_reset_func
177

178
179
180
181
182
183
184
185
186
187
func cortex_a53_core_pwr_dwn
	mov	x18, x30

	/* ---------------------------------------------
	 * Turn off caches.
	 * ---------------------------------------------
	 */
	bl	cortex_a53_disable_dcache

	/* ---------------------------------------------
188
	 * Flush L1 caches.
189
190
191
	 * ---------------------------------------------
	 */
	mov	x0, #DCCISW
192
	bl	dcsw_op_level1
193
194
195
196
197
198
199

	/* ---------------------------------------------
	 * Come out of intra cluster coherency
	 * ---------------------------------------------
	 */
	mov	x30, x18
	b	cortex_a53_disable_smp
200
endfunc cortex_a53_core_pwr_dwn
201
202
203
204
205
206
207
208
209
210

func cortex_a53_cluster_pwr_dwn
	mov	x18, x30

	/* ---------------------------------------------
	 * Turn off caches.
	 * ---------------------------------------------
	 */
	bl	cortex_a53_disable_dcache

211
212
213
214
215
216
217
	/* ---------------------------------------------
	 * Flush L1 caches.
	 * ---------------------------------------------
	 */
	mov	x0, #DCCISW
	bl	dcsw_op_level1

218
219
220
221
222
223
224
	/* ---------------------------------------------
	 * Disable the optional ACP.
	 * ---------------------------------------------
	 */
	bl	plat_disable_acp

	/* ---------------------------------------------
225
	 * Flush L2 caches.
226
227
228
	 * ---------------------------------------------
	 */
	mov	x0, #DCCISW
229
	bl	dcsw_op_level2
230
231
232
233
234
235
236

	/* ---------------------------------------------
	 * Come out of intra cluster coherency
	 * ---------------------------------------------
	 */
	mov	x30, x18
	b	cortex_a53_disable_smp
237
endfunc cortex_a53_cluster_pwr_dwn
238

239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
#if REPORT_ERRATA
/*
 * Errata printing function for Cortex A53. Must follow AAPCS.
 */
func cortex_a53_errata_report
	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.
	 */
	report_errata ERRATA_A53_826319, cortex_a53, 826319
	report_errata ERRATA_A53_836870, cortex_a53, disable_non_temporal_hint
255
	report_errata ERRATA_A53_855873, cortex_a53, 855873
256
257
258
259
260
261

	ldp	x8, x30, [sp], #16
	ret
endfunc cortex_a53_errata_report
#endif

262
263
264
265
266
267
268
269
270
271
272
	/* ---------------------------------------------
	 * This function provides cortex_a53 specific
	 * 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.
	 * ---------------------------------------------
	 */
.section .rodata.cortex_a53_regs, "aS"
cortex_a53_regs:  /* The ascii list of register names to be reported */
273
274
	.asciz	"cpuectlr_el1", "cpumerrsr_el1", "l2merrsr_el1", \
		"cpuactlr_el1", ""
275
276
277
278

func cortex_a53_cpu_reg_dump
	adr	x6, cortex_a53_regs
	mrs	x8, CPUECTLR_EL1
279
280
	mrs	x9, CPUMERRSR_EL1
	mrs	x10, L2MERRSR_EL1
281
	mrs	x11, CPUACTLR_EL1
282
	ret
283
endfunc cortex_a53_cpu_reg_dump
284

285
286
287
288
declare_cpu_ops cortex_a53, CORTEX_A53_MIDR, \
	cortex_a53_reset_func, \
	cortex_a53_core_pwr_dwn, \
	cortex_a53_cluster_pwr_dwn