[source] oxnas: add method to extract mac_adr from legacy cmdline

LEDE Commits lede-commits at lists.infradead.org
Sat Sep 3 22:57:51 PDT 2016


dangole pushed a commit to source.git, branch master:
https://git.lede-project.org/9c69ba83e2d0c19959fed81cf4fa038fde3e518d

commit 9c69ba83e2d0c19959fed81cf4fa038fde3e518d
Author: Daniel Golle <daniel at makrotopia.org>
AuthorDate: Sun Sep 4 03:34:19 2016 +0200

    oxnas: add method to extract mac_adr from legacy cmdline
    
    Signed-off-by: Daniel Golle <daniel at makrotopia.org>
---
 .../linux/oxnas/base-files/etc/board.d/02_network  | 10 +++++++++
 target/linux/oxnas/base-files/lib/oxnas.sh         | 24 ++++++++++++++++++++++
 2 files changed, 34 insertions(+)

diff --git a/target/linux/oxnas/base-files/etc/board.d/02_network b/target/linux/oxnas/base-files/etc/board.d/02_network
index a025027..d4010e8 100755
--- a/target/linux/oxnas/base-files/etc/board.d/02_network
+++ b/target/linux/oxnas/base-files/etc/board.d/02_network
@@ -2,10 +2,20 @@
 
 . /lib/functions/uci-defaults.sh
 . /lib/functions/system.sh
+. /lib/oxnas.sh
 
 board_config_update
 
+lan_mac=""
+
+case "$(oxnas_board_name)" in
+	kd20)
+		lan_mac="$(legacy_boot_mac_adr)"
+		;;
+esac
+
 ucidef_set_interface_lan "eth0" "dhcp"
+[ -n "$lan_mac" ] && ucidef_set_interface_macaddr lan "$lan_mac"
 
 board_config_flush
 
diff --git a/target/linux/oxnas/base-files/lib/oxnas.sh b/target/linux/oxnas/base-files/lib/oxnas.sh
index 991f927..b0d79ea 100755
--- a/target/linux/oxnas/base-files/lib/oxnas.sh
+++ b/target/linux/oxnas/base-files/lib/oxnas.sh
@@ -6,6 +6,30 @@
 OXNAS_BOARD_NAME=
 OXNAS_MODEL=
 
+bootloader_cmdline_var() {
+	local param
+	local pval
+	for arg in $(cat /proc/device-tree/chosen/bootloader-args); do
+		param="$(echo $arg | cut -d'=' -f 1)"
+		pval="$(echo $arg | cut -d'=' -f 2-)"
+
+		if [ "$param" = "$1" ]; then
+			echo "$pval"
+		fi
+	done
+}
+
+legacy_boot_mac_adr() {
+	local macstr
+	local oIFS
+	macstr="$(bootloader_cmdline_var mac_adr)"
+	oIFS="$IFS"
+	IFS=","
+	set -- $macstr
+	printf "%02x:%02x:%02x:%02x:%02x:%02x" $1 $2 $3 $4 $5 $6
+	IFS="$oIFS"
+}
+
 oxnas_board_detect() {
 	local machine
 	local name



More information about the lede-commits mailing list