Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 1 | /* |
Arvind Ram Prakash | 5b27ecf | 2023-06-23 14:47:30 -0500 | [diff] [blame] | 2 | * Copyright (c) 2020-2023, Arm Limited. All rights reserved. |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 3 | * |
| 4 | * SPDX-License-Identifier: BSD-3-Clause |
| 5 | */ |
| 6 | |
| 7 | #include <arch.h> |
| 8 | #include <asm_macros.S> |
| 9 | #include <cpu_macros.S> |
| 10 | #include <neoverse_n2.h> |
Bipin Ravi | 8649974 | 2022-01-18 01:59:06 -0600 | [diff] [blame] | 11 | #include "wa_cve_2022_23960_bhb_vector.S" |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 12 | |
| 13 | /* Hardware handled coherency */ |
| 14 | #if HW_ASSISTED_COHERENCY == 0 |
| 15 | #error "Neoverse N2 must be compiled with HW_ASSISTED_COHERENCY enabled" |
| 16 | #endif |
| 17 | |
| 18 | /* 64-bit only core */ |
| 19 | #if CTX_INCLUDE_AARCH32_REGS == 1 |
| 20 | #error "Neoverse-N2 supports only AArch64. Compile with CTX_INCLUDE_AARCH32_REGS=0" |
| 21 | #endif |
| 22 | |
Bipin Ravi | 8649974 | 2022-01-18 01:59:06 -0600 | [diff] [blame] | 23 | #if WORKAROUND_CVE_2022_23960 |
| 24 | wa_cve_2022_23960_bhb_vector_table NEOVERSE_N2_BHB_LOOP_COUNT, neoverse_n2 |
| 25 | #endif /* WORKAROUND_CVE_2022_23960 */ |
| 26 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 27 | /* |
| 28 | * ERRATA_DSU_2313941: |
| 29 | * The errata is defined in dsu_helpers.S and applies to Neoverse N2. |
| 30 | * Henceforth creating symbolic names to the already existing errata |
| 31 | * workaround functions to get them registered under the Errata Framework. |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 32 | */ |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 33 | .equ check_erratum_neoverse_n2_2313941, check_errata_dsu_2313941 |
| 34 | .equ erratum_neoverse_n2_2313941_wa, errata_dsu_2313941_wa |
| 35 | add_erratum_entry neoverse_n2, ERRATUM(2313941), ERRATA_DSU_2313941, APPLY_AT_RESET |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 36 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 37 | workaround_reset_start neoverse_n2, ERRATUM(2002655), ERRATA_N2_2002655 |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 38 | /* Apply instruction patching sequence */ |
| 39 | ldr x0,=0x6 |
| 40 | msr S3_6_c15_c8_0,x0 |
| 41 | ldr x0,=0xF3A08002 |
| 42 | msr S3_6_c15_c8_2,x0 |
| 43 | ldr x0,=0xFFF0F7FE |
| 44 | msr S3_6_c15_c8_3,x0 |
| 45 | ldr x0,=0x40000001003ff |
| 46 | msr S3_6_c15_c8_1,x0 |
| 47 | ldr x0,=0x7 |
| 48 | msr S3_6_c15_c8_0,x0 |
| 49 | ldr x0,=0xBF200000 |
| 50 | msr S3_6_c15_c8_2,x0 |
| 51 | ldr x0,=0xFFEF0000 |
| 52 | msr S3_6_c15_c8_3,x0 |
| 53 | ldr x0,=0x40000001003f3 |
| 54 | msr S3_6_c15_c8_1,x0 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 55 | workaround_reset_end neoverse_n2, ERRATUM(2002655) |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 56 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 57 | check_erratum_ls neoverse_n2, ERRATUM(2002655), CPU_REV(0, 0) |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 58 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 59 | workaround_reset_start neoverse_n2, ERRATUM(2025414), ERRATA_N2_2025414 |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 60 | sysreg_bit_set NEOVERSE_N2_CPUECTLR_EL1, NEOVERSE_N2_CPUECTLR_EL1_PFSTIDIS_BIT |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 61 | workaround_reset_end neoverse_n2, ERRATUM(2025414) |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 62 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 63 | check_erratum_ls neoverse_n2, ERRATUM(2025414), CPU_REV(0, 0) |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 64 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 65 | workaround_reset_start neoverse_n2, ERRATUM(2067956), ERRATA_N2_2067956 |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 66 | sysreg_bit_set NEOVERSE_N2_CPUACTLR_EL1, NEOVERSE_N2_CPUACTLR_EL1_BIT_46 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 67 | workaround_reset_end neoverse_n2, ERRATUM(2067956) |
Bipin Ravi | 7e03069 | 2021-08-30 13:02:51 -0500 | [diff] [blame] | 68 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 69 | check_erratum_ls neoverse_n2, ERRATUM(2067956), CPU_REV(0, 0) |
Arvind Ram Prakash | 5b27ecf | 2023-06-23 14:47:30 -0500 | [diff] [blame] | 70 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 71 | workaround_reset_start neoverse_n2, ERRATUM(2138953), ERRATA_N2_2138953 |
Arvind Ram Prakash | 5b27ecf | 2023-06-23 14:47:30 -0500 | [diff] [blame] | 72 | /* Apply instruction patching sequence */ |
| 73 | mrs x1, NEOVERSE_N2_CPUECTLR2_EL1 |
| 74 | mov x0, #NEOVERSE_N2_CPUECTLR2_EL1_PF_MODE_CNSRV |
| 75 | bfi x1, x0, #CPUECTLR2_EL1_PF_MODE_LSB, #CPUECTLR2_EL1_PF_MODE_WIDTH |
| 76 | msr NEOVERSE_N2_CPUECTLR2_EL1, x1 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 77 | workaround_reset_end neoverse_n2, ERRATUM(2138953) |
Bipin Ravi | 7e03069 | 2021-08-30 13:02:51 -0500 | [diff] [blame] | 78 | |
Arvind Ram Prakash | f99b798 | 2023-06-29 16:17:23 -0500 | [diff] [blame] | 79 | check_erratum_ls neoverse_n2, ERRATUM(2138953), CPU_REV(0, 3) |
Bipin Ravi | 0ba631c | 2021-09-01 01:36:43 -0500 | [diff] [blame] | 80 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 81 | workaround_reset_start neoverse_n2, ERRATUM(2138956), ERRATA_N2_2138956 |
Bipin Ravi | 0ba631c | 2021-09-01 01:36:43 -0500 | [diff] [blame] | 82 | /* Apply instruction patching sequence */ |
| 83 | ldr x0,=0x3 |
| 84 | msr S3_6_c15_c8_0,x0 |
| 85 | ldr x0,=0xF3A08002 |
| 86 | msr S3_6_c15_c8_2,x0 |
| 87 | ldr x0,=0xFFF0F7FE |
| 88 | msr S3_6_c15_c8_3,x0 |
| 89 | ldr x0,=0x10002001003FF |
| 90 | msr S3_6_c15_c8_1,x0 |
| 91 | ldr x0,=0x4 |
| 92 | msr S3_6_c15_c8_0,x0 |
| 93 | ldr x0,=0xBF200000 |
| 94 | msr S3_6_c15_c8_2,x0 |
| 95 | ldr x0,=0xFFEF0000 |
| 96 | msr S3_6_c15_c8_3,x0 |
| 97 | ldr x0,=0x10002001003F3 |
| 98 | msr S3_6_c15_c8_1,x0 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 99 | workaround_reset_end neoverse_n2, ERRATUM(2138956) |
Bipin Ravi | 0ba631c | 2021-09-01 01:36:43 -0500 | [diff] [blame] | 100 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 101 | check_erratum_ls neoverse_n2, ERRATUM(2138956), CPU_REV(0, 0) |
Bipin Ravi | 0ba631c | 2021-09-01 01:36:43 -0500 | [diff] [blame] | 102 | |
nayanpatel-arm | 2f15399 | 2021-10-06 15:31:24 -0700 | [diff] [blame] | 103 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 104 | workaround_reset_start neoverse_n2, ERRATUM(2138958), ERRATA_N2_2138958 |
nayanpatel-arm | 2f15399 | 2021-10-06 15:31:24 -0700 | [diff] [blame] | 105 | /* Apply instruction patching sequence */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 106 | sysreg_bit_set NEOVERSE_N2_CPUACTLR5_EL1, NEOVERSE_N2_CPUACTLR5_EL1_BIT_13 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 107 | workaround_reset_end neoverse_n2, ERRATUM(2138958) |
nayanpatel-arm | 2f15399 | 2021-10-06 15:31:24 -0700 | [diff] [blame] | 108 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 109 | check_erratum_ls neoverse_n2, ERRATUM(2138958), CPU_REV(0, 0) |
nayanpatel-arm | 2f15399 | 2021-10-06 15:31:24 -0700 | [diff] [blame] | 110 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 111 | workaround_reset_start neoverse_n2, ERRATUM(2189731), ERRATA_N2_2189731 |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 112 | sysreg_bit_set NEOVERSE_N2_CPUACTLR5_EL1, NEOVERSE_N2_CPUACTLR5_EL1_BIT_44 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 113 | workaround_reset_end neoverse_n2, ERRATUM(2189731) |
nayanpatel-arm | d4c5f9c | 2021-09-28 09:46:45 -0700 | [diff] [blame] | 114 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 115 | check_erratum_ls neoverse_n2, ERRATUM(2189731), CPU_REV(0, 0) |
nayanpatel-arm | 8e1aa01 | 2021-10-20 18:28:58 -0700 | [diff] [blame] | 116 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 117 | workaround_reset_start neoverse_n2, ERRATUM(2242400), ERRATA_N2_2242400 |
nayanpatel-arm | 8e1aa01 | 2021-10-20 18:28:58 -0700 | [diff] [blame] | 118 | /* Apply instruction patching sequence */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 119 | sysreg_bit_set NEOVERSE_N2_CPUACTLR5_EL1, NEOVERSE_N2_CPUACTLR5_EL1_BIT_17 |
Arvind Ram Prakash | 5b27ecf | 2023-06-23 14:47:30 -0500 | [diff] [blame] | 120 | ldr x0, =0x2 |
| 121 | msr S3_6_c15_c8_0, x0 |
| 122 | ldr x0, =0x10F600E000 |
| 123 | msr S3_6_c15_c8_2, x0 |
| 124 | ldr x0, =0x10FF80E000 |
| 125 | msr S3_6_c15_c8_3, x0 |
| 126 | ldr x0, =0x80000000003FF |
| 127 | msr S3_6_c15_c8_1, x0 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 128 | workaround_reset_end neoverse_n2, ERRATUM(2242400) |
nayanpatel-arm | 8e1aa01 | 2021-10-20 18:28:58 -0700 | [diff] [blame] | 129 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 130 | check_erratum_ls neoverse_n2, ERRATUM(2242400), CPU_REV(0, 0) |
nayanpatel-arm | 8e1aa01 | 2021-10-20 18:28:58 -0700 | [diff] [blame] | 131 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 132 | workaround_reset_start neoverse_n2, ERRATUM(2242415), ERRATA_N2_2242415 |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 133 | sysreg_bit_set NEOVERSE_N2_CPUACTLR_EL1, NEOVERSE_N2_CPUACTLR_EL1_BIT_22 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 134 | workaround_reset_end neoverse_n2, ERRATUM(2242415) |
nayanpatel-arm | fed9813 | 2021-10-07 17:59:33 -0700 | [diff] [blame] | 135 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 136 | check_erratum_ls neoverse_n2, ERRATUM(2242415), CPU_REV(0, 0) |
nayanpatel-arm | fed9813 | 2021-10-07 17:59:33 -0700 | [diff] [blame] | 137 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 138 | workaround_reset_start neoverse_n2, ERRATUM(2280757), ERRATA_N2_2280757 |
nayanpatel-arm | 45b9f6f | 2021-10-20 17:30:46 -0700 | [diff] [blame] | 139 | /* Apply instruction patching sequence */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 140 | sysreg_bit_set NEOVERSE_N2_CPUACTLR_EL1, NEOVERSE_N2_CPUACTLR_EL1_BIT_22 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 141 | workaround_reset_end neoverse_n2, ERRATUM(2280757) |
nayanpatel-arm | 45b9f6f | 2021-10-20 17:30:46 -0700 | [diff] [blame] | 142 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 143 | check_erratum_ls neoverse_n2, ERRATUM(2280757), CPU_REV(0, 0) |
Boyan Karatotev | d3f8b4d | 2022-10-03 14:07:08 +0100 | [diff] [blame] | 144 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 145 | workaround_runtime_start neoverse_n2, ERRATUM(2326639), ERRATA_N2_2326639 |
Boyan Karatotev | d3f8b4d | 2022-10-03 14:07:08 +0100 | [diff] [blame] | 146 | /* Set bit 36 in ACTLR2_EL1 */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 147 | sysreg_bit_set NEOVERSE_N2_CPUACTLR2_EL1, NEOVERSE_N2_CPUACTLR2_EL1_BIT_36 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 148 | workaround_runtime_end neoverse_n2, ERRATUM(2326639) |
Akram Ahmad | b621bda | 2022-07-18 12:27:29 +0100 | [diff] [blame] | 149 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 150 | check_erratum_ls neoverse_n2, ERRATUM(2326639), CPU_REV(0, 0) |
Akram Ahmad | b621bda | 2022-07-18 12:27:29 +0100 | [diff] [blame] | 151 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 152 | workaround_reset_start neoverse_n2, ERRATUM(2376738), ERRATA_N2_2376738 |
Akram Ahmad | b621bda | 2022-07-18 12:27:29 +0100 | [diff] [blame] | 153 | /* Set CPUACTLR2_EL1[0] to 1 to force PLDW/PFRM |
| 154 | * ST to behave like PLD/PFRM LD and not cause |
| 155 | * invalidations to other PE caches. |
| 156 | */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 157 | sysreg_bit_set NEOVERSE_N2_CPUACTLR2_EL1, NEOVERSE_N2_CPUACTLR2_EL1_BIT_0 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 158 | workaround_reset_end neoverse_n2, ERRATUM(2376738) |
Akram Ahmad | b621bda | 2022-07-18 12:27:29 +0100 | [diff] [blame] | 159 | |
Arvind Ram Prakash | f99b798 | 2023-06-29 16:17:23 -0500 | [diff] [blame] | 160 | check_erratum_ls neoverse_n2, ERRATUM(2376738), CPU_REV(0, 3) |
Daniel Boulby | 1af2b11 | 2022-07-06 14:33:13 +0100 | [diff] [blame] | 161 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 162 | workaround_reset_start neoverse_n2, ERRATUM(2388450), ERRATA_N2_2388450 |
Daniel Boulby | 1af2b11 | 2022-07-06 14:33:13 +0100 | [diff] [blame] | 163 | /*Set bit 40 in ACTLR2_EL1 */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 164 | sysreg_bit_set NEOVERSE_N2_CPUACTLR2_EL1, NEOVERSE_N2_CPUACTLR2_EL1_BIT_40 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 165 | workaround_reset_end neoverse_n2, ERRATUM(2388450) |
Daniel Boulby | 1af2b11 | 2022-07-06 14:33:13 +0100 | [diff] [blame] | 166 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 167 | check_erratum_ls neoverse_n2, ERRATUM(2388450), CPU_REV(0, 0) |
Daniel Boulby | 1af2b11 | 2022-07-06 14:33:13 +0100 | [diff] [blame] | 168 | |
Arvind Ram Prakash | 465f93b | 2023-07-05 17:24:23 -0500 | [diff] [blame] | 169 | workaround_reset_start neoverse_n2, ERRATUM(2743014), ERRATA_N2_2743014 |
| 170 | /* Set CPUACTLR5_EL1[56:55] to 2'b01 */ |
| 171 | sysreg_bit_set NEOVERSE_N2_CPUACTLR5_EL1, NEOVERSE_N2_CPUACTLR5_EL1_BIT_55 |
| 172 | sysreg_bit_clear NEOVERSE_N2_CPUACTLR5_EL1, NEOVERSE_N2_CPUACTLR5_EL1_BIT_56 |
| 173 | workaround_reset_end neoverse_n2, ERRATUM(2743014) |
| 174 | |
| 175 | check_erratum_ls neoverse_n2, ERRATUM(2743014), CPU_REV(0, 2) |
| 176 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 177 | workaround_runtime_start neoverse_n2, ERRATUM(2743089), ERRATA_N2_2743089 |
Bipin Ravi | cc744bf | 2022-12-07 17:01:26 -0600 | [diff] [blame] | 178 | /* dsb before isb of power down sequence */ |
| 179 | dsb sy |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 180 | workaround_runtime_end neoverse_n2, ERRATUM(2743089) |
Bipin Ravi | cc744bf | 2022-12-07 17:01:26 -0600 | [diff] [blame] | 181 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 182 | check_erratum_ls neoverse_n2, ERRATUM(2743089), CPU_REV(0, 2) |
Bipin Ravi | cc744bf | 2022-12-07 17:01:26 -0600 | [diff] [blame] | 183 | |
Arvind Ram Prakash | 189622a | 2023-07-17 14:46:14 -0500 | [diff] [blame] | 184 | workaround_reset_start neoverse_n2, ERRATUM(2779511), ERRATA_N2_2779511 |
| 185 | /* Set bit 47 in ACTLR3_EL1 */ |
| 186 | sysreg_bit_set NEOVERSE_N2_CPUACTLR3_EL1, NEOVERSE_N2_CPUACTLR3_EL1_BIT_47 |
| 187 | workaround_reset_end neoverse_n2, ERRATUM(2779511) |
| 188 | |
| 189 | check_erratum_ls neoverse_n2, ERRATUM(2779511), CPU_REV(0, 2) |
| 190 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 191 | workaround_reset_start neoverse_n2, CVE(2022,23960), WORKAROUND_CVE_2022_23960 |
| 192 | #if IMAGE_BL31 |
| 193 | /* |
| 194 | * The Neoverse-N2 generic vectors are overridden to apply errata |
| 195 | * mitigation on exception entry from lower ELs. |
| 196 | */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 197 | override_vector_table wa_cve_vbar_neoverse_n2 |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 198 | #endif /* IMAGE_BL31 */ |
| 199 | workaround_reset_end neoverse_n2, CVE(2022,23960) |
| 200 | |
| 201 | check_erratum_chosen neoverse_n2, CVE(2022, 23960), WORKAROUND_CVE_2022_23960 |
Bipin Ravi | 8649974 | 2022-01-18 01:59:06 -0600 | [diff] [blame] | 202 | |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 203 | /* ------------------------------------------- |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 204 | * The CPU Ops reset function for Neoverse N2. |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 205 | * ------------------------------------------- |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 206 | */ |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 207 | cpu_reset_func_start neoverse_n2 |
nayanpatel-arm | 277581e | 2021-08-06 17:46:10 -0700 | [diff] [blame] | 208 | |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 209 | /* Check if the PE implements SSBS */ |
| 210 | mrs x0, id_aa64pfr1_el1 |
| 211 | tst x0, #(ID_AA64PFR1_EL1_SSBS_MASK << ID_AA64PFR1_EL1_SSBS_SHIFT) |
| 212 | b.eq 1f |
| 213 | |
| 214 | /* Disable speculative loads */ |
| 215 | msr SSBS, xzr |
| 216 | 1: |
| 217 | /* Force all cacheable atomic instructions to be near */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 218 | sysreg_bit_set NEOVERSE_N2_CPUACTLR2_EL1, NEOVERSE_N2_CPUACTLR2_EL1_BIT_2 |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 219 | |
Andre Przywara | 0b7f1b0 | 2023-03-21 13:53:19 +0000 | [diff] [blame] | 220 | #if ENABLE_FEAT_AMU |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 221 | /* Make sure accesses from EL0/EL1 and EL2 are not trapped to EL3 */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 222 | sysreg_bit_set cptr_el3, TAM_BIT |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 223 | /* Make sure accesses from EL0/EL1 are not trapped to EL2 */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 224 | sysreg_bit_set cptr_el2, TAM_BIT |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 225 | /* No need to enable the counters as this would be done at el3 exit */ |
| 226 | #endif |
| 227 | |
| 228 | #if NEOVERSE_Nx_EXTERNAL_LLC |
| 229 | /* Some systems may have External LLC, core needs to be made aware */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 230 | sysreg_bit_set NEOVERSE_N2_CPUECTLR_EL1, NEOVERSE_N2_CPUECTLR_EL1_EXTLLC_BIT |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 231 | #endif |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 232 | cpu_reset_func_end neoverse_n2 |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 233 | |
| 234 | func neoverse_n2_core_pwr_dwn |
Boyan Karatotev | d3f8b4d | 2022-10-03 14:07:08 +0100 | [diff] [blame] | 235 | |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 236 | apply_erratum neoverse_n2, ERRATUM(2326639), ERRATA_N2_2326639 |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 237 | /* --------------------------------------------------- |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 238 | * Enable CPU power down bit in power control register |
| 239 | * No need to do cache maintenance here. |
Bipin Ravi | 7f56547 | 2021-03-31 10:10:27 -0500 | [diff] [blame] | 240 | * --------------------------------------------------- |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 241 | */ |
Arvind Ram Prakash | 05464d9 | 2023-06-27 09:54:23 -0500 | [diff] [blame] | 242 | sysreg_bit_set NEOVERSE_N2_CPUPWRCTLR_EL1, NEOVERSE_N2_CORE_PWRDN_EN_BIT |
| 243 | |
| 244 | apply_erratum neoverse_n2, ERRATUM(2743089), ERRATA_N2_2743089 |
| 245 | |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 246 | isb |
| 247 | ret |
| 248 | endfunc neoverse_n2_core_pwr_dwn |
| 249 | |
Arvind Ram Prakash | 7aea56c | 2023-06-26 15:05:40 -0500 | [diff] [blame] | 250 | errata_report_shim neoverse_n2 |
Javier Almansa Sobrino | 9faad3c | 2020-10-23 13:22:07 +0100 | [diff] [blame] | 251 | |
| 252 | /* --------------------------------------------- |
| 253 | * This function provides Neoverse N2 specific |
| 254 | * register information for crash reporting. |
| 255 | * It needs to return with x6 pointing to |
| 256 | * a list of register names in ASCII and |
| 257 | * x8 - x15 having values of registers to be |
| 258 | * reported. |
| 259 | * --------------------------------------------- |
| 260 | */ |
| 261 | .section .rodata.neoverse_n2_regs, "aS" |
| 262 | neoverse_n2_regs: /* The ASCII list of register names to be reported */ |
| 263 | .asciz "cpupwrctlr_el1", "" |
| 264 | |
| 265 | func neoverse_n2_cpu_reg_dump |
| 266 | adr x6, neoverse_n2_regs |
| 267 | mrs x8, NEOVERSE_N2_CPUPWRCTLR_EL1 |
| 268 | ret |
| 269 | endfunc neoverse_n2_cpu_reg_dump |
| 270 | |
| 271 | declare_cpu_ops neoverse_n2, NEOVERSE_N2_MIDR, \ |
| 272 | neoverse_n2_reset_func, \ |
| 273 | neoverse_n2_core_pwr_dwn |