]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
riscv: set fdtfile on Milk-V Mars
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Tue, 2 Apr 2024 08:49:09 +0000 (10:49 +0200)
committerLeo Yu-Chi Liang <ycliang@andestech.com>
Tue, 9 Apr 2024 03:30:37 +0000 (11:30 +0800)
Set environment variable fdtfile to the correct value for the Milk-V Mars
board.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Leo Yu-Chi Liang <ycliang@andestech.com>
board/starfive/visionfive2/starfive_visionfive2.c

index 76439179fa74729f2780f49d0f5a5d90fffa2b21..5ae8b850280374c4b08d9bfaf65cc9dbf0d7014d 100644 (file)
@@ -9,6 +9,7 @@
 #include <dm.h>
 #include <fdt_support.h>
 #include <env.h>
+#include <log.h>
 #include <asm/arch/eeprom.h>
 #include <asm/io.h>
 #include <asm/sections.h>
@@ -17,6 +18,8 @@
 DECLARE_GLOBAL_DATA_PTR;
 #define JH7110_L2_PREFETCHER_BASE_ADDR         0x2030000
 #define JH7110_L2_PREFETCHER_HART_OFFSET       0x2000
+#define FDTFILE_MILK_V_MARS \
+       "starfive/jh7110-milkv-mars.dtb"
 #define FDTFILE_VISIONFIVE2_1_2A \
        "starfive/jh7110-starfive-visionfive-2-v1.2a.dtb"
 #define FDTFILE_VISIONFIVE2_1_3B \
@@ -48,24 +51,38 @@ static void set_fdtfile(void)
 {
        u8 version;
        const char *fdtfile;
+       const char *product_id;
 
        fdtfile = env_get("fdtfile");
        if (fdtfile)
                return;
 
-       version = get_pcb_revision_from_eeprom();
-       switch (version) {
-       case 'a':
-       case 'A':
-               fdtfile = FDTFILE_VISIONFIVE2_1_2A;
-               break;
-
-       case 'b':
-       case 'B':
-       default:
-               fdtfile = FDTFILE_VISIONFIVE2_1_3B;
-               break;
-       };
+       product_id = get_product_id_from_eeprom();
+       if (!product_id) {
+               log_err("Can't read EEPROM\n");
+               return;
+       }
+       if (!strncmp(product_id, "MARS", 4)) {
+               fdtfile = FDTFILE_MILK_V_MARS;
+       } else if (!strncmp(product_id, "VF7110", 6)) {
+               version = get_pcb_revision_from_eeprom();
+
+               switch (version) {
+               case 'a':
+               case 'A':
+                       fdtfile = FDTFILE_VISIONFIVE2_1_2A;
+                       break;
+
+               case 'b':
+               case 'B':
+               default:
+                       fdtfile = FDTFILE_VISIONFIVE2_1_3B;
+                       break;
+               }
+       } else {
+               log_err("Unknown product\n");
+               return;
+       }
 
        env_set("fdtfile", fdtfile);
 }