On 29.08.25 08:09, Hal Feng wrote:
Add eeprom data format v3 support.
Add wifi_bt field in ATOM4 and add "mac wifi_bt <?>" command to modify it.
Set or show eth0/1 MAC address only if the board has eth0/1.

Signed-off-by: Hal Feng <hal.f...@starfivetech.com>
---
  .../visionfive2/visionfive2-i2c-eeprom.c      | 91 ++++++++++++++++---
  1 file changed, 78 insertions(+), 13 deletions(-)

diff --git a/board/starfive/visionfive2/visionfive2-i2c-eeprom.c 
b/board/starfive/visionfive2/visionfive2-i2c-eeprom.c
index 43b8af4fc59..7352252c475 100644
--- a/board/starfive/visionfive2/visionfive2-i2c-eeprom.c
+++ b/board/starfive/visionfive2/visionfive2-i2c-eeprom.c
@@ -11,7 +11,7 @@
  #include <u-boot/crc.h>
  #include <linux/delay.h>
-#define FORMAT_VERSION 0x2
+#define FORMAT_VERSION         0x3
  #define PCB_VERSION           0xB1
  #define BOM_VERSION           'A'
  /*
@@ -105,7 +105,8 @@ struct eeprom_atom4_data {
        u8 bom_revision;                /* BOM version */
        u8 mac0_addr[MAC_ADDR_BYTES];   /* Ethernet0 MAC */
        u8 mac1_addr[MAC_ADDR_BYTES];   /* Ethernet1 MAC */
-       u8 reserved[2];
+       u8 wifi_bt;                     /* WIFI/BT support flag */
+       u8 reserved;
  };
