2021-07-28 22:29:53 +00:00
|
|
|
--- a/drivers/of/of_net.c
|
|
|
|
+++ b/drivers/of/of_net.c
|
2021-07-29 06:45:24 +00:00
|
|
|
@@ -127,6 +127,33 @@ static void *of_get_mac_address_mtd(stru
|
|
|
|
return NULL;
|
2021-07-28 22:29:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
+static int of_add_mac_address(struct device_node *np, u8* addr)
|
|
|
|
+{
|
|
|
|
+ struct property *prop;
|
|
|
|
+ u8 *np_addr;
|
|
|
|
+
|
|
|
|
+ np_addr = of_get_mac_addr(np, "mac-address");
|
|
|
|
+ if (np_addr) {
|
|
|
|
+ memcpy(np_addr, addr, ETH_ALEN);
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ prop = kzalloc(sizeof(*prop), GFP_KERNEL);
|
|
|
|
+ if (!prop)
|
|
|
|
+ return 0;
|
|
|
|
+
|
|
|
|
+ prop->name = "mac-address";
|
|
|
|
+ prop->length = ETH_ALEN;
|
|
|
|
+ prop->value = kmemdup(addr, ETH_ALEN, GFP_KERNEL);
|
|
|
|
+ if (!prop->value || of_add_property(np, prop))
|
|
|
|
+ goto free;
|
|
|
|
+
|
|
|
|
+ return 0;
|
|
|
|
+free:
|
|
|
|
+ kfree(prop->value);
|
|
|
|
+ kfree(prop);
|
|
|
|
+ return -ENOMEM;
|
|
|
|
+}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Search the device tree for the best MAC address to use. 'mac-address' is
|
2021-07-29 06:45:24 +00:00
|
|
|
@@ -200,6 +227,7 @@ found:
|
2021-07-28 22:29:53 +00:00
|
|
|
if (!of_property_read_u32(np, "mac-address-increment", &mac_inc))
|
|
|
|
addr[inc_idx] += mac_inc;
|
|
|
|
|
|
|
|
+ of_add_mac_address(np, addr);
|
|
|
|
return addr;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(of_get_mac_address);
|