]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
board: add support for Milk-V Mars CM
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sun, 12 May 2024 04:25:23 +0000 (06:25 +0200)
committerLeo Yu-Chi Liang <ycliang@andestech.com>
Tue, 14 May 2024 10:40:10 +0000 (18:40 +0800)
We already support the VisionFive 2 and the Milk-V Mars board by
patching the VisionFive 2 device tree. With this patch the same
is done for the Milk-V Mars CM.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Tested-by: E. Shattow <lucent@gmail.com>
Reviewed-by: E. Shattow <lucent@gmail.com>
board/starfive/visionfive2/spl.c
board/starfive/visionfive2/starfive_visionfive2.c

index ca61b5be227def8c1aa003f1dcda4575e560e153..b555189556a6e2b6b27e192ee00b8731012b16d9 100644 (file)
@@ -129,6 +129,30 @@ void spl_fdt_fixup_mars(void *fdt)
        }
 }
 
+void spl_fdt_fixup_mars_cm(void *fdt)
+{
+       const char *compat;
+       const char *model;
+
+       spl_fdt_fixup_mars(fdt);
+
+       if (!get_mmc_size_from_eeprom()) {
+               int offset;
+
+               model = "Milk-V Mars CM Lite";
+               compat = "milkv,mars-cm-lite\0starfive,jh7110";
+
+               offset = fdt_path_offset(fdt, "/soc/pinctrl/mmc0-pins/mmc0-pins-rest");
+               /* GPIOMUX(22, GPOUT_SYS_SDIO0_RST, GPOEN_ENABLE, GPI_NONE) */
+               fdt_setprop_u32(fdt, offset, "pinmux", 0xff130016);
+       } else {
+               model = "Milk-V Mars CM";
+               compat = "milkv,mars-cm\0starfive,jh7110";
+       }
+       fdt_setprop(fdt, fdt_path_offset(fdt, "/"), "compatible", compat, sizeof(compat));
+       fdt_setprop_string(fdt, fdt_path_offset(fdt, "/"), "model", model);
+}
+
 void spl_fdt_fixup_version_a(void *fdt)
 {
        static const char compat[] = "starfive,visionfive-2-v1.2a\0starfive,jh7110";
@@ -236,7 +260,9 @@ void spl_perform_fixups(struct spl_image_info *spl_image)
                pr_err("Can't read EEPROM\n");
                return;
        }
-       if (!strncmp(product_id, "MARS", 4)) {
+       if (!strncmp(product_id, "MARC", 4)) {
+               spl_fdt_fixup_mars_cm(spl_image->fdt_addr);
+       } else if (!strncmp(product_id, "MARS", 4)) {
                spl_fdt_fixup_mars(spl_image->fdt_addr);
        } else if (!strncmp(product_id, "VF7110", 6)) {
                version = get_pcb_revision_from_eeprom();
index a86bca533b2ff43c8be89306b6e4953cb2c99636..6be534896260d318219648b12e64b01fda0cb474 100644 (file)
@@ -19,6 +19,10 @@ DECLARE_GLOBAL_DATA_PTR;
 #define JH7110_L2_PREFETCHER_HART_OFFSET       0x2000
 #define FDTFILE_MILK_V_MARS \
        "starfive/jh7110-milkv-mars.dtb"
+#define FDTFILE_MILK_V_MARS_CM \
+       "starfive/jh7110-milkv-mars-cm.dtb"
+#define FDTFILE_MILK_V_MARS_CM_LITE \
+       "starfive/jh7110-milkv-mars-cm-lite.dtb"
 #define FDTFILE_VISIONFIVE2_1_2A \
        "starfive/jh7110-starfive-visionfive-2-v1.2a.dtb"
 #define FDTFILE_VISIONFIVE2_1_3B \
@@ -61,7 +65,12 @@ static void set_fdtfile(void)
                log_err("Can't read EEPROM\n");
                return;
        }
-       if (!strncmp(product_id, "MARS", 4)) {
+       if (!strncmp(product_id, "MARC", 4)) {
+               if (get_mmc_size_from_eeprom())
+                       fdtfile = FDTFILE_MILK_V_MARS_CM;
+               else
+                       fdtfile = FDTFILE_MILK_V_MARS_CM_LITE;
+       } else if (!strncmp(product_id, "MARS", 4)) {
                fdtfile = FDTFILE_MILK_V_MARS;
        } else if (!strncmp(product_id, "VF7110", 6)) {
                version = get_pcb_revision_from_eeprom();