struct starfive_eeprom_atom4 {
@@ -128,6 +129,35 @@ static union {
  /* Set to 1 if we've read EEPROM into memory */
  static int has_been_read __section(".data");
+static const char * const board_no_eth0_list[] = {
+       "FML13V01",
+};
+
+static const char * const board_no_eth1_list[] = {
+       "FML13V01",
+       "MARS",
+       "VF7110SL",
+};

Do you know in which category the Milk-V Mars CM ("MARC") falls?

Best regards

Heinrich

+
+static bool board_have_eth(u8 eth)
+{
+       int i;
+
+       if (eth == 0) {
+               for (i = 0 ; i < ARRAY_SIZE(board_no_eth0_list); i++)
+                       if (!strncmp(pbuf.eeprom.atom1.data.pstr, 
board_no_eth0_list[i],
+                                    strlen(board_no_eth0_list[i])))
+                               return false;
+       } else {
+               for (i = 0 ; i < ARRAY_SIZE(board_no_eth1_list); i++)
+                       if (!strncmp(pbuf.eeprom.atom1.data.pstr, 
board_no_eth1_list[i],
+                                    strlen(board_no_eth1_list[i])))
+                               return false;
+       }
+
+       return true;
+}
+
  static inline int is_match_magic(void)
  {
        return strncmp(pbuf.eeprom.header.signature, STARFIVE_EEPROM_HATS_SIG,
@@ -176,17 +206,22 @@ static void show_eeprom(void)
        printf("Vendor : %s\n", pbuf.eeprom.atom1.data.vstr);
        printf("Product full SN: %s\n", pbuf.eeprom.atom1.data.pstr);
        printf("data version: 0x%x\n", pbuf.eeprom.atom4.data.version);
-       if (pbuf.eeprom.atom4.data.version == 2) {
+       if (pbuf.eeprom.atom4.data.version >= 2 && pbuf.eeprom.atom4.data.version 
<= 3) {
                printf("PCB revision: 0x%x\n", 
pbuf.eeprom.atom4.data.pcb_revision);
                printf("BOM revision: %c\n", 
pbuf.eeprom.atom4.data.bom_revision);
-               printf("Ethernet MAC0 address: %02x:%02x:%02x:%02x:%02x:%02x\n",
-                      pbuf.eeprom.atom4.data.mac0_addr[0], 
pbuf.eeprom.atom4.data.mac0_addr[1],
-                      pbuf.eeprom.atom4.data.mac0_addr[2], 
pbuf.eeprom.atom4.data.mac0_addr[3],
-                      pbuf.eeprom.atom4.data.mac0_addr[4], 
pbuf.eeprom.atom4.data.mac0_addr[5]);
-               printf("Ethernet MAC1 address: %02x:%02x:%02x:%02x:%02x:%02x\n",
-                      pbuf.eeprom.atom4.data.mac1_addr[0], 
pbuf.eeprom.atom4.data.mac1_addr[1],
-                      pbuf.eeprom.atom4.data.mac1_addr[2], 
pbuf.eeprom.atom4.data.mac1_addr[3],
-                      pbuf.eeprom.atom4.data.mac1_addr[4], 
pbuf.eeprom.atom4.data.mac1_addr[5]);
+               if (board_have_eth(0))
+                       printf("Ethernet MAC0 address: 
%02x:%02x:%02x:%02x:%02x:%02x\n",
+                       pbuf.eeprom.atom4.data.mac0_addr[0], 
pbuf.eeprom.atom4.data.mac0_addr[1],
+                       pbuf.eeprom.atom4.data.mac0_addr[2], 
pbuf.eeprom.atom4.data.mac0_addr[3],
+                       pbuf.eeprom.atom4.data.mac0_addr[4], 
pbuf.eeprom.atom4.data.mac0_addr[5]);
+
+               if (board_have_eth(1))
+                       printf("Ethernet MAC1 address: 
%02x:%02x:%02x:%02x:%02x:%02x\n",
+                       pbuf.eeprom.atom4.data.mac1_addr[0], 
pbuf.eeprom.atom4.data.mac1_addr[1],
+                       pbuf.eeprom.atom4.data.mac1_addr[2], 
pbuf.eeprom.atom4.data.mac1_addr[3],
+                       pbuf.eeprom.atom4.data.mac1_addr[4], 
pbuf.eeprom.atom4.data.mac1_addr[5]);
+               if (pbuf.eeprom.atom4.data.version >= 3)
+                       printf("WIFI/BT support: %x\n", 
pbuf.eeprom.atom4.data.wifi_bt);
        } else {
                printf("Custom data v%d is not Supported\n", 
pbuf.eeprom.atom4.data.version);
                dump_raw_eeprom();
@@ -260,6 +295,7 @@ static void init_local_copy(void)
        pbuf.eeprom.atom4.data.bom_revision = BOM_VERSION;
        set_mac_address(STARFIVE_DEFAULT_MAC0, 0);
        set_mac_address(STARFIVE_DEFAULT_MAC1, 1);
+       pbuf.eeprom.atom4.data.wifi_bt = 0;
  }
/**
@@ -385,6 +421,28 @@ static void set_bom_revision(char *string)
        update_crc();
  }
+/**
+ * set_wifi_bt() - stores a StarFive WIFI/BT support flag into the local 
EEPROM copy
+ *
+ * Takes a pointer to a string representing the numeric WIFI/BT support flag in
+ * decimal ("0" or "1"), stores it in the wifi_bt field of the
+ * EEPROM local copy, and updates the CRC of the local copy.
+ */
+static void set_wifi_bt(char *string)
+{
+       u8 wifi_bt;
+
+       wifi_bt = simple_strtoul(string, &string, 16);
+       if (wifi_bt > 1) {
+               printf("WIFI/BT support flag must not be greater than 1");
+               return;
+       }
+
+       pbuf.eeprom.atom4.data.wifi_bt = wifi_bt;
+
+       update_crc();
+}
+
  /**
   * set_product_id() - stores a StarFive product ID into the local EEPROM copy
   *
@@ -478,6 +536,9 @@ int do_mac(struct cmd_tbl *cmdtp, int flag, int argc, char 
*const argv[])
        } else if (!strcmp(cmd, "bom_revision")) {
                set_bom_revision(argv[2]);
                return 0;
+       } else if (!strcmp(cmd, "wifi_bt")) {
+               set_wifi_bt(argv[2]);
+               return 0;
        } else if (!strcmp(cmd, "product_id")) {
                set_product_id(argv[2]);
                return 0;
@@ -513,8 +574,10 @@ int mac_read_from_eeprom(void)
        }
// 1, setup ethaddr env
-       eth_env_set_enetaddr("ethaddr", pbuf.eeprom.atom4.data.mac0_addr);
-       eth_env_set_enetaddr("eth1addr", pbuf.eeprom.atom4.data.mac1_addr);
+       if (board_have_eth(0))
+               eth_env_set_enetaddr("ethaddr", 
pbuf.eeprom.atom4.data.mac0_addr);
+       if (board_have_eth(1))
+               eth_env_set_enetaddr("eth1addr", 
pbuf.eeprom.atom4.data.mac1_addr);
/**
         * 2, setup serial# env, reference to hifive-platform-i2c-eeprom.c,
@@ -585,6 +648,8 @@ U_BOOT_LONGHELP(mac,
        "    - stores a StarFive PCB revision into the local EEPROM copy\n"
        "mac bom_revision <A>\n"
        "    - stores a StarFive BOM revision into the local EEPROM copy\n"
+       "mac wifi_bt <?>\n"
+       "    - stores a StarFive WIFI/BT support flag into the local EEPROM 
copy\n"
        "mac product_id <VF7110A1-2228-D008E000-xxxxxxxx>\n"
        "    - stores a StarFive product ID into the local EEPROM copy\n"
        "mac vendor <Vendor Name>\n"

Reply via email to