PART_NAME=firmware
RAMFS_COPY_DATA=/lib/ar71xx.sh
+RAMFS_COPY_BIN='nandwrite'
CI_BLKSZ=65536
CI_LDADR=0x80060000
+PLATFORM_DO_UPGRADE_COMBINED_SEPARATE_MTD=0
+
platform_find_partitions() {
local first dev size erasesize name
while read dev size erasesize name; do
done
}
+platform_find_rootfspart() {
+ local part
+ for part in "${1%:*}" "${1#*:}"; do
+ [ "$part" != "$2" ] && echo "$part" && break
+ done
+}
+
platform_do_upgrade_combined() {
local partitions=$(platform_find_partitions)
local kernelpart=$(platform_find_kernelpart "${partitions#*:}")
[ ${root_blocks:-0} -gt 0 ] && \
[ ${erase_size:-0} -gt 0 ];
then
+ local rootfspart=$(platform_find_rootfspart "$partitions" "$kernelpart")
local append=""
[ -f "$CONF_TAR" -a "$SAVE_CONFIG" -eq 1 ] && append="-j $CONF_TAR"
- ( dd if="$1" bs=$CI_BLKSZ skip=1 count=$kern_blocks 2>/dev/null; \
- dd if="$1" bs=$CI_BLKSZ skip=$((1+$kern_blocks)) count=$root_blocks 2>/dev/null ) | \
- mtd -r $append -F$kernelpart:$kern_length:$CI_LDADR,rootfs write - $partitions
+ if [ "$PLATFORM_DO_UPGRADE_COMBINED_SEPARATE_MTD" -ne 1 ]; then
+ ( dd if="$1" bs=$CI_BLKSZ skip=1 count=$kern_blocks 2>/dev/null; \
+ dd if="$1" bs=$CI_BLKSZ skip=$((1+$kern_blocks)) count=$root_blocks 2>/dev/null ) | \
+ mtd -r $append -F$kernelpart:$kern_length:$CI_LDADR,rootfs write - $partitions
+ elif [ -n "$rootfspart" ]; then
+ dd if="$1" bs=$CI_BLKSZ skip=1 count=$kern_blocks 2>/dev/null | \
+ mtd write - $kernelpart
+ dd if="$1" bs=$CI_BLKSZ skip=$((1+$kern_blocks)) count=$root_blocks 2>/dev/null | \
+ mtd -r $append write - $rootfspart
+ fi
fi
+ PLATFORM_DO_UPGRADE_COMBINED_SEPARATE_MTD=0
}
tplink_get_image_hwid() {
# is accepted (loading the first 1.5M of a remote image for this check seems
# a bit extreme)
dd if="$1" bs=1 skip=1511432 count=1024 2>/dev/null | while read line; do
- [ "$line" == "$model_string" ] && break
+ [ "$line" = "$model_string" ] && break
done || {
echo "Unsupported image (model not in support-list)"
return 1
return 0
}
+platform_nand_board_name() {
+ local board=$(board_name)
+
+ case "$board" in
+ rb*) echo "routerboard";;
+ *) echo "$board";;
+ esac
+}
+
platform_check_image() {
- local board=$(ar71xx_board_name)
+ local board=$(board_name)
local magic="$(get_magic_word "$1")"
local magic_long="$(get_magic_long "$1")"
airgatewaypro|\
airgateway|\
airrouter|\
+ ap121f|\
ap132|\
+ ap531b0|\
ap90q|\
+ archer-c25-v1|\
+ archer-c58-v1|\
+ archer-c59-v1|\
+ archer-c60-v1|\
bullet-m|\
c-55|\
carambola2|\
cf-e380ac-v2|\
cf-e520n|\
cf-e530n|\
+ cpe505n|\
cpe830|\
cpe870|\
dgl-5500-a1|\
dlan-pro-500-wp|\
dr531|\
dragino2|\
+ ebr-2310-c1|\
+ ens202ext|\
epg5000|\
esr1750|\
esr900|\
gl-ar300|\
gl-domino|\
gl-mifi|\
+ gl-usb150|\
hiwifi-hc6361|\
hornet-ub-x2|\
jwap230|\
+ lima|\
loco-m-xw|\
mzk-w04nu|\
mzk-w300nh|\
nanostation-m-xw|\
nanostation-m|\
nbg460n_550n_550nh|\
+ pqi-air-pen|\
+ r602n|\
rocket-m-ti|\
rocket-m-xw|\
rocket-m|\
rw2458n|\
+ sc1750|\
+ sc300m|\
+ sc450|\
sr3200|\
tew-632brp|\
tew-712br|\
tew-732br|\
tew-823dru|\
+ tl-wr942n-v1|\
unifi-outdoor|\
unifiac-lite|\
unifiac-pro|\
wpj342|\
wpj344|\
wpj531|\
+ wpj558|\
+ wpj563|\
wrt400n|\
wrtnode2q|\
wzr-450hp2|\
hornet-ub|\
mr12|\
mr16|\
- wpj558|\
zbt-we1526|\
zcn-1523h-2|\
zcn-1523h-5)
omy-x1|\
onion-omega|\
oolite|\
+ re450|\
smart-300|\
som9331|\
tellstick-znet-lite|\
tl-mr3220|\
tl-mr3420-v2|\
tl-mr3420|\
+ tl-mr6400|\
tl-wa701nd-v2|\
tl-wa7210n-v2|\
tl-wa750re|\
tl-wa801nd-v3|\
tl-wa830re-v2|\
tl-wa850re|\
+ tl-wa850re-v2|\
+ tl-wa855re-v1|\
tl-wa860re|\
tl-wa901nd-v2|\
tl-wa901nd-v3|\
tl-wpa8630|\
tl-wr1041n-v2|\
tl-wr1043nd-v2|\
+ tl-wr1043nd-v4|\
tl-wr1043nd|\
tl-wr2543n|\
tl-wr703n|\
tl-wr710n|\
tl-wr720n-v3|\
+ tl-wr740n-v6|\
tl-wr741nd-v4|\
tl-wr741nd|\
tl-wr802n-v1|\
+ tl-wr802n-v2|\
tl-wr810n|\
+ tl-wr840n-v2|\
+ tl-wr840n-v3|\
tl-wr841n-v11|\
tl-wr841n-v1|\
tl-wr841n-v7|\
tl-wr841n-v9|\
tl-wr842n-v2|\
tl-wr842n-v3|\
+ tl-wr902ac-v1|\
tl-wr941nd-v5|\
tl-wr941nd-v6|\
tl-wr940n-v4|\
tew-673gru)
dir825b_check_image "$1" && return 0
;;
+ rb-411|\
+ rb-411u|\
+ rb-433|\
+ rb-433u|\
+ rb-435g|\
+ rb-450|\
+ rb-450g|\
+ rb-493|\
+ rb-493g|\
+ rb-750|\
+ rb-750gl|\
+ rb-751|\
+ rb-751g|\
+ rb-911g-2hpnd|\
+ rb-911g-5hpnd|\
+ rb-911g-5hpacd|\
+ rb-912uag-2hpnd|\
+ rb-912uag-5hpnd|\
+ rb-951g-2hnd|\
+ rb-951ui-2hnd|\
+ rb-2011l|\
+ rb-2011il|\
+ rb-2011uas|\
+ rb-2011uias|\
+ rb-2011uas-2hnd|\
+ rb-2011uias-2hnd|\
+ rb-sxt2n|\
+ rb-sxt5n)
+ nand_do_platform_check routerboard $1
+ return $?
+ ;;
c-60|\
+ hiveap-121|\
nbg6716|\
r6100|\
+ rambutan|\
wndr3700v4|\
wndr4300)
nand_do_platform_check $board $1
;;
cpe210|\
cpe510|\
- eap120)
+ eap120|\
+ wbs210|\
+ wbs510)
tplink_pharos_check_image "$1" && return 0
return 1
;;
+ a40|\
+ a60|\
mr1750v2|\
mr1750|\
mr600v2|\
mr900|\
om2p-hsv2|\
om2p-hsv3|\
+ om2p-hsv4|\
om2p-hs|\
om2p-lc|\
om2pv2|\
+ om2pv4|\
om2p|\
om5p-acv2|\
om5p-ac|\
return 0;
;;
+ # these boards use metadata images
+ fritz300e|\
+ rb-750-r2|\
+ rb-750up-r2|\
+ rb-941-2nd|\
+ rb-951ui-2nd|\
+ rb-952ui-5ac2nd|\
+ rb-962uigs-5hact2hnt|\
+ rb-lhg-5nd|\
+ rb-mapl-2nd)
+ return 0
+ ;;
esac
echo "Sysupgrade is not yet supported on $board."
}
platform_pre_upgrade() {
- local board=$(ar71xx_board_name)
+ local board=$(board_name)
case "$board" in
c-60|\
+ hiveap-121|\
nbg6716|\
r6100|\
+ rambutan|\
+ rb-411|\
+ rb-411u|\
+ rb-433|\
+ rb-433u|\
+ rb-435g|\
+ rb-450|\
+ rb-450g|\
+ rb-493|\
+ rb-493g|\
+ rb-750|\
+ rb-750gl|\
+ rb-751|\
+ rb-751g|\
+ rb-911g-2hpnd|\
+ rb-911g-5hpnd|\
+ rb-911g-5hpacd|\
+ rb-912uag-2hpnd|\
+ rb-912uag-5hpnd|\
+ rb-951g-2hnd|\
+ rb-951ui-2hnd|\
+ rb-2011il|\
+ rb-2011l|\
+ rb-2011uas|\
+ rb-2011uias|\
+ rb-2011uas-2hnd|\
+ rb-2011uias-2hnd|\
+ rb-sxt2n|\
+ rb-sxt5n|\
wndr3700v4|\
wndr4300)
nand_do_upgrade "$1"
;;
+ rb-750-r2|\
+ rb-750up-r2|\
+ rb-941-2nd|\
+ rb-951ui-2nd|\
+ rb-952ui-5ac2nd|\
+ rb-962uigs-5hact2hnt|\
+ rb-lhg-5nd|\
+ rb-mapl-2nd)
+ # erase firmware if booted from initramfs
+ [ -z "$(rootfs_type)" ] && mtd erase firmware
+ ;;
mr18|\
z1)
merakinand_do_upgrade "$1"
esac
}
+platform_nand_pre_upgrade() {
+ local board=$(board_name)
+
+ case "$board" in
+ rb*)
+ CI_KERNPART=none
+ local fw_mtd=$(find_mtd_part kernel)
+ fw_mtd="${fw_mtd/block/}"
+ [ -n "$fw_mtd" ] || return
+ mtd erase kernel
+ tar xf "$1" sysupgrade-routerboard/kernel -O | nandwrite -o "$fw_mtd" -
+ ;;
+ esac
+}
+
platform_do_upgrade() {
- local board=$(ar71xx_board_name)
+ local board=$(board_name)
case "$board" in
all0258n)
platform_do_upgrade_allnet "0x9f080000" "$ARGV"
;;
cap4200ag|\
- eap300v2)
+ eap300v2|\
+ ens202ext)
platform_do_upgrade_allnet "0xbf0a0000" "$ARGV"
;;
dir-825-b1|\
tew-673gru)
platform_do_upgrade_dir825b "$ARGV"
;;
+ a40|\
+ a60|\
mr1750v2|\
mr1750|\
mr600v2|\
mr900|\
om2p-hsv2|\
om2p-hsv3|\
+ om2p-hsv4|\
om2p-hs|\
om2p-lc|\
om2pv2|\
+ om2pv4|\
om2p|\
om5p-acv2|\
om5p-ac|\