[openwrt/openwrt] mediatek: store MAC address in boot partition on Banana Pi R2

LEDE Commits lede-commits at lists.infradead.org
Wed Jul 8 17:22:59 EDT 2020


ynezz pushed a commit to openwrt/openwrt.git, branch master:
https://git.openwrt.org/e19ffb25d97e3859693c6d4582caf32e45265aa7

commit e19ffb25d97e3859693c6d4582caf32e45265aa7
Author: David Woodhouse <dwmw2 at infradead.org>
AuthorDate: Sun Jun 14 14:20:36 2020 +0100

    mediatek: store MAC address in boot partition on Banana Pi R2
    
    Like many boards, the Banana Pi R2 doesn't have permanant storage of
    its MAC address, and we store the first random one that the kernel
    generates in order to use it later and at least be consistent.
    
    Store it in the FAT boot partition, just as the U7623 board (and others)
    do.
    
    Signed-off-by: David Woodhouse <dwmw2 at infradead.org>
---
 .../mt7623/base-files/lib/preinit/07_set_iface_mac | 59 +++++++++++++---------
 1 file changed, 36 insertions(+), 23 deletions(-)

diff --git a/target/linux/mediatek/mt7623/base-files/lib/preinit/07_set_iface_mac b/target/linux/mediatek/mt7623/base-files/lib/preinit/07_set_iface_mac
index f64458526f..60b699d9c9 100644
--- a/target/linux/mediatek/mt7623/base-files/lib/preinit/07_set_iface_mac
+++ b/target/linux/mediatek/mt7623/base-files/lib/preinit/07_set_iface_mac
@@ -1,23 +1,19 @@
 # Copyright (C) 2018 OpenWrt.org
 
-RECOVERY_PART=/dev/mmcblk0p1
+. /lib/functions.sh
+. /lib/functions/system.sh
 
-preinit_set_mac_address() {
+set_recovery_mac_address() {
+	local RECOVERY_PART="$1"
 	local mac
 
-	. /lib/functions.sh
-	. /lib/functions/system.sh
-
-	case $(board_name) in
-	unielec,u7623-02-emmc-512m)
-		if [ -b $RECOVERY_PART ]; then
-			insmod nls_cp437
-			insmod nls_iso8859-1
-			insmod fat
-			insmod vfat
-			mkdir -p /tmp/recovery
-			mount -o rw,noatime $RECOVERY_PART /tmp/recovery
-
+	if [ -b $RECOVERY_PART ]; then
+		insmod nls_cp437
+		insmod nls_iso8859-1
+		insmod fat
+		insmod vfat
+		mkdir -p /tmp/recovery
+		if mount -o rw,noatime $RECOVERY_PART -t vfat /tmp/recovery; then
 			if [ -f "/tmp/recovery/mac_addr" ];
 			then
 				mac=$(cat /tmp/recovery/mac_addr)
@@ -28,17 +24,34 @@ preinit_set_mac_address() {
 
 			sync
 			umount /tmp/recovery
-			rm -rf /tmp/recovery
-		fi
+			rmdir /tmp/recovery
 
-		ip link set dev wan address $mac 2> /dev/null
+			ip link set dev wan address $mac 2> /dev/null
 
-		mac=$(macaddr_add $mac 1)
+			mac=$(macaddr_add $mac 1)
 
-		ip link set dev lan0 address $mac 2>/dev/null
-		ip link set dev lan1 address $mac 2>/dev/null
-		ip link set dev lan2 address $mac 2>/dev/null
-		ip link set dev lan3 address $mac 2>/dev/null
+			ip link set dev lan0 address $mac 2>/dev/null
+			ip link set dev lan1 address $mac 2>/dev/null
+			ip link set dev lan2 address $mac 2>/dev/null
+			ip link set dev lan3 address $mac 2>/dev/null
+		fi
+	fi
+}
+
+preinit_set_mac_address() {
+	local rootpart
+
+	case $(board_name) in
+	bananapi,bpi-r2)
+		rootpart=$(cat /proc/cmdline)
+		rootpart="${rootpart##*root=}"
+		rootpart="${rootpart%%p3 *}"
+		if [ "$rootpart" = "/dev/mmcblk0" -o "$rootpart" = "/dev/mmcblk1" ]; then
+			set_recovery_mac_address ${rootpart}p2
+		fi
+		;;
+	unielec,u7623-02-emmc-512m)
+		set_recovery_mac_address /dev/mmcblk0p1
 		;;
 	esac
 }



More information about the lede-commits mailing list