From 86148ac69bbfb69d10b5118b6583fb0c94ede629 Mon Sep 17 00:00:00 2001
From: Florian Fainelli <florian@openwrt.org>
Date: Mon, 15 Oct 2012 18:54:34 +0000
Subject: [x86] merge the RDC R-321x target as a subtarget of x86

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@33779 3c298f89-4303-0410-b956-a3cf2f4a3e73
---
 target/linux/x86/rdc/base-files/etc/config/network | 18 +++++++++++
 target/linux/x86/rdc/base-files/etc/diag.sh        | 19 ++++++++++++
 .../base-files/lib/preinit/05_set_ether_mac_rdc    | 36 ++++++++++++++++++++++
 .../x86/rdc/base-files/lib/upgrade/platform.sh     | 10 ++++++
 4 files changed, 83 insertions(+)
 create mode 100644 target/linux/x86/rdc/base-files/etc/config/network
 create mode 100644 target/linux/x86/rdc/base-files/etc/diag.sh
 create mode 100644 target/linux/x86/rdc/base-files/lib/preinit/05_set_ether_mac_rdc
 create mode 100644 target/linux/x86/rdc/base-files/lib/upgrade/platform.sh

(limited to 'target/linux/x86/rdc/base-files')

diff --git a/target/linux/x86/rdc/base-files/etc/config/network b/target/linux/x86/rdc/base-files/etc/config/network
new file mode 100644
index 0000000000..44c57940e2
--- /dev/null
+++ b/target/linux/x86/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/x86/rdc/base-files/etc/diag.sh b/target/linux/x86/rdc/base-files/etc/diag.sh
new file mode 100644
index 0000000000..8d5c38262c
--- /dev/null
+++ b/target/linux/x86/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/x86/rdc/base-files/lib/preinit/05_set_ether_mac_rdc b/target/linux/x86/rdc/base-files/lib/preinit/05_set_ether_mac_rdc
new file mode 100644
index 0000000000..4640e008fa
--- /dev/null
+++ b/target/linux/x86/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/x86/rdc/base-files/lib/upgrade/platform.sh b/target/linux/x86/rdc/base-files/lib/upgrade/platform.sh
new file mode 100644
index 0000000000..6348a6990b
--- /dev/null
+++ b/target/linux/x86/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()
-- 
cgit v1.2.3