From 1622ff3442ff6aecc1f538cda437379d1f6a4a93 Mon Sep 17 00:00:00 2001
From: hc <hc@nodka.com>
Date: Mon, 06 Nov 2023 07:25:52 +0000
Subject: [PATCH] rk3568 dts

---
 kernel/drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c |   23 +++++++++++++++++++++--
 1 files changed, 21 insertions(+), 2 deletions(-)

diff --git a/kernel/drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c b/kernel/drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c
index d945d92..0d967a3 100644
--- a/kernel/drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c
+++ b/kernel/drivers/net/ethernet/stmicro/stmmac/dwmac-rk.c
@@ -2346,13 +2346,16 @@
 {
 }
 
+
+static unsigned char macaddr[6];
+extern ssize_t at24_mac_read(unsigned char* addr);
 void rk_get_eth_addr(void *priv, unsigned char *addr)
 {
 	struct rk_priv_data *bsp_priv = priv;
 	struct device *dev = &bsp_priv->pdev->dev;
 	unsigned char ethaddr[ETH_ALEN * MAX_ETH] = {0};
-	int ret, id = bsp_priv->bus_id;
-
+	int ret,i, id = bsp_priv->bus_id;
+#if 0
 	rk_devinfo_get_eth_mac(addr);
 	if (is_valid_ether_addr(addr))
 		goto out;
@@ -2383,6 +2386,22 @@
 	} else {
 		memcpy(addr, &ethaddr[id * ETH_ALEN], ETH_ALEN);
 	}
+#endif
+     #if 1
+        if (at24_mac_read(macaddr) > 0) {
+                printk("ben %s: at24_mac_read Success!! \n", __func__);
+                memcpy(addr, macaddr, 6);
+
+                printk("Read the Ethernet MAC address from :");
+                for (i = 0; i < 5; i++)
+                        printk("%2.2x:", addr[i]);
+
+                printk("%2.2x\n", addr[i]);
+        } else {
+                printk("ben %s: at24_mac_read Failed!! \n", __func__);
+                goto out;
+        }
+        #endif
 
 out:
 	dev_err(dev, "%s: mac address: %pM\n", __func__, addr);

--
Gitblit v1.6.2