mirror of
https://git.openwrt.org/openwrt/openwrt.git
synced 2024-11-28 07:44:32 +00:00
293caa16a0
Refresh pending patches with make target/linux/refresh. Signed-off-by: Weijie Gao <hackpascal@gmail.com>
76 lines
1.9 KiB
Diff
76 lines
1.9 KiB
Diff
From 8585756342caa6d27008d1ad0c18023e4211a40a Mon Sep 17 00:00:00 2001
|
|
From: OpenWrt community <openwrt-devel@lists.openwrt.org>
|
|
Date: Wed, 13 Jul 2022 12:22:48 +0200
|
|
Subject: [PATCH] of/of_net: write back netdev MAC-address to device-tree
|
|
|
|
The label-mac logic relies on the mac-address property of a netdev
|
|
devices of-node. However, the mac address can also be stored as a
|
|
different property or read from e.g. an mtd device.
|
|
|
|
Create this node when reading a mac-address from OF if it does not
|
|
already exist and copy the mac-address used for the device to this
|
|
property. This way, the MAC address can be accessed using procfs.
|
|
|
|
---
|
|
net/core/of_net.c | 22 ++++++++++++++++++++++
|
|
1 file changed, 22 insertions(+)
|
|
|
|
--- a/net/core/of_net.c
|
|
+++ b/net/core/of_net.c
|
|
@@ -97,6 +97,27 @@ int of_get_mac_address_nvmem(struct devi
|
|
}
|
|
EXPORT_SYMBOL(of_get_mac_address_nvmem);
|
|
|
|
+static int of_add_mac_address(struct device_node *np, u8* addr)
|
|
+{
|
|
+ struct property *prop;
|
|
+
|
|
+ prop = kzalloc(sizeof(*prop), GFP_KERNEL);
|
|
+ if (!prop)
|
|
+ return -ENOMEM;
|
|
+
|
|
+ prop->name = "mac-address";
|
|
+ prop->length = ETH_ALEN;
|
|
+ prop->value = kmemdup(addr, ETH_ALEN, GFP_KERNEL);
|
|
+ if (!prop->value || of_update_property(np, prop))
|
|
+ goto free;
|
|
+
|
|
+ return 0;
|
|
+free:
|
|
+ kfree(prop->value);
|
|
+ kfree(prop);
|
|
+ return -ENOMEM;
|
|
+}
|
|
+
|
|
/**
|
|
* of_get_mac_address()
|
|
* @np: Caller's Device Node
|
|
@@ -132,17 +153,23 @@ int of_get_mac_address(struct device_nod
|
|
|
|
ret = of_get_mac_addr(np, "mac-address", addr);
|
|
if (!ret)
|
|
- return 0;
|
|
+ goto found;
|
|
|
|
ret = of_get_mac_addr(np, "local-mac-address", addr);
|
|
if (!ret)
|
|
- return 0;
|
|
+ goto found;
|
|
|
|
ret = of_get_mac_addr(np, "address", addr);
|
|
if (!ret)
|
|
- return 0;
|
|
+ goto found;
|
|
|
|
- return of_get_mac_address_nvmem(np, addr);
|
|
+ ret = of_get_mac_address_nvmem(np, addr);
|
|
+ if (ret)
|
|
+ return ret;
|
|
+
|
|
+found:
|
|
+ ret = of_add_mac_address(np, addr);
|
|
+ return ret;
|
|
}
|
|
EXPORT_SYMBOL(of_get_mac_address);
|
|
|