diff options
author | Florian Fainelli <florian@openwrt.org> | 2012-07-17 16:40:24 +0000 |
---|---|---|
committer | Florian Fainelli <florian@openwrt.org> | 2012-07-17 16:40:24 +0000 |
commit | f7dfd20f97d46fe6b1dee21ecfef19b02798aa68 (patch) | |
tree | 3b1a17a97412a2ba9996fc18957f2c8dc68e9120 /target/linux/au1000 | |
parent | ac6bf6d62f93ecaa7655872d90dccccd8fe6c7dd (diff) | |
download | upstream-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.tar.gz upstream-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.tar.bz2 upstream-f7dfd20f97d46fe6b1dee21ecfef19b02798aa68.zip |
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.sh | 36 | ||||
-rw-r--r-- | target/linux/au1000/image/Makefile | 1 |
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 0000000000..85ab213347 --- /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 573d541858..ac3efa282f 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 |