armbian-build/patch/kernel/meson64-default/stmmac_platform_mac_addr_set.patch

61 lines
1.4 KiB
Diff

--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c 2017-11-24 08:33:43.000000000 +0100
+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c 2017-12-28 19:40:51.443864071 +0100
@@ -33,6 +33,41 @@
#include "stmmac.h"
#include "stmmac_platform.h"
+#ifdef CONFIG_DWMAC_MESON
+static u8 DEFMAC[] = {0, 0, 0, 0, 0, 0};
+static unsigned int g_mac_addr_setup;
+static unsigned char chartonum(char c)
+{
+ if (c >= '0' && c <= '9')
+ return c - '0';
+ if (c >= 'A' && c <= 'F')
+ return (c - 'A') + 10;
+ if (c >= 'a' && c <= 'f')
+ return (c - 'a') + 10;
+ return 0;
+
+}
+
+static int __init mac_addr_set(char *line)
+{
+ unsigned char mac[6];
+ int i = 0;
+ for (i = 0; i < 6 && line[0] != '\0' && line[1] != '\0'; i++) {
+ mac[i] = chartonum(line[0]) << 4 | chartonum(line[1]);
+ line += 3;
+ }
+ memcpy(DEFMAC, mac, 6);
+ pr_debug("uboot setup mac-addr: %x:%x:%x:%x:%x:%x\n",
+ DEFMAC[0], DEFMAC[1], DEFMAC[2], DEFMAC[3], DEFMAC[4],
+ DEFMAC[5]);
+ g_mac_addr_setup++;
+
+ return 1;
+}
+
+__setup("mac=", mac_addr_set);
+#endif
+
#ifdef CONFIG_OF
/**
@@ -218,7 +253,15 @@
if (!plat)
return ERR_PTR(-ENOMEM);
+#ifdef CONFIG_DWMAC_MESON
+ if (g_mac_addr_setup) /*so uboot mac= is first priority.*/
+ *mac = DEFMAC;
+ else
+ *mac = of_get_mac_address(np);
+#else
*mac = of_get_mac_address(np);
+#endif
+
plat->interface = of_get_phy_mode(np);
/* Get max speed of operation from device tree */