Same code is duplicated into stm32mp25x.c, stm32mp23x.c and stm32mp21x.c.

Migrate read_deviceid(), get_cpu_dev(), get_cpu_rev(), get_cpu_type() and
get_cpu_package() into new stm32mp2x.c.

Signed-off-by: Patrice Chotard <[email protected]>
---
 arch/arm/mach-stm32mp/stm32mp2/Makefile     |  1 +
 arch/arm/mach-stm32mp/stm32mp2/stm32mp21x.c | 44 -----------------------
 arch/arm/mach-stm32mp/stm32mp2/stm32mp23x.c | 44 -----------------------
 arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c | 46 ------------------------
 arch/arm/mach-stm32mp/stm32mp2/stm32mp2x.c  | 56 +++++++++++++++++++++++++++++
 5 files changed, 57 insertions(+), 134 deletions(-)

diff --git a/arch/arm/mach-stm32mp/stm32mp2/Makefile 
b/arch/arm/mach-stm32mp/stm32mp2/Makefile
index b25af2e8934..8f2e641dcab 100644
--- a/arch/arm/mach-stm32mp/stm32mp2/Makefile
+++ b/arch/arm/mach-stm32mp/stm32mp2/Makefile
@@ -6,6 +6,7 @@
 obj-y += cpu.o
 obj-y += arm64-mmu.o
 obj-y += rifsc.o
+obj-y += stm32mp2x.o
 obj-$(CONFIG_OF_SYSTEM_SETUP) += fdt.o
 obj-$(CONFIG_STM32MP21X) += stm32mp21x.o
 obj-$(CONFIG_STM32MP23X) += stm32mp23x.o
diff --git a/arch/arm/mach-stm32mp/stm32mp2/stm32mp21x.c 
b/arch/arm/mach-stm32mp/stm32mp2/stm32mp21x.c
index 40d0f329496..7b5d79d3497 100644
--- a/arch/arm/mach-stm32mp/stm32mp2/stm32mp21x.c
+++ b/arch/arm/mach-stm32mp/stm32mp2/stm32mp21x.c
@@ -11,19 +11,6 @@
 #include <asm/arch/stm32.h>
 #include <asm/arch/sys_proto.h>
 
-/* SYSCFG register */
-#define SYSCFG_DEVICEID_OFFSET         0x6400
-#define SYSCFG_DEVICEID_DEV_ID_MASK    GENMASK(11, 0)
-#define SYSCFG_DEVICEID_DEV_ID_SHIFT   0
-
-/* 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
-#define RPN_MASK       GENMASK(31, 0)
-
 /* Package = bit 0:2 of OTP122 => STM32MP21_PKG defines
  * - 000: Custom package
  * - 001: VFBGA361 => AL = 10x10, 361 balls pith 0.5mm
@@ -32,37 +19,6 @@
  * - 101: TFBGA289 => AM = 14x14, 289 balls pith 0.8mm
  * - 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 get_otp(BSEC_OTP_REVID, REVID_SHIFT, REVID_MASK);
-}
-
-/* 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)
 {
diff --git a/arch/arm/mach-stm32mp/stm32mp2/stm32mp23x.c 
b/arch/arm/mach-stm32mp/stm32mp2/stm32mp23x.c
index 022db60811a..e4e5812760c 100644
--- a/arch/arm/mach-stm32mp/stm32mp2/stm32mp23x.c
+++ b/arch/arm/mach-stm32mp/stm32mp2/stm32mp23x.c
@@ -11,19 +11,6 @@
 #include <asm/arch/stm32.h>
 #include <asm/arch/sys_proto.h>
 
-/* SYSCFG register */
-#define SYSCFG_DEVICEID_OFFSET         0x6400
-#define SYSCFG_DEVICEID_DEV_ID_MASK    GENMASK(11, 0)
-#define SYSCFG_DEVICEID_DEV_ID_SHIFT   0
-
-/* 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
-#define RPN_MASK       GENMASK(31, 0)
-
 /* Package = bit 0:2 of OTP122 => STM32MP23_PKG defines
  * - 000: Custom package
  * - 011: TFBGA361 => AL = 10x10, 361 balls pith 0.5mm
@@ -31,37 +18,6 @@
  * - 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 get_otp(BSEC_OTP_REVID, REVID_SHIFT, REVID_MASK);
-}
-
-/* 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)
 {
diff --git a/arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c 
b/arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c
index bf1f3d3c5a7..e0d54f4ecc8 100644
--- a/arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c
+++ b/arch/arm/mach-stm32mp/stm32mp2/stm32mp25x.c
@@ -6,24 +6,9 @@
 #define LOG_CATEGORY LOGC_ARCH
 
 #include <log.h>
-#include <syscon.h>
 #include <asm/io.h>
-#include <asm/arch/stm32.h>
 #include <asm/arch/sys_proto.h>
 
-/* SYSCFG register */
-#define SYSCFG_DEVICEID_OFFSET         0x6400
-#define SYSCFG_DEVICEID_DEV_ID_MASK    GENMASK(11, 0)
-#define SYSCFG_DEVICEID_DEV_ID_SHIFT   0
-
-/* 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
-#define RPN_MASK       GENMASK(31, 0)
-
 /* Package = bit 0:2 of OTP122 => STM32MP25_PKG defines
  * - 000: Custom package
  * - 001: VFBGA361 => AL = 10x10, 361 balls pith 0.5mm
@@ -31,37 +16,6 @@
  * - 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 get_otp(BSEC_OTP_REVID, REVID_SHIFT, REVID_MASK);
-}
-
-/* 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)
 {
diff --git a/arch/arm/mach-stm32mp/stm32mp2/stm32mp2x.c 
b/arch/arm/mach-stm32mp/stm32mp2/stm32mp2x.c
new file mode 100644
index 00000000000..551601a12a9
--- /dev/null
+++ b/arch/arm/mach-stm32mp/stm32mp2/stm32mp2x.c
@@ -0,0 +1,56 @@
+// SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause
+/*
+ * Copyright (C) 2026, STMicroelectronics - All Rights Reserved
+ */
+
+#define LOG_CATEGORY LOGC_ARCH
+
+#include <log.h>
+#include <syscon.h>
+#include <asm/io.h>
+#include <asm/arch/sys_proto.h>
+
+/* SYSCFG register */
+#define SYSCFG_DEVICEID_OFFSET         0x6400
+#define SYSCFG_DEVICEID_DEV_ID_MASK    GENMASK(11, 0)
+#define SYSCFG_DEVICEID_DEV_ID_SHIFT   0
+
+/* 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
+#define RPN_MASK       GENMASK(31, 0)
+
+#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 get_otp(BSEC_OTP_REVID, REVID_SHIFT, REVID_MASK);
+}
+
+/* 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);
+}

-- 
2.43.0

Reply via email to