silicon-errata.rst 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. =======================================
  2. Silicon Errata and Software Workarounds
  3. =======================================
  4. Author: Will Deacon <[email protected]>
  5. Date : 27 November 2015
  6. It is an unfortunate fact of life that hardware is often produced with
  7. so-called "errata", which can cause it to deviate from the architecture
  8. under specific circumstances. For hardware produced by ARM, these
  9. errata are broadly classified into the following categories:
  10. ========== ========================================================
  11. Category A A critical error without a viable workaround.
  12. Category B A significant or critical error with an acceptable
  13. workaround.
  14. Category C A minor error that is not expected to occur under normal
  15. operation.
  16. ========== ========================================================
  17. For more information, consult one of the "Software Developers Errata
  18. Notice" documents available on infocenter.arm.com (registration
  19. required).
  20. As far as Linux is concerned, Category B errata may require some special
  21. treatment in the operating system. For example, avoiding a particular
  22. sequence of code, or configuring the processor in a particular way. A
  23. less common situation may require similar actions in order to declassify
  24. a Category A erratum into a Category C erratum. These are collectively
  25. known as "software workarounds" and are only required in the minority of
  26. cases (e.g. those cases that both require a non-secure workaround *and*
  27. can be triggered by Linux).
  28. For software workarounds that may adversely impact systems unaffected by
  29. the erratum in question, a Kconfig entry is added under "Kernel
  30. Features" -> "ARM errata workarounds via the alternatives framework".
  31. These are enabled by default and patched in at runtime when an affected
  32. CPU is detected. For less-intrusive workarounds, a Kconfig option is not
  33. available and the code is structured (preferably with a comment) in such
  34. a way that the erratum will not be hit.
  35. This approach can make it slightly onerous to determine exactly which
  36. errata are worked around in an arbitrary kernel source tree, so this
  37. file acts as a registry of software workarounds in the Linux Kernel and
  38. will be updated when new workarounds are committed and backported to
  39. stable kernels.
  40. +----------------+-----------------+-----------------+-----------------------------+
  41. | Implementor | Component | Erratum ID | Kconfig |
  42. +================+=================+=================+=============================+
  43. | Allwinner | A64/R18 | UNKNOWN1 | SUN50I_ERRATUM_UNKNOWN1 |
  44. +----------------+-----------------+-----------------+-----------------------------+
  45. +----------------+-----------------+-----------------+-----------------------------+
  46. | ARM | Cortex-A510 | #2457168 | ARM64_ERRATUM_2457168 |
  47. +----------------+-----------------+-----------------+-----------------------------+
  48. | ARM | Cortex-A510 | #2064142 | ARM64_ERRATUM_2064142 |
  49. +----------------+-----------------+-----------------+-----------------------------+
  50. | ARM | Cortex-A510 | #2038923 | ARM64_ERRATUM_2038923 |
  51. +----------------+-----------------+-----------------+-----------------------------+
  52. | ARM | Cortex-A510 | #1902691 | ARM64_ERRATUM_1902691 |
  53. +----------------+-----------------+-----------------+-----------------------------+
  54. | ARM | Cortex-A53 | #826319 | ARM64_ERRATUM_826319 |
  55. +----------------+-----------------+-----------------+-----------------------------+
  56. | ARM | Cortex-A53 | #827319 | ARM64_ERRATUM_827319 |
  57. +----------------+-----------------+-----------------+-----------------------------+
  58. | ARM | Cortex-A53 | #824069 | ARM64_ERRATUM_824069 |
  59. +----------------+-----------------+-----------------+-----------------------------+
  60. | ARM | Cortex-A53 | #819472 | ARM64_ERRATUM_819472 |
  61. +----------------+-----------------+-----------------+-----------------------------+
  62. | ARM | Cortex-A53 | #845719 | ARM64_ERRATUM_845719 |
  63. +----------------+-----------------+-----------------+-----------------------------+
  64. | ARM | Cortex-A53 | #843419 | ARM64_ERRATUM_843419 |
  65. +----------------+-----------------+-----------------+-----------------------------+
  66. | ARM | Cortex-A55 | #1024718 | ARM64_ERRATUM_1024718 |
  67. +----------------+-----------------+-----------------+-----------------------------+
  68. | ARM | Cortex-A55 | #1530923 | ARM64_ERRATUM_1530923 |
  69. +----------------+-----------------+-----------------+-----------------------------+
  70. | ARM | Cortex-A55 | #2441007 | ARM64_ERRATUM_2441007 |
  71. +----------------+-----------------+-----------------+-----------------------------+
  72. | ARM | Cortex-A57 | #832075 | ARM64_ERRATUM_832075 |
  73. +----------------+-----------------+-----------------+-----------------------------+
  74. | ARM | Cortex-A57 | #852523 | N/A |
  75. +----------------+-----------------+-----------------+-----------------------------+
  76. | ARM | Cortex-A57 | #834220 | ARM64_ERRATUM_834220 |
  77. +----------------+-----------------+-----------------+-----------------------------+
  78. | ARM | Cortex-A57 | #1319537 | ARM64_ERRATUM_1319367 |
  79. +----------------+-----------------+-----------------+-----------------------------+
  80. | ARM | Cortex-A57 | #1742098 | ARM64_ERRATUM_1742098 |
  81. +----------------+-----------------+-----------------+-----------------------------+
  82. | ARM | Cortex-A72 | #853709 | N/A |
  83. +----------------+-----------------+-----------------+-----------------------------+
  84. | ARM | Cortex-A72 | #1319367 | ARM64_ERRATUM_1319367 |
  85. +----------------+-----------------+-----------------+-----------------------------+
  86. | ARM | Cortex-A72 | #1655431 | ARM64_ERRATUM_1742098 |
  87. +----------------+-----------------+-----------------+-----------------------------+
  88. | ARM | Cortex-A73 | #858921 | ARM64_ERRATUM_858921 |
  89. +----------------+-----------------+-----------------+-----------------------------+
  90. | ARM | Cortex-A76 | #1188873,1418040| ARM64_ERRATUM_1418040 |
  91. +----------------+-----------------+-----------------+-----------------------------+
  92. | ARM | Cortex-A76 | #1165522 | ARM64_ERRATUM_1165522 |
  93. +----------------+-----------------+-----------------+-----------------------------+
  94. | ARM | Cortex-A76 | #1286807 | ARM64_ERRATUM_1286807 |
  95. +----------------+-----------------+-----------------+-----------------------------+
  96. | ARM | Cortex-A76 | #1463225 | ARM64_ERRATUM_1463225 |
  97. +----------------+-----------------+-----------------+-----------------------------+
  98. | ARM | Cortex-A77 | #1508412 | ARM64_ERRATUM_1508412 |
  99. +----------------+-----------------+-----------------+-----------------------------+
  100. | ARM | Cortex-A510 | #2051678 | ARM64_ERRATUM_2051678 |
  101. +----------------+-----------------+-----------------+-----------------------------+
  102. | ARM | Cortex-A510 | #2077057 | ARM64_ERRATUM_2077057 |
  103. +----------------+-----------------+-----------------+-----------------------------+
  104. | ARM | Cortex-A510 | #2441009 | ARM64_ERRATUM_2441009 |
  105. +----------------+-----------------+-----------------+-----------------------------+
  106. | ARM | Cortex-A510 | #2658417 | ARM64_ERRATUM_2658417 |
  107. +----------------+-----------------+-----------------+-----------------------------+
  108. | ARM | Cortex-A710 | #2119858 | ARM64_ERRATUM_2119858 |
  109. +----------------+-----------------+-----------------+-----------------------------+
  110. | ARM | Cortex-A710 | #2054223 | ARM64_ERRATUM_2054223 |
  111. +----------------+-----------------+-----------------+-----------------------------+
  112. | ARM | Cortex-A710 | #2224489 | ARM64_ERRATUM_2224489 |
  113. +----------------+-----------------+-----------------+-----------------------------+
  114. | ARM | Cortex-X2 | #2119858 | ARM64_ERRATUM_2119858 |
  115. +----------------+-----------------+-----------------+-----------------------------+
  116. | ARM | Cortex-X2 | #2224489 | ARM64_ERRATUM_2224489 |
  117. +----------------+-----------------+-----------------+-----------------------------+
  118. | ARM | Neoverse-N1 | #1188873,1418040| ARM64_ERRATUM_1418040 |
  119. +----------------+-----------------+-----------------+-----------------------------+
  120. | ARM | Neoverse-N1 | #1349291 | N/A |
  121. +----------------+-----------------+-----------------+-----------------------------+
  122. | ARM | Neoverse-N1 | #1542419 | ARM64_ERRATUM_1542419 |
  123. +----------------+-----------------+-----------------+-----------------------------+
  124. | ARM | Neoverse-N2 | #2139208 | ARM64_ERRATUM_2139208 |
  125. +----------------+-----------------+-----------------+-----------------------------+
  126. | ARM | Neoverse-N2 | #2067961 | ARM64_ERRATUM_2067961 |
  127. +----------------+-----------------+-----------------+-----------------------------+
  128. | ARM | Neoverse-N2 | #2253138 | ARM64_ERRATUM_2253138 |
  129. +----------------+-----------------+-----------------+-----------------------------+
  130. | ARM | MMU-500 | #841119,826419 | N/A |
  131. +----------------+-----------------+-----------------+-----------------------------+
  132. | ARM | MMU-600 | #1076982,1209401| N/A |
  133. +----------------+-----------------+-----------------+-----------------------------+
  134. | ARM | MMU-700 | #2268618,2812531| N/A |
  135. +----------------+-----------------+-----------------+-----------------------------+
  136. +----------------+-----------------+-----------------+-----------------------------+
  137. | ARM | GIC-700 | #2941627 | ARM64_ERRATUM_2941627 |
  138. +----------------+-----------------+-----------------+-----------------------------+
  139. +----------------+-----------------+-----------------+-----------------------------+
  140. | Broadcom | Brahma-B53 | N/A | ARM64_ERRATUM_845719 |
  141. +----------------+-----------------+-----------------+-----------------------------+
  142. | Broadcom | Brahma-B53 | N/A | ARM64_ERRATUM_843419 |
  143. +----------------+-----------------+-----------------+-----------------------------+
  144. +----------------+-----------------+-----------------+-----------------------------+
  145. | Cavium | ThunderX ITS | #22375,24313 | CAVIUM_ERRATUM_22375 |
  146. +----------------+-----------------+-----------------+-----------------------------+
  147. | Cavium | ThunderX ITS | #23144 | CAVIUM_ERRATUM_23144 |
  148. +----------------+-----------------+-----------------+-----------------------------+
  149. | Cavium | ThunderX GICv3 | #23154,38545 | CAVIUM_ERRATUM_23154 |
  150. +----------------+-----------------+-----------------+-----------------------------+
  151. | Cavium | ThunderX GICv3 | #38539 | N/A |
  152. +----------------+-----------------+-----------------+-----------------------------+
  153. | Cavium | ThunderX Core | #27456 | CAVIUM_ERRATUM_27456 |
  154. +----------------+-----------------+-----------------+-----------------------------+
  155. | Cavium | ThunderX Core | #30115 | CAVIUM_ERRATUM_30115 |
  156. +----------------+-----------------+-----------------+-----------------------------+
  157. | Cavium | ThunderX SMMUv2 | #27704 | N/A |
  158. +----------------+-----------------+-----------------+-----------------------------+
  159. | Cavium | ThunderX2 SMMUv3| #74 | N/A |
  160. +----------------+-----------------+-----------------+-----------------------------+
  161. | Cavium | ThunderX2 SMMUv3| #126 | N/A |
  162. +----------------+-----------------+-----------------+-----------------------------+
  163. | Cavium | ThunderX2 Core | #219 | CAVIUM_TX2_ERRATUM_219 |
  164. +----------------+-----------------+-----------------+-----------------------------+
  165. +----------------+-----------------+-----------------+-----------------------------+
  166. | Marvell | ARM-MMU-500 | #582743 | N/A |
  167. +----------------+-----------------+-----------------+-----------------------------+
  168. +----------------+-----------------+-----------------+-----------------------------+
  169. | NVIDIA | Carmel Core | N/A | NVIDIA_CARMEL_CNP_ERRATUM |
  170. +----------------+-----------------+-----------------+-----------------------------+
  171. +----------------+-----------------+-----------------+-----------------------------+
  172. | Freescale/NXP | LS2080A/LS1043A | A-008585 | FSL_ERRATUM_A008585 |
  173. +----------------+-----------------+-----------------+-----------------------------+
  174. +----------------+-----------------+-----------------+-----------------------------+
  175. | Hisilicon | Hip0{5,6,7} | #161010101 | HISILICON_ERRATUM_161010101 |
  176. +----------------+-----------------+-----------------+-----------------------------+
  177. | Hisilicon | Hip0{6,7} | #161010701 | N/A |
  178. +----------------+-----------------+-----------------+-----------------------------+
  179. | Hisilicon | Hip0{6,7} | #161010803 | N/A |
  180. +----------------+-----------------+-----------------+-----------------------------+
  181. | Hisilicon | Hip07 | #161600802 | HISILICON_ERRATUM_161600802 |
  182. +----------------+-----------------+-----------------+-----------------------------+
  183. | Hisilicon | Hip08 SMMU PMCG | #162001800 | N/A |
  184. +----------------+-----------------+-----------------+-----------------------------+
  185. | Hisilicon | Hip08 SMMU PMCG | #162001900 | N/A |
  186. | | Hip09 SMMU PMCG | | |
  187. +----------------+-----------------+-----------------+-----------------------------+
  188. +----------------+-----------------+-----------------+-----------------------------+
  189. | Qualcomm Tech. | Kryo/Falkor v1 | E1003 | QCOM_FALKOR_ERRATUM_1003 |
  190. +----------------+-----------------+-----------------+-----------------------------+
  191. | Qualcomm Tech. | Kryo/Falkor v1 | E1009 | QCOM_FALKOR_ERRATUM_1009 |
  192. +----------------+-----------------+-----------------+-----------------------------+
  193. | Qualcomm Tech. | QDF2400 ITS | E0065 | QCOM_QDF2400_ERRATUM_0065 |
  194. +----------------+-----------------+-----------------+-----------------------------+
  195. | Qualcomm Tech. | Falkor v{1,2} | E1041 | QCOM_FALKOR_ERRATUM_1041 |
  196. +----------------+-----------------+-----------------+-----------------------------+
  197. | Qualcomm Tech. | Kryo4xx Gold | N/A | ARM64_ERRATUM_1463225 |
  198. +----------------+-----------------+-----------------+-----------------------------+
  199. | Qualcomm Tech. | Kryo4xx Gold | N/A | ARM64_ERRATUM_1418040 |
  200. +----------------+-----------------+-----------------+-----------------------------+
  201. | Qualcomm Tech. | Kryo4xx Silver | N/A | ARM64_ERRATUM_1530923 |
  202. +----------------+-----------------+-----------------+-----------------------------+
  203. | Qualcomm Tech. | Kryo4xx Silver | N/A | ARM64_ERRATUM_1024718 |
  204. +----------------+-----------------+-----------------+-----------------------------+
  205. | Qualcomm Tech. | Kryo4xx Gold | N/A | ARM64_ERRATUM_1286807 |
  206. +----------------+-----------------+-----------------+-----------------------------+
  207. +----------------+-----------------+-----------------+-----------------------------+
  208. | Fujitsu | A64FX | E#010001 | FUJITSU_ERRATUM_010001 |
  209. +----------------+-----------------+-----------------+-----------------------------+
  210. +----------------+-----------------+-----------------+-----------------------------+
  211. | ASR | ASR8601 | #8601001 | N/A |
  212. +----------------+-----------------+-----------------+-----------------------------+