aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/cns21xx/base-files
diff options
context:
space:
mode:
authorblogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-10-05 10:12:53 +0000
committerblogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-10-05 10:12:53 +0000
commit5c105d9f3fd086aff195d3849dcf847d6b0bd927 (patch)
tree1229a11f725bfa58aa7c57a76898553bb5f6654a /target/linux/cns21xx/base-files
downloadopenwrt-5c105d9f3fd086aff195d3849dcf847d6b0bd927.tar.gz
openwrt-5c105d9f3fd086aff195d3849dcf847d6b0bd927.zip
branch Attitude Adjustment
git-svn-id: svn://svn.openwrt.org/openwrt/branches/attitude_adjustment@33625 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/cns21xx/base-files')
-rwxr-xr-xtarget/linux/cns21xx/base-files/etc/diag.sh54
-rwxr-xr-xtarget/linux/cns21xx/base-files/etc/uci-defaults/leds21
-rwxr-xr-xtarget/linux/cns21xx/base-files/lib/cns21xx.sh25
-rw-r--r--target/linux/cns21xx/base-files/lib/preinit/05_cns21xx_load_button_drivers11
-rwxr-xr-xtarget/linux/cns21xx/base-files/lib/upgrade/platform.sh45
5 files changed, 156 insertions, 0 deletions
diff --git a/target/linux/cns21xx/base-files/etc/diag.sh b/target/linux/cns21xx/base-files/etc/diag.sh
new file mode 100755
index 000000000..3fb835262
--- /dev/null
+++ b/target/linux/cns21xx/base-files/etc/diag.sh
@@ -0,0 +1,54 @@
+#!/bin/sh
+#
+# Copyright (C) 2010 OpenWrt.org
+#
+#
+
+. /lib/cns21xx.sh
+
+status_led=""
+
+led_set_attr() {
+ [ -f "/sys/class/leds/$1/$2" ] && echo "$3" > "/sys/class/leds/$1/$2"
+}
+
+status_led_set_timer() {
+ led_set_attr $status_led "trigger" "timer"
+ led_set_attr $status_led "delay_on" "$1"
+ led_set_attr $status_led "delay_off" "$2"
+}
+
+status_led_on() {
+ led_set_attr $status_led "trigger" "none"
+ led_set_attr $status_led "brightness" 255
+}
+
+status_led_off() {
+ led_set_attr $status_led "trigger" "none"
+ led_set_attr $status_led "brightness" 0
+}
+
+get_status_led() {
+ case $(get_board_name) in
+ ns-k330)
+ status_led="ns-k330:red:link"
+ ;;
+ esac;
+}
+
+set_state() {
+ get_status_led
+
+ case "$1" in
+ preinit)
+ insmod leds-gpio
+ status_led_set_timer 200 200
+ ;;
+ failsafe)
+ status_led_set_timer 50 50
+ ;;
+ done)
+ status_led_on
+ ;;
+ esac
+}
diff --git a/target/linux/cns21xx/base-files/etc/uci-defaults/leds b/target/linux/cns21xx/base-files/etc/uci-defaults/leds
new file mode 100755
index 000000000..bdebb6c1c
--- /dev/null
+++ b/target/linux/cns21xx/base-files/etc/uci-defaults/leds
@@ -0,0 +1,21 @@
+#!/bin/sh
+#
+# Copyright (C) 2010 OpenWrt.org
+#
+
+. /lib/functions/uci-defaults.sh
+. /lib/cns21xx.sh
+
+board=$(get_board_name)
+
+case "$board" in
+"ns-k330")
+ ucidef_set_led_netdev "eth_orange" "ETH (orange)" "ns-k330:orange:eth" "eth0"
+ ucidef_set_led_usbdev "usb1" "USB1" "ns-k330:green:usb1" "1-1"
+ ucidef_set_led_usbdev "usb2" "USB2" "ns-k330:green:usb2" "1-2"
+ ;;
+fi
+
+ucidef_commit_leds
+
+exit 0
diff --git a/target/linux/cns21xx/base-files/lib/cns21xx.sh b/target/linux/cns21xx/base-files/lib/cns21xx.sh
new file mode 100755
index 000000000..c10f6d38c
--- /dev/null
+++ b/target/linux/cns21xx/base-files/lib/cns21xx.sh
@@ -0,0 +1,25 @@
+#!/bin/sh
+#
+# Copyright (C) 2010 OpenWrt.org
+#
+
+get_board_name() {
+ local hardware
+ local name
+
+ hardware=$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /Hardware/ {print $2}' /proc/cpuinfo)
+
+ case "$hardware" in
+ *NSB3AST)
+ name="nsb3ast"
+ ;;
+ "NS-K330 NAS")
+ name="ns-k330"
+ ;;
+ *)
+ name="generic"
+ ;;
+ esac
+
+ echo $name
+}
diff --git a/target/linux/cns21xx/base-files/lib/preinit/05_cns21xx_load_button_drivers b/target/linux/cns21xx/base-files/lib/preinit/05_cns21xx_load_button_drivers
new file mode 100644
index 000000000..fe71f98d0
--- /dev/null
+++ b/target/linux/cns21xx/base-files/lib/preinit/05_cns21xx_load_button_drivers
@@ -0,0 +1,11 @@
+#
+# Copyright (C) 2010 OpenWrt.org
+#
+
+preinit_load_button_drivers() {
+ insmod input-core
+ insmod gpio_keys
+ insmod button-hotplug
+}
+
+boot_hook_add preinit_main preinit_load_button_drivers
diff --git a/target/linux/cns21xx/base-files/lib/upgrade/platform.sh b/target/linux/cns21xx/base-files/lib/upgrade/platform.sh
new file mode 100755
index 000000000..52aa789f5
--- /dev/null
+++ b/target/linux/cns21xx/base-files/lib/upgrade/platform.sh
@@ -0,0 +1,45 @@
+#
+# Copyright (C) 2010 OpenWrt.org
+#
+
+. /lib/cns21xx.sh
+
+PART_NAME=firmware
+RAMFS_COPY_DATA=/lib/cns21xx.sh
+
+platform_check_image() {
+ local board=$(get_board_name)
+ local magic="$(get_magic_word "$1")"
+
+ [ "$ARGC" -gt 1 ] && return 1
+
+ case "$board" in
+ nsb3ast)
+ [ "$magic" != "0b1c" ] && {
+ echo "Invalid image type."
+ return 1
+ }
+ return 0
+ ;;
+ ns-k330)
+ [ "$magic" != "0c1c" ] && {
+ echo "Invalid image type."
+ return 1
+ }
+ return 0
+ ;;
+ esac
+
+ echo "Sysupgrade is not yet supported on $board."
+ return 1
+}
+
+disable_watchdog() {
+ killall watchdog
+ ( ps | grep -v 'grep' | grep '/dev/watchdog' ) && {
+ echo 'Could not disable watchdog'
+ return 1
+ }
+}
+
+append sysupgrade_pre_upgrade disable_watchdog