aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/au1000/base-files/lib/upgrade/platform.sh
diff options
context:
space:
mode:
authorJames <>2013-03-17 12:16:37 +0000
committerJames <>2013-03-17 12:16:37 +0000
commit27b76ab0671089c47506615a796a261e993896a7 (patch)
tree61213d67e7fa87b20356b23798558e2c4212c42f /target/linux/au1000/base-files/lib/upgrade/platform.sh
downloadtrunk-36060-master.tar.gz
trunk-36060-master.tar.bz2
trunk-36060-master.zip
Diffstat (limited to 'target/linux/au1000/base-files/lib/upgrade/platform.sh')
-rw-r--r--target/linux/au1000/base-files/lib/upgrade/platform.sh36
1 files changed, 36 insertions, 0 deletions
diff --git a/target/linux/au1000/base-files/lib/upgrade/platform.sh b/target/linux/au1000/base-files/lib/upgrade/platform.sh
new file mode 100644
index 0000000..85ab213
--- /dev/null
+++ b/target/linux/au1000/base-files/lib/upgrade/platform.sh
@@ -0,0 +1,36 @@
+KERNEL_IMG="openwrt-au1000-au1500-vmlinux.bin"
+ROOTFS_IMG="openwrt-au1000-au1500-jffs2-128k.fs"
+
+platform_check_image() {
+ [ "$ARGC" -gt 1 ] && return 1
+ case "$(get_magic_word "$1")" in
+ 6f70)
+ ( get_image "$1" | tar -tf - $KERNEL_IMG >/dev/null && \
+ get_image "$1" | tar -tf - $ROOTFS_IMG >/dev/null) || {
+ echo "Invalid image contents"
+ return 1
+ }
+ return 0;;
+ *)
+ echo "Invalid image type"
+ return 1;;
+ esac
+}
+
+platform_do_upgrade() {
+ sync
+ local conf=""
+ [ -f "$CONF_TAR" -a "$SAVE_CONFIG" -eq 1 ] && conf="-j $CONF_TAR"
+ get_image "$1" | tar -Oxvf - $KERNEL_IMG | mtd write - "kernel"
+ get_image "$1" | tar -Oxvf - $ROOTFS_IMG | mtd $conf write - "rootfs"
+}
+
+disable_watchdog() {
+ killall watchdog
+ ( ps | grep -v 'grep' | grep '/dev/watchdog' ) && {
+ echo 'Could not disable watchdog'
+ return 1
+ }
+}
+
+append sysupgrade_pre_upgrade disable_watchdog