diff options
Diffstat (limited to 'target/linux/rdc/base-files')
-rw-r--r-- | target/linux/rdc/base-files/etc/config/network | 18 | ||||
-rw-r--r-- | target/linux/rdc/base-files/etc/diag.sh | 19 | ||||
-rw-r--r-- | target/linux/rdc/base-files/lib/preinit/05_set_ether_mac_rdc | 36 | ||||
-rw-r--r-- | target/linux/rdc/base-files/lib/upgrade/platform.sh | 10 |
4 files changed, 83 insertions, 0 deletions
diff --git a/target/linux/rdc/base-files/etc/config/network b/target/linux/rdc/base-files/etc/config/network new file mode 100644 index 000000000..44c57940e --- /dev/null +++ b/target/linux/rdc/base-files/etc/config/network @@ -0,0 +1,18 @@ +# Copyright (C) 2009 OpenWrt.org + +config interface loopback + option ifname lo + option proto static + option ipaddr 127.0.0.1 + option netmask 255.0.0.0 + +config interface lan + option ifname eth1 + option type bridge + option proto static + option ipaddr 192.168.1.1 + option netmask 255.255.255.0 + +config interface wan + option ifname eth0 + option proto dhcp diff --git a/target/linux/rdc/base-files/etc/diag.sh b/target/linux/rdc/base-files/etc/diag.sh new file mode 100644 index 000000000..8d5c38262 --- /dev/null +++ b/target/linux/rdc/base-files/etc/diag.sh @@ -0,0 +1,19 @@ +#!/bin/sh +# Copyright (C) 2007 OpenWrt.org + +set_led() { + local led="$1" + local state="$2" + [ -d "/sys/class/leds/rdc321x:$led" ] && echo "$state" > "/sys/class/leds/rdc321x:$led/brightness" +} + +set_state() { + case "$1" in + preinit) + set_led dmz 1 + ;; + done) + set_led dmz 0 + ;; + esac +} diff --git a/target/linux/rdc/base-files/lib/preinit/05_set_ether_mac_rdc b/target/linux/rdc/base-files/lib/preinit/05_set_ether_mac_rdc new file mode 100644 index 000000000..4640e008f --- /dev/null +++ b/target/linux/rdc/base-files/lib/preinit/05_set_ether_mac_rdc @@ -0,0 +1,36 @@ +#!/bin/sh +# Copyright (C) 2009-2012 OpenWrt.org + +. /lib/functions/boot.sh + +r6040_module() { + insmod libphy + insmod swconfig + insmod ip17xx + sleep 1 + insmod r6040 +} + +set_ether_mac() { + kernel=$(grep firmware /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 "$mac1" = "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 +} + +boot_hook_add preinit_main r6040_module +boot_hook_add preinit_main set_ether_mac + diff --git a/target/linux/rdc/base-files/lib/upgrade/platform.sh b/target/linux/rdc/base-files/lib/upgrade/platform.sh new file mode 100644 index 000000000..6348a6990 --- /dev/null +++ b/target/linux/rdc/base-files/lib/upgrade/platform.sh @@ -0,0 +1,10 @@ +PART_NAME=firmware + +platform_check_image() { + [ "$(get_magic_word $(find_mtd_part firmware))" -eq "$(get_magic_word "$1")" ] && return 0 + + echo "Invalid image type. Please use an appropriate .bin file" + return 1 +} + +# use default for platform_do_upgrade() |