[rdc] fix the handling of MAC addresses with r6040, patch from rtz
authorflorian <florian@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sun, 6 Dec 2009 09:07:53 +0000 (09:07 +0000)
committerflorian <florian@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sun, 6 Dec 2009 09:07:53 +0000 (09:07 +0000)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@18669 3c298f89-4303-0410-b956-a3cf2f4a3e73

target/linux/rdc/base-files/etc/preinit.arch

index 8f21b1f..fd456f8 100644 (file)
@@ -1,8 +1,23 @@
-# Copyright (C) 2008 OpenWrt.org
+# Copyright (C) 2009 OpenWrt.org
 
-ash -c ". /etc/functions.sh
-hdr=\$(find_mtd_part productinfo)
-[ \$(find_mtd_part productinfo_parthdr) ] || rev=reverse
-[ \"\$hdr\" ] && mac=\$(hexdump -n 6 -e '6/1 \",0x%X\"' \$hdr |cut -c2-)
-[ \"\$mac\" = \"0x0,0x0,0x0,0x0,0x0,0x0\" ] && unset mac
-[ \"\$mac\" ] && insmod r6040 \$rev mac_base=\$mac"
+. /etc/functions.sh
+
+insmod r6040
+
+kernel=$(grep magic /proc/mtd | awk -F: '{print $1}')
+[ -n $kernel ] && hdr=$(dd if=/dev/$kernel count=4 bs=1 2> /dev/null)
+[ "$hdr" = "CSYS" ] && config=$(find_mtd_part config)
+if [ -n "$config" ]; then
+       mac0=$(hexdump -n 6 -e '6/1 ":%X"' -s 24583 $config | cut -c2-)
+       [ "$mac0" = "FF:FF:FF:FF:FF:FF" -o "$mac0" = "0:0:0:0:0:0" ] && unset mac0
+       mac1=$(hexdump -n 6 -e '6/1 ":%X"' -s 24589 $config | cut -c2-)
+       [ "$mac1" = "FF:FF:FF:FF:FF:FF" -o "$mac0" = "0:0:0:0:0:0" ] && unset mac1
+fi
+if [ -n $mac0 ]; then
+       logger -t kernel -p user.info "r6040: Setting MAC for eth0 to $mac0"
+       ifconfig eth0 hw ether $mac0
+fi
+if [ -n $mac1 ]; then
+       logger -t kernel -p user.info "r6040: Setting MAC for eth1 to $mac1"
+       ifconfig eth1 hw ether $mac1
+fi
This page took 0.024588 seconds and 4 git commands to generate.