Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
Arm Trusted Firmware
Commits
6db7190b
Commit
6db7190b
authored
Mar 20, 2017
by
davidcunado-arm
Committed by
GitHub
Mar 20, 2017
Browse files
Merge pull request #857 from Andre-ARM/a53-855873
ARM Cortex-A53 erratum 855873 workaround
parents
3944adca
baac5dd4
Changes
8
Show whitespace changes
Inline
Side-by-side
docs/cpu-specific-build-macros.md
View file @
6db7190b
...
@@ -60,6 +60,13 @@ For Cortex-A53, following errata build flags are defined :
...
@@ -60,6 +60,13 @@ For Cortex-A53, following errata build flags are defined :
CPU. This needs to be enabled only for revision <= r0p3 of the CPU. From
CPU. This needs to be enabled only for revision <= r0p3 of the CPU. From
r0p4 and onwards, this errata is enabled by default in hardware.
r0p4 and onwards, this errata is enabled by default in hardware.
*
`ERRATA_A53_855873`
: This applies errata 855873 workaround to Cortex-A53
CPUs. Though the erratum is present in every revision of the CPU,
this workaround is only applied to CPUs from r0p3 onwards, which feature
a chicken bit in CPUACTLR_EL1 to enable a hardware workaround.
Earlier revisions of the CPU have other errata which require the same
workaround in software, so they should be covered anyway.
For Cortex-A57, following errata build flags are defined :
For Cortex-A57, following errata build flags are defined :
*
`ERRATA_A57_806969`
: This applies errata 806969 workaround to Cortex-A57
*
`ERRATA_A57_806969`
: This applies errata 806969 workaround to Cortex-A57
...
...
include/lib/cpus/aarch64/cortex_a53.h
View file @
6db7190b
...
@@ -67,6 +67,7 @@
...
@@ -67,6 +67,7 @@
#define CPUACTLR_EL1 S3_1_C15_C2_0
/* Instruction def. */
#define CPUACTLR_EL1 S3_1_C15_C2_0
/* Instruction def. */
#define CPUACTLR_DTAH (1 << 24)
#define CPUACTLR_DTAH (1 << 24)
#define CPUACTLR_ENDCCASCI (1 << 44)
/*******************************************************************************
/*******************************************************************************
* L2 Auxiliary Control register specific definitions.
* L2 Auxiliary Control register specific definitions.
...
...
lib/cpus/aarch64/cortex_a53.S
View file @
6db7190b
...
@@ -129,6 +129,39 @@ func check_errata_disable_non_temporal_hint
...
@@ -129,6 +129,39 @@ func check_errata_disable_non_temporal_hint
b
cpu_rev_var_ls
b
cpu_rev_var_ls
endfunc
check_errata_disable_non_temporal_hint
endfunc
check_errata_disable_non_temporal_hint
/
*
--------------------------------------------------
*
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
,
1
f
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
/
*
-------------------------------------------------
/
*
-------------------------------------------------
*
The
CPU
Ops
reset
function
for
Cortex
-
A53
.
*
The
CPU
Ops
reset
function
for
Cortex
-
A53
.
*
Shall
clobber
:
x0
-
x19
*
Shall
clobber
:
x0
-
x19
...
@@ -150,6 +183,11 @@ func cortex_a53_reset_func
...
@@ -150,6 +183,11 @@ func cortex_a53_reset_func
bl
a53_disable_non_temporal_hint
bl
a53_disable_non_temporal_hint
#endif
#endif
#if ERRATA_A53_855873
mov
x0
,
x18
bl
errata_a53_855873_wa
#endif
/
*
---------------------------------------------
/
*
---------------------------------------------
*
Enable
the
SMP
bit
.
*
Enable
the
SMP
bit
.
*
---------------------------------------------
*
---------------------------------------------
...
@@ -238,6 +276,7 @@ func cortex_a53_errata_report
...
@@ -238,6 +276,7 @@ func cortex_a53_errata_report
*/
*/
report_errata
ERRATA_A53_826319
,
cortex_a53
,
826319
report_errata
ERRATA_A53_826319
,
cortex_a53
,
826319
report_errata
ERRATA_A53_836870
,
cortex_a53
,
disable_non_temporal_hint
report_errata
ERRATA_A53_836870
,
cortex_a53
,
disable_non_temporal_hint
report_errata
ERRATA_A53_855873
,
cortex_a53
,
855873
ldp
x8
,
x30
,
[
sp
],
#
16
ldp
x8
,
x30
,
[
sp
],
#
16
ret
ret
...
@@ -255,13 +294,15 @@ endfunc cortex_a53_errata_report
...
@@ -255,13 +294,15 @@ endfunc cortex_a53_errata_report
*/
*/
.
section
.
rodata.
cortex_a53_regs
,
"aS"
.
section
.
rodata.
cortex_a53_regs
,
"aS"
cortex_a53_regs
:
/
*
The
ascii
list
of
register
names
to
be
reported
*/
cortex_a53_regs
:
/
*
The
ascii
list
of
register
names
to
be
reported
*/
.
asciz
"cpuectlr_el1"
,
"cpumerrsr_el1"
,
"l2merrsr_el1"
,
""
.
asciz
"cpuectlr_el1"
,
"cpumerrsr_el1"
,
"l2merrsr_el1"
,
\
"
cpuactlr_el1
",
""
func
cortex_a53_cpu_reg_dump
func
cortex_a53_cpu_reg_dump
adr
x6
,
cortex_a53_regs
adr
x6
,
cortex_a53_regs
mrs
x8
,
CPUECTLR_EL1
mrs
x8
,
CPUECTLR_EL1
mrs
x9
,
CPUMERRSR_EL1
mrs
x9
,
CPUMERRSR_EL1
mrs
x10
,
L2MERRSR_EL1
mrs
x10
,
L2MERRSR_EL1
mrs
x11
,
CPUACTLR_EL1
ret
ret
endfunc
cortex_a53_cpu_reg_dump
endfunc
cortex_a53_cpu_reg_dump
...
...
lib/cpus/aarch64/cpu_helpers.S
View file @
6db7190b
...
@@ -234,6 +234,20 @@ func cpu_rev_var_ls
...
@@ -234,6 +234,20 @@ func cpu_rev_var_ls
ret
ret
endfunc
cpu_rev_var_ls
endfunc
cpu_rev_var_ls
/*
*
Compare
the
CPU
's revision-variant (x0) with a given value (x1), for errata
*
application
purposes
.
If
the
revision
-
variant
is
higher
than
or
same
as
a
*
given
value
,
indicates
that
errata
applies
; otherwise not.
*/
.
globl
cpu_rev_var_hs
func
cpu_rev_var_hs
mov
x2
,
#
ERRATA_APPLIES
mov
x3
,
#
ERRATA_NOT_APPLIES
cmp
x0
,
x1
csel
x0
,
x2
,
x3
,
hs
ret
endfunc
cpu_rev_var_hs
#if REPORT_ERRATA
#if REPORT_ERRATA
/*
/*
*
void
print_errata_status
(
void
)
;
*
void
print_errata_status
(
void
)
;
...
...
lib/cpus/cpu-ops.mk
View file @
6db7190b
...
@@ -66,6 +66,12 @@ ERRATA_A53_826319 ?=0
...
@@ -66,6 +66,12 @@ ERRATA_A53_826319 ?=0
# erratum workaround is enabled by default in hardware.
# erratum workaround is enabled by default in hardware.
ERRATA_A53_836870
?=
0
ERRATA_A53_836870
?=
0
# Flag to apply errata 855873 during reset. This errata applies to all
# revisions of the Cortex A53 CPU, but this firmware workaround only works
# for revisions r0p3 and higher. Earlier revisions are taken care
# of by the rich OS.
ERRATA_A53_855873
?=
0
# Flag to apply erratum 806969 workaround during reset. This erratum applies
# Flag to apply erratum 806969 workaround during reset. This erratum applies
# only to revision r0p0 of the Cortex A57 cpu.
# only to revision r0p0 of the Cortex A57 cpu.
ERRATA_A57_806969
?=
0
ERRATA_A57_806969
?=
0
...
@@ -106,6 +112,10 @@ $(eval $(call add_define,ERRATA_A53_826319))
...
@@ -106,6 +112,10 @@ $(eval $(call add_define,ERRATA_A53_826319))
$(eval
$(call
assert_boolean,ERRATA_A53_836870))
$(eval
$(call
assert_boolean,ERRATA_A53_836870))
$(eval
$(call
add_define,ERRATA_A53_836870))
$(eval
$(call
add_define,ERRATA_A53_836870))
# Process ERRATA_A53_855873 flag
$(eval
$(call
assert_boolean,ERRATA_A53_855873))
$(eval
$(call
add_define,ERRATA_A53_855873))
# Process ERRATA_A57_806969 flag
# Process ERRATA_A57_806969 flag
$(eval
$(call
assert_boolean,ERRATA_A57_806969))
$(eval
$(call
assert_boolean,ERRATA_A57_806969))
$(eval
$(call
add_define,ERRATA_A57_806969))
$(eval
$(call
add_define,ERRATA_A57_806969))
...
...
plat/arm/board/juno/platform.mk
View file @
6db7190b
...
@@ -67,7 +67,8 @@ BL31_SOURCES += lib/cpus/aarch64/cortex_a53.S \
...
@@ -67,7 +67,8 @@ BL31_SOURCES += lib/cpus/aarch64/cortex_a53.S \
${JUNO_INTERCONNECT_SOURCES}
\
${JUNO_INTERCONNECT_SOURCES}
\
${JUNO_SECURITY_SOURCES}
${JUNO_SECURITY_SOURCES}
# Enable workarounds for selected Cortex-A57 erratas.
# Enable workarounds for selected Cortex-A53 and A57 erratas.
ERRATA_A53_855873
:=
1
ERRATA_A57_806969
:=
0
ERRATA_A57_806969
:=
0
ERRATA_A57_813419
:=
1
ERRATA_A57_813419
:=
1
ERRATA_A57_813420
:=
1
ERRATA_A57_813420
:=
1
...
...
plat/mediatek/mt8173/platform.mk
View file @
6db7190b
...
@@ -90,6 +90,7 @@ $(eval $(call add_define,ARM_GIC_ARCH))
...
@@ -90,6 +90,7 @@ $(eval $(call add_define,ARM_GIC_ARCH))
# Enable workarounds for selected Cortex-A53 erratas.
# Enable workarounds for selected Cortex-A53 erratas.
ERRATA_A53_826319
:=
1
ERRATA_A53_826319
:=
1
ERRATA_A53_836870
:=
1
ERRATA_A53_836870
:=
1
ERRATA_A53_855873
:=
1
# indicate the reset vector address can be programmed
# indicate the reset vector address can be programmed
PROGRAMMABLE_RESET_ADDRESS
:=
1
PROGRAMMABLE_RESET_ADDRESS
:=
1
...
...
plat/nvidia/tegra/soc/t210/platform_t210.mk
View file @
6db7190b
...
@@ -66,3 +66,4 @@ ERRATA_A57_833471 := 1
...
@@ -66,3 +66,4 @@ ERRATA_A57_833471 := 1
A53_DISABLE_NON_TEMPORAL_HINT
:=
1
A53_DISABLE_NON_TEMPORAL_HINT
:=
1
ERRATA_A53_826319
:=
1
ERRATA_A53_826319
:=
1
ERRATA_A53_836870
:=
1
ERRATA_A53_836870
:=
1
ERRATA_A53_855873
:=
1
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment