]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
soc: renesas: rz-sysc: Move RZ/V2H SoC detection to the SYS driver
authorJohn Madieu <john.madieu.xa@bp.renesas.com>
Tue, 28 Jan 2025 03:13:41 +0000 (04:13 +0100)
committerGeert Uytterhoeven <geert+renesas@glider.be>
Thu, 20 Feb 2025 16:38:33 +0000 (17:38 +0100)
As per the other SoC variant of the same family, the system controller
provides SoC ID in its own registers.

Signed-off-by: John Madieu <john.madieu.xa@bp.renesas.com>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://lore.kernel.org/20250128031342.52675-5-john.madieu.xa@bp.renesas.com
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
drivers/soc/renesas/Kconfig
drivers/soc/renesas/Makefile
drivers/soc/renesas/r9a09g057-sys.c [new file with mode: 0644]
drivers/soc/renesas/renesas-soc.c
drivers/soc/renesas/rz-sysc.c
drivers/soc/renesas/rz-sysc.h

index d3ba74b5fa1110f889ec68ac81b187571b4fea20..49648cf28bd230763fcd4bcb1b7e480c37a25df0 100644 (file)
@@ -355,6 +355,7 @@ config ARCH_R9A09G047
 config ARCH_R9A09G057
        bool "ARM64 Platform support for RZ/V2H(P)"
        select RENESAS_RZV2H_ICU
+       select SYS_R9A09G057
        help
          This enables support for the Renesas RZ/V2H(P) SoC variants.
 
@@ -396,4 +397,8 @@ config SYS_R9A09G047
        bool "Renesas RZ/G3E System controller support" if COMPILE_TEST
        select SYSC_RZ
 
+config SYS_R9A09G057
+       bool "Renesas RZ/V2H System controller support" if COMPILE_TEST
+       select SYSC_RZ
+
 endif # SOC_RENESAS
index 17b86d3ae47881d48e0d54c20c016f2ab37d94a0..81d4c5726e4c8ac150d55d5411193cf861a5861c 100644 (file)
@@ -8,6 +8,7 @@ obj-$(CONFIG_ARCH_R9A06G032)    += r9a06g032-smp.o
 endif
 obj-$(CONFIG_SYSC_R9A08G045)   += r9a08g045-sysc.o
 obj-$(CONFIG_SYS_R9A09G047)    += r9a09g047-sys.o
+obj-$(CONFIG_SYS_R9A09G057)    += r9a09g057-sys.o
 
 # Family
 obj-$(CONFIG_PWC_RZV2M)                += pwc-rzv2m.o
diff --git a/drivers/soc/renesas/r9a09g057-sys.c b/drivers/soc/renesas/r9a09g057-sys.c
new file mode 100644 (file)
index 0000000..49a92de
--- /dev/null
@@ -0,0 +1,25 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * RZ/V2H System controller (SYS) driver
+ *
+ * Copyright (C) 2025 Renesas Electronics Corp.
+ */
+
+#include <linux/bits.h>
+#include <linux/device.h>
+#include <linux/init.h>
+#include <linux/io.h>
+
+#include "rz-sysc.h"
+
+static const struct rz_sysc_soc_id_init_data rzv2h_sys_soc_id_init_data __initconst = {
+       .family = "RZ/V2H",
+       .id = 0x847a447,
+       .devid_offset = 0x304,
+       .revision_mask = GENMASK(31, 28),
+       .specific_id_mask = GENMASK(27, 0),
+};
+
+const struct rz_sysc_init_data rzv2h_sys_init_data = {
+       .soc_id_init_data = &rzv2h_sys_soc_id_init_data,
+};
index 425d9037dcd08e7623570c883d85661931a88f0e..df2b38417b8042fc7ac425981552cc204fdaa851 100644 (file)
@@ -71,10 +71,6 @@ static const struct renesas_family fam_rzg2ul __initconst __maybe_unused = {
        .name   = "RZ/G2UL",
 };
 
-static const struct renesas_family fam_rzv2h __initconst __maybe_unused = {
-       .name   = "RZ/V2H",
-};
-
 static const struct renesas_family fam_rzv2l __initconst __maybe_unused = {
        .name   = "RZ/V2L",
 };
@@ -172,11 +168,6 @@ static const struct renesas_soc soc_rz_g2ul __initconst __maybe_unused = {
        .id     = 0x8450447,
 };
 
-static const struct renesas_soc soc_rz_v2h __initconst __maybe_unused = {
-       .family = &fam_rzv2h,
-       .id     = 0x847a447,
-};
-
 static const struct renesas_soc soc_rz_v2l __initconst __maybe_unused = {
        .family = &fam_rzv2l,
        .id     = 0x8447447,
@@ -280,7 +271,6 @@ static const struct renesas_soc soc_shmobile_ag5 __initconst __maybe_unused = {
        .id     = 0x37,
 };
 
-
 static const struct of_device_id renesas_socs[] __initconst __maybe_unused = {
 #ifdef CONFIG_ARCH_R7S72100
        { .compatible = "renesas,r7s72100",     .data = &soc_rz_a1h },
@@ -404,9 +394,6 @@ static const struct of_device_id renesas_socs[] __initconst __maybe_unused = {
 #ifdef CONFIG_ARCH_R9A09G011
        { .compatible = "renesas,r9a09g011",    .data = &soc_rz_v2m },
 #endif
-#ifdef CONFIG_ARCH_R9A09G057
-       { .compatible = "renesas,r9a09g057",    .data = &soc_rz_v2h },
-#endif
 #ifdef CONFIG_ARCH_SH73A0
        { .compatible = "renesas,sh73a0",       .data = &soc_shmobile_ag5 },
 #endif
@@ -432,11 +419,6 @@ static const struct renesas_id id_rzg2l __initconst = {
        .mask = 0xfffffff,
 };
 
-static const struct renesas_id id_rzv2h __initconst = {
-       .offset = 0x304,
-       .mask = 0xfffffff,
-};
-
 static const struct renesas_id id_rzv2m __initconst = {
        .offset = 0x104,
        .mask = 0xff,
@@ -454,7 +436,6 @@ static const struct of_device_id renesas_ids[] __initconst = {
        { .compatible = "renesas,r9a07g054-sysc",       .data = &id_rzg2l },
        { .compatible = "renesas,r9a08g045-sysc",       .data = &id_rzg2l },
        { .compatible = "renesas,r9a09g011-sys",        .data = &id_rzv2m },
-       { .compatible = "renesas,r9a09g057-sys",        .data = &id_rzv2h },
        { .compatible = "renesas,prr",                  .data = &id_prr },
        { /* sentinel */ }
 };
@@ -519,7 +500,7 @@ static int __init renesas_soc_init(void)
                        eslo = product & 0xf;
                        soc_dev_attr->revision = kasprintf(GFP_KERNEL, "ES%u.%u",
                                                           eshi, eslo);
-               }  else if (id == &id_rzg2l || id == &id_rzv2h) {
+               }  else if (id == &id_rzg2l) {
                        eshi =  ((product >> 28) & 0x0f);
                        soc_dev_attr->revision = kasprintf(GFP_KERNEL, "%u",
                                                           eshi);
index 70a0f193163334b0efdf68cb8c1a232a67a635fe..14db508f669ff918dfc6bfc11d77fe93c570de3f 100644 (file)
@@ -87,6 +87,9 @@ static const struct of_device_id rz_sysc_match[] = {
 #endif
 #ifdef CONFIG_SYS_R9A09G047
        { .compatible = "renesas,r9a09g047-sys", .data = &rzg3e_sys_init_data },
+#endif
+#ifdef CONFIG_SYS_R9A09G057
+       { .compatible = "renesas,r9a09g057-sys", .data = &rzv2h_sys_init_data },
 #endif
        { }
 };
index 4e70b77433a3eb30ec5726656c584fd5e4260367..aa83948c511725edecb0ed59dedfcc29d62c453d 100644 (file)
@@ -41,5 +41,6 @@ struct rz_sysc_init_data {
 
 extern const struct rz_sysc_init_data rzg3e_sys_init_data;
 extern const struct rz_sysc_init_data rzg3s_sysc_init_data;
+extern const struct rz_sysc_init_data rzv2h_sys_init_data;
 
 #endif /* __SOC_RENESAS_RZ_SYSC_H__ */