diff --git a/arch/arm64/include/asm/cputype.h b/arch/arm64/include/asm/cputype.h index bb2664e482a94322d488cbc2f023d06f4f28b5c9..2325023b6b3af31da15332a8750946e43a56f326 100644 --- a/arch/arm64/include/asm/cputype.h +++ b/arch/arm64/include/asm/cputype.h @@ -149,7 +149,6 @@ struct midr_range { } #define MIDR_REV_RANGE(m, v, r_min, r_max) MIDR_RANGE(m, v, r_min, v, r_max) -#define MIDR_REV(m, v, r) MIDR_RANGE(m, v, r, v, r) #define MIDR_ALL_VERSIONS(m) MIDR_RANGE(m, 0, 0, 0xf, 0xf) static inline bool midr_is_cpu_model_range(u32 midr, u32 model, u32 rv_min, diff --git a/arch/arm64/kernel/cpu_errata.c b/arch/arm64/kernel/cpu_errata.c index b14102a01a47ffd2e72f9bc5a7c03b7889778670..c74bf316c63e7056e14ebc02cc7a36d2e86d53b3 100644 --- a/arch/arm64/kernel/cpu_errata.c +++ b/arch/arm64/kernel/cpu_errata.c @@ -730,28 +730,6 @@ static const struct midr_range arm64_harden_el2_vectors[] = { #endif -#ifdef CONFIG_CAVIUM_ERRATUM_27456 -static const struct midr_range cavium_erratum_27456_cpus[] = { - /* Cavium ThunderX, T88 pass 1.x - 2.1 */ - MIDR_RANGE(MIDR_THUNDERX, 0, 0, 1, 1), - /* Cavium ThunderX, T81 pass 1.0 */ - MIDR_REV(MIDR_THUNDERX_81XX, 0, 0), - {}, -}; -#endif - -#ifdef CONFIG_CAVIUM_ERRATUM_30115 -static const struct midr_range cavium_erratum_30115_cpus[] = { - /* Cavium ThunderX, T88 pass 1.x - 2.2 */ - MIDR_RANGE(MIDR_THUNDERX, 0, 0, 1, 2), - /* Cavium ThunderX, T81 pass 1.0 - 1.2 */ - MIDR_REV_RANGE(MIDR_THUNDERX_81XX, 0, 0, 2), - /* Cavium ThunderX, T83 pass 1.0 */ - MIDR_REV(MIDR_THUNDERX_83XX, 0, 0), - {}, -}; -#endif - #ifdef CONFIG_ARM64_WORKAROUND_CLEAN_CACHE static const struct midr_range workaround_clean_cache[] = { #if defined(CONFIG_ARM64_ERRATUM_826319) || \ @@ -824,16 +802,40 @@ const struct arm64_cpu_capabilities arm64_errata[] = { #endif #ifdef CONFIG_CAVIUM_ERRATUM_27456 { + /* Cavium ThunderX, T88 pass 1.x - 2.1 */ .desc = "Cavium erratum 27456", .capability = ARM64_WORKAROUND_CAVIUM_27456, - ERRATA_MIDR_RANGE_LIST(cavium_erratum_27456_cpus), + ERRATA_MIDR_RANGE(MIDR_THUNDERX, + 0, 0, + 1, 1), + }, + { + /* Cavium ThunderX, T81 pass 1.0 */ + .desc = "Cavium erratum 27456", + .capability = ARM64_WORKAROUND_CAVIUM_27456, + ERRATA_MIDR_REV(MIDR_THUNDERX_81XX, 0, 0), }, #endif #ifdef CONFIG_CAVIUM_ERRATUM_30115 { + /* Cavium ThunderX, T88 pass 1.x - 2.2 */ + .desc = "Cavium erratum 30115", + .capability = ARM64_WORKAROUND_CAVIUM_30115, + ERRATA_MIDR_RANGE(MIDR_THUNDERX, + 0, 0, + 1, 2), + }, + { + /* Cavium ThunderX, T81 pass 1.0 - 1.2 */ + .desc = "Cavium erratum 30115", + .capability = ARM64_WORKAROUND_CAVIUM_30115, + ERRATA_MIDR_REV_RANGE(MIDR_THUNDERX_81XX, 0, 0, 2), + }, + { + /* Cavium ThunderX, T83 pass 1.0 */ .desc = "Cavium erratum 30115", .capability = ARM64_WORKAROUND_CAVIUM_30115, - ERRATA_MIDR_RANGE_LIST(cavium_erratum_30115_cpus), + ERRATA_MIDR_REV(MIDR_THUNDERX_83XX, 0, 0), }, #endif {