summaryrefslogtreecommitdiff
path: root/target/linux/au1000
diff options
context:
space:
mode:
authorFlorian Fainelli <florian@openwrt.org>2012-07-17 16:40:24 +0000
committerFlorian Fainelli <florian@openwrt.org>2012-07-17 16:40:24 +0000
commitf7dfd20f97d46fe6b1dee21ecfef19b02798aa68 (patch)
tree3b1a17a97412a2ba9996fc18957f2c8dc68e9120 /target/linux/au1000
parentac6bf6d62f93ecaa7655872d90dccccd8fe6c7dd (diff)
downloadmtk-20170518-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.zip
mtk-20170518-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.tar.gz
mtk-20170518-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.tar.bz2
au1000: implement sysupgrade platform.sh
Signed-off-by: Bruno Randolf <br1@einfach.org> SVN-Revision: 32768
Diffstat (limited to 'target/linux/au1000')
-rw-r--r--target/linux/au1000/base-files/lib/upgrade/platform.sh36
-rw-r--r--target/linux/au1000/image/Makefile1
2 files changed, 37 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
diff --git a/target/linux/au1000/image/Makefile b/target/linux/au1000/image/Makefile
index 573d541..ac3efa2 100644
--- a/target/linux/au1000/image/Makefile
+++ b/target/linux/au1000/image/Makefile
@@ -62,6 +62,7 @@ define Image/Build
$(CP) $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-$(1).fs
$(CP) $(KDIR)/kernel.flash.srec $(BIN_DIR)/$(IMG_PREFIX)-vmlinux-flash.srec
$(CP) $(KDIR)/kernel.ram.srec $(BIN_DIR)/$(IMG_PREFIX)-vmlinux-ram.srec
+ tar -C $(BIN_DIR) -cvzf $(BIN_DIR)/$(IMG_PREFIX)-upgrade.tgz $(IMG_PREFIX)-vmlinux.bin $(IMG_PREFIX)-$(1).fs
ifeq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),y)
$(call Image/Build/Initramfs)
endif