// SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause /* * Copyright (C) 2023, STMicroelectronics - All Rights Reserved */ #define LOG_CATEGORY LOGC_ARCH #include #include #include #include #include /* SYSCFG register */ #define SYSCFG_DEVICEID_OFFSET 0x6400 #define SYSCFG_DEVICEID_DEV_ID_MASK GENMASK(11, 0) #define SYSCFG_DEVICEID_DEV_ID_SHIFT 0 #define SYSCFG_DEVICEID_REV_ID_MASK GENMASK(31, 16) #define SYSCFG_DEVICEID_REV_ID_SHIFT 16 /* Device Part Number (RPN) = OTP9 */ #define RPN_SHIFT 0 #define RPN_MASK GENMASK(31, 0) /* Package = bit 0:2 of OTP122 => STM32MP25_PKG defines * - 000: Custom package * - 011: TFBGA361 => AL = 10x10, 361 balls pith 0.5mm * - 100: TFBGA424 => AK = 14x14, 424 balls pith 0.5mm * - 101: TFBGA436 => AI = 18x18, 436 balls pith 0.5mm * - others: Reserved */ #define PKG_SHIFT 0 #define PKG_MASK GENMASK(2, 0) static u32 read_deviceid(void) { void *syscfg = syscon_get_first_range(STM32MP_SYSCON_SYSCFG); return readl(syscfg + SYSCFG_DEVICEID_OFFSET); } u32 get_cpu_dev(void) { return (read_deviceid() & SYSCFG_DEVICEID_DEV_ID_MASK) >> SYSCFG_DEVICEID_DEV_ID_SHIFT; } u32 get_cpu_rev(void) { return (read_deviceid() & SYSCFG_DEVICEID_REV_ID_MASK) >> SYSCFG_DEVICEID_REV_ID_SHIFT; } /* Get Device Part Number (RPN) from OTP */ u32 get_cpu_type(void) { return get_otp(BSEC_OTP_RPN, RPN_SHIFT, RPN_MASK); } /* Get Package options from OTP */ u32 get_cpu_package(void) { return get_otp(BSEC_OTP_PKG, PKG_SHIFT, PKG_MASK); } int get_eth_nb(void) { int nb_eth; switch (get_cpu_type()) { case CPU_STM32MP257Fxx: fallthrough; case CPU_STM32MP257Dxx: fallthrough; case CPU_STM32MP257Cxx: fallthrough; case CPU_STM32MP257Axx: nb_eth = 5; /* dual ETH with TSN support */ break; case CPU_STM32MP253Fxx: fallthrough; case CPU_STM32MP253Dxx: fallthrough; case CPU_STM32MP253Cxx: fallthrough; case CPU_STM32MP253Axx: nb_eth = 2; /* dual ETH */ break; case CPU_STM32MP251Fxx: fallthrough; case CPU_STM32MP251Dxx: fallthrough; case CPU_STM32MP251Cxx: fallthrough; case CPU_STM32MP251Axx: nb_eth = 1; /* single ETH */ break; default: nb_eth = 0; break; } return nb_eth; } void get_soc_name(char name[SOC_NAME_SIZE]) { char *cpu_s, *cpu_r, *package; cpu_s = "????"; cpu_r = "?"; package = "??"; if (get_cpu_dev() == CPU_DEV_STM32MP25) { switch (get_cpu_type()) { case CPU_STM32MP257Fxx: cpu_s = "257F"; break; case CPU_STM32MP257Dxx: cpu_s = "257D"; break; case CPU_STM32MP257Cxx: cpu_s = "257C"; break; case CPU_STM32MP257Axx: cpu_s = "257A"; break; case CPU_STM32MP255Fxx: cpu_s = "255F"; break; case CPU_STM32MP255Dxx: cpu_s = "255D"; break; case CPU_STM32MP255Cxx: cpu_s = "255C"; break; case CPU_STM32MP255Axx: cpu_s = "255A"; break; case CPU_STM32MP253Fxx: cpu_s = "253F"; break; case CPU_STM32MP253Dxx: cpu_s = "253D"; break; case CPU_STM32MP253Cxx: cpu_s = "253C"; break; case CPU_STM32MP253Axx: cpu_s = "253A"; break; case CPU_STM32MP251Fxx: cpu_s = "251F"; break; case CPU_STM32MP251Dxx: cpu_s = "251D"; break; case CPU_STM32MP251Cxx: cpu_s = "251C"; break; case CPU_STM32MP251Axx: cpu_s = "251A"; break; default: cpu_s = "25??"; break; } /* REVISION */ switch (get_cpu_rev()) { case CPU_REV1: cpu_r = "A"; break; default: break; } /* PACKAGE */ switch (get_cpu_package()) { case STM32MP25_PKG_CUSTOM: package = "XX"; break; case STM32MP25_PKG_AL_TBGA361: package = "AL"; break; case STM32MP25_PKG_AK_TBGA424: package = "AK"; break; case STM32MP25_PKG_AI_TBGA436: package = "AI"; break; default: break; } } snprintf(name, SOC_NAME_SIZE, "STM32MP%s%s Rev.%s", cpu_s, package, cpu_r); }