]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
arm: stm32mp: implement new STM32MP25 revision ID system
authorPatrick Delaunay <patrick.delaunay@foss.st.com>
Tue, 19 Mar 2024 19:14:27 +0000 (20:14 +0100)
committerPatrice Chotard <patrice.chotard@foss.st.com>
Fri, 25 Apr 2025 14:00:23 +0000 (16:00 +0200)
The STM32MP25 revision ID are now defined with the OTP102, this patch
implements this new system.

Signed-off-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
Signed-off-by: Patrice CHOTARD <patrice.chotard@foss.st.com>
arch/arm/mach-stm32mp/include/mach/stm32.h
arch/arm/mach-stm32mp/include/mach/sys_proto.h
arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c

index 156009f51e3b35043e5cb254fb63f4ef16a3a954..a9ac49bc5d298772d6066215ad5012c3cb155eae 100644 (file)
@@ -212,6 +212,7 @@ enum forced_boot_mode {
 #ifdef CONFIG_STM32MP25X
 #define BSEC_OTP_SERIAL        5
 #define BSEC_OTP_RPN   9
+#define BSEC_OTP_REVID 102
 #define BSEC_OTP_PKG   122
 #define BSEC_OTP_BOARD 246
 #define BSEC_OTP_MAC   247
index 2a65efc0a50a42bf95106c08b9efa98fd3e5aa5b..0770f0a0cf6ce0c21ab1738c345f4195f82b08ae 100644 (file)
@@ -58,6 +58,7 @@ u32 get_cpu_type(void);
 /* return CPU_DEV constants */
 u32 get_cpu_dev(void);
 
+/* Silicon revision = REV_ID[15:0] of Device Version */
 #define CPU_REV1       0x1000
 #define CPU_REV1_1     0x1001
 #define CPU_REV1_2     0x1003
@@ -65,7 +66,15 @@ u32 get_cpu_dev(void);
 #define CPU_REV2_1     0x2001
 #define CPU_REV2_2     0x2003
 
-/* return Silicon revision = REV_ID[15:0] of Device Version */
+/* OTP revision ID = 6 bits : 3 for Major / 3 for Minor */
+#define OTP_REVID_1    0b001000
+#define OTP_REVID_1_1  0b001001
+#define OTP_REVID_1_2  0b001010
+#define OTP_REVID_2    0b010000
+#define OTP_REVID_2_1  0b010001
+#define OTP_REVID_2_2  0b010010
+
+/* return SoC revision = Silicon revision (STM32MP1) or OTP revision ID (STM32MP2)*/
 u32 get_cpu_rev(void);
 
 /* Get Package options from OTP */
index 7f896a0d65d2f5730bd7b5c7ce4b7a7a07a194ae..ac229bdf7cc233581322156ed2952540891c373c 100644 (file)
 #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
+
+/* Revision ID = OTP102[5:0] 6 bits : 3 for Major / 3 for Minor*/
+#define REVID_SHIFT    0
+#define REVID_MASK     GENMASK(5, 0)
 
 /* Device Part Number (RPN) = OTP9 */
 #define RPN_SHIFT      0
@@ -46,7 +48,7 @@ u32 get_cpu_dev(void)
 
 u32 get_cpu_rev(void)
 {
-       return (read_deviceid() & SYSCFG_DEVICEID_REV_ID_MASK) >> SYSCFG_DEVICEID_REV_ID_SHIFT;
+       return get_otp(BSEC_OTP_REVID, REVID_SHIFT, REVID_MASK);
 }
 
 /* Get Device Part Number (RPN) from OTP */
@@ -164,12 +166,21 @@ void get_soc_name(char name[SOC_NAME_SIZE])
                }
                /* REVISION */
                switch (get_cpu_rev()) {
-               case CPU_REV1:
+               case OTP_REVID_1:
                        cpu_r = "A";
                        break;
-               case CPU_REV2:
+               case OTP_REVID_1_1:
+                       cpu_r = "Z";
+                       break;
+               case OTP_REVID_2:
                        cpu_r = "B";
                        break;
+               case OTP_REVID_2_1:
+                       cpu_r = "Y";
+                       break;
+               case OTP_REVID_2_2:
+                       cpu_r = "X";
+                       break;
                default:
                        break;
                }