[PATCH v2 v2 8/8] spacemit: k1: load product name from environment variable

Peng Fan peng.fan at oss.nxp.com
Tue Jun 30 04:55:12 CEST 2026


On Mon, Jun 29, 2026 at 11:51:22PM +0800, Eric Chung wrote:
>Read the product name from the environment instead of EEPROM,
>as the EEPROM may not be programmed and the environment always
>contains this information.
>
>Signed-off-by: Eric Chung <eric.chung at riscstar.com>
>---
> board/spacemit/k1/spl.c | 50 ++++++++++---------------------------------------
> 1 file changed, 10 insertions(+), 40 deletions(-)
>
>diff --git a/board/spacemit/k1/spl.c b/board/spacemit/k1/spl.c
>index 0db362130e4..4f8b2f1035d 100644
>--- a/board/spacemit/k1/spl.c
>+++ b/board/spacemit/k1/spl.c
>@@ -12,6 +12,7 @@
> #include <configs/k1.h>
> #include <dm/device.h>
> #include <dm/uclass.h>
>+#include <env.h>
> #include <i2c.h>
> #include <linux/delay.h>
> #include <log.h>
>@@ -73,39 +74,6 @@ static void i2c_early_init(void)
> 	}
> }
> 
>-int read_product_name(char *name, int size)
>-{
>-	u8 eeprom_data[TLV_TOTAL_LEN_MAX], *p;
>-	struct tlvinfo_header *tlv_hdr;
>-	struct tlvinfo_tlv *tlv_entry;
>-	int ret, i = 0;
>-	u32 entry_size;
>-
>-	if (!name || size <= 0)
>-		return -EINVAL;
>-	ret = read_tlvinfo_tlv_eeprom(eeprom_data, &tlv_hdr,
>-				      &tlv_entry, i);
>-	if (ret)
>-		return ret;
>-	p = (u8 *)tlv_entry;
>-	for (i = 0; i < tlv_hdr->totallen; ) {
>-		if (tlv_entry->type == TLV_CODE_PRODUCT_NAME) {
>-			if (tlv_entry->length < size)
>-				size = tlv_entry->length;
>-			memset(name, 0, size);
>-			memcpy(name, &tlv_entry->value[0], size);
>-			return 0;
>-		}
>-		if (tlv_entry->type == TLV_CODE_CRC_32)
>-			return -ENOENT;
>-		entry_size = tlv_entry->length + sizeof(struct tlvinfo_tlv);
>-		i += entry_size;
>-		p += entry_size;
>-		tlv_entry = (struct tlvinfo_tlv *)p;
>-	}
>-	return -ENOENT;
>-}
>-
> static const struct {
> 	const char *eeprom_name;
> 	const char *fit_name;
>@@ -117,9 +85,14 @@ static const struct {
> 
> static void fixup_product_name(void)
> {
>-	char fdt_name[I2C_BUF_SIZE];
>+	char fdt_name[I2C_BUF_SIZE], *name;
> 	int i;
> 
>+	memset(product_name, 0, I2C_BUF_SIZE);
>+	env_init();
>+	env_load();
>+	name = env_get("product_name");

Need a NULL pointer check.

>+	snprintf(product_name, I2C_BUF_SIZE, "%s", name);
> 	memset(fdt_name, 0, I2C_BUF_SIZE);


More information about the U-Boot mailing list