2014-06-20 13:41:16 +00:00
|
|
|
#
|
2021-05-16 23:58:59 +02:00
|
|
|
# Copyright (C) 2021 OpenWrt.org
|
2014-06-20 13:41:16 +00:00
|
|
|
#
|
|
|
|
|
2014-12-05 00:19:46 +00:00
|
|
|
platform_get_rootfs() {
|
|
|
|
local rootfsdev
|
|
|
|
|
|
|
|
if read cmdline < /proc/cmdline; then
|
|
|
|
case "$cmdline" in
|
|
|
|
*root=*)
|
|
|
|
rootfsdev="${cmdline##*root=}"
|
|
|
|
rootfsdev="${rootfsdev%% *}"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
echo "${rootfsdev}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2021-05-16 23:58:59 +02:00
|
|
|
platform_copy_config_helper() {
|
|
|
|
local device=$1
|
|
|
|
|
|
|
|
mount -t vfat "$device" /mnt
|
|
|
|
cp -af "$UPGRADE_BACKUP" "/mnt/$BACKUP_FILE"
|
|
|
|
umount /mnt
|
|
|
|
}
|
|
|
|
|
2014-12-05 00:19:59 +00:00
|
|
|
platform_copy_config() {
|
2017-07-09 13:00:36 +02:00
|
|
|
case "$(board_name)" in
|
2022-05-28 21:34:48 +02:00
|
|
|
erlite|\
|
|
|
|
ubnt,usg)
|
2021-05-16 23:58:59 +02:00
|
|
|
platform_copy_config_helper /dev/sda1
|
2014-12-05 08:58:25 +00:00
|
|
|
;;
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
itus,shield-router)
|
2021-05-16 23:58:59 +02:00
|
|
|
platform_copy_config_helper /dev/mmcblk1p1
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
;;
|
2021-05-16 23:58:59 +02:00
|
|
|
ubnt,edgerouter-4|\
|
2021-05-12 14:48:01 +02:00
|
|
|
ubnt,edgerouter-6p)
|
2021-05-16 23:58:59 +02:00
|
|
|
platform_copy_config_helper /dev/mmcblk0p1
|
2020-10-22 21:20:05 +00:00
|
|
|
;;
|
2014-12-05 08:58:25 +00:00
|
|
|
esac
|
2014-12-05 00:19:59 +00:00
|
|
|
}
|
|
|
|
|
2015-03-20 08:49:08 +00:00
|
|
|
platform_do_flash() {
|
|
|
|
local tar_file=$1
|
|
|
|
local board=$2
|
|
|
|
local kernel=$3
|
|
|
|
local rootfs=$4
|
|
|
|
|
2020-08-15 13:50:43 +02:00
|
|
|
local board_dir=$(tar tf "$tar_file" | grep -m 1 '^sysupgrade-.*/$')
|
|
|
|
board_dir=${board_dir%/}
|
|
|
|
[ -n "$board_dir" ] || return 1
|
|
|
|
|
2015-03-20 08:49:08 +00:00
|
|
|
mkdir -p /boot
|
|
|
|
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
if [ $board = "itus,shield-router" ]; then
|
|
|
|
# mmcblk1p1 (fat) contains all ELF-bin images for the Shield
|
|
|
|
mount /dev/mmcblk1p1 /boot
|
|
|
|
|
|
|
|
echo "flashing Itus Kernel to /boot/$kernel (/dev/mmblk1p1)"
|
|
|
|
tar -Oxf $tar_file "$board_dir/kernel" > /boot/$kernel
|
|
|
|
else
|
|
|
|
mount -t vfat /dev/$kernel /boot
|
|
|
|
|
|
|
|
[ -f /boot/vmlinux.64 -a ! -L /boot/vmlinux.64 ] && {
|
|
|
|
mv /boot/vmlinux.64 /boot/vmlinux.64.previous
|
|
|
|
mv /boot/vmlinux.64.md5 /boot/vmlinux.64.md5.previous
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "flashing kernel to /dev/$kernel"
|
|
|
|
tar xf $tar_file $board_dir/kernel -O > /boot/vmlinux.64
|
|
|
|
md5sum /boot/vmlinux.64 | cut -f1 -d " " > /boot/vmlinux.64.md5
|
|
|
|
fi
|
2015-03-20 08:49:08 +00:00
|
|
|
|
|
|
|
echo "flashing rootfs to ${rootfs}"
|
2020-08-15 13:50:43 +02:00
|
|
|
tar xf $tar_file $board_dir/root -O | dd of="${rootfs}" bs=4096
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
|
2015-03-20 08:49:08 +00:00
|
|
|
sync
|
|
|
|
umount /boot
|
|
|
|
}
|
|
|
|
|
2014-06-20 13:41:16 +00:00
|
|
|
platform_do_upgrade() {
|
2015-03-20 08:49:08 +00:00
|
|
|
local tar_file="$1"
|
2017-07-09 13:00:36 +02:00
|
|
|
local board=$(board_name)
|
2014-12-05 00:19:46 +00:00
|
|
|
local rootfs="$(platform_get_rootfs)"
|
2015-03-20 08:49:08 +00:00
|
|
|
local kernel=
|
2014-12-05 00:19:46 +00:00
|
|
|
|
2014-12-05 08:58:06 +00:00
|
|
|
[ -b "${rootfs}" ] || return 1
|
2014-06-20 13:41:16 +00:00
|
|
|
case "$board" in
|
2020-10-22 21:20:05 +00:00
|
|
|
er | \
|
2021-05-12 14:48:01 +02:00
|
|
|
ubnt,edgerouter-4 | \
|
|
|
|
ubnt,edgerouter-6p)
|
2015-03-20 08:49:08 +00:00
|
|
|
kernel=mmcblk0p1
|
2014-06-20 13:41:16 +00:00
|
|
|
;;
|
2022-05-28 21:34:48 +02:00
|
|
|
erlite|\
|
|
|
|
ubnt,usg)
|
2018-12-04 14:59:31 -05:00
|
|
|
kernel=sda1
|
|
|
|
;;
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
itus,shield-router)
|
|
|
|
kernel=ItusrouterImage
|
|
|
|
;;
|
2015-03-20 08:49:08 +00:00
|
|
|
*)
|
|
|
|
return 1
|
2014-06-20 13:41:16 +00:00
|
|
|
esac
|
|
|
|
|
2015-03-20 08:49:08 +00:00
|
|
|
platform_do_flash $tar_file $board $kernel $rootfs
|
|
|
|
|
|
|
|
return 0
|
2014-06-20 13:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
platform_check_image() {
|
2017-07-09 13:00:36 +02:00
|
|
|
local board=$(board_name)
|
2020-08-15 13:50:43 +02:00
|
|
|
local tar_file="$1"
|
|
|
|
|
|
|
|
local board_dir=$(tar tf "$tar_file" | grep -m 1 '^sysupgrade-.*/$')
|
|
|
|
board_dir=${board_dir%/}
|
|
|
|
[ -n "$board_dir" ] || return 1
|
2014-06-20 13:41:16 +00:00
|
|
|
|
|
|
|
case "$board" in
|
2018-12-04 14:59:31 -05:00
|
|
|
er | \
|
octeon: add support for Itus Shield Router
Itus Networks Shield - 1Ghz dual-core mips64 / Cavium Octeon 3 SoC,
1Gb RAM, 4Gb eMMC,3 GbE 10/100/1000 ports
Information regarding device can be found:
https://deviwiki.com/wiki/Itus_Networks_Shield_Pro
Installing OpenWrt on Itus Networks Shield:
1) Boot Shield
2) On device: mount /dev/mmcblk1p1 /mnt
3) scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin to
/mnt/ItusrouterImage
3a) Optionally: scp openwrt-octeon-itus,shield-router-initramfs-kernel.bin
to /mnt/ItusgatewayImage to allow you to have an emergency recovery
boot in the GATEWAY slot - this slot will have no permament storage and
is used for emergency recovery only when booted in the (G)ateway
position
4) On device: umount /mnt
5) reboot
Once booted, run the sysupgrade via cli or luCi on the
openwrt-octeon-itus,shield-router-squashfs-sysupgrade.tar file the mode
you are running.
Once rebooted, the system installation is complete. Your storage partition
for the mode is inialized and set.
Signed-off-by: Donald Hoskins <grommish@gmail.com>
[cut out sysupgrade-* changes, move a few lines,
drop case CVMX_BOARD_TYPE_ITUS_SHIELD]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-22 05:26:33 -04:00
|
|
|
erlite | \
|
2020-10-22 21:20:05 +00:00
|
|
|
itus,shield-router | \
|
2021-05-12 14:48:01 +02:00
|
|
|
ubnt,edgerouter-4 | \
|
2022-05-28 21:34:48 +02:00
|
|
|
ubnt,edgerouter-6p | \
|
|
|
|
ubnt,usg)
|
2020-08-15 13:50:43 +02:00
|
|
|
local kernel_length=$(tar xf $tar_file $board_dir/kernel -O | wc -c 2> /dev/null)
|
|
|
|
local rootfs_length=$(tar xf $tar_file $board_dir/root -O | wc -c 2> /dev/null)
|
2014-06-20 13:41:16 +00:00
|
|
|
[ "$kernel_length" = 0 -o "$rootfs_length" = 0 ] && {
|
2019-01-12 19:39:01 +01:00
|
|
|
echo "The upgrade image is corrupt."
|
2014-06-20 13:41:16 +00:00
|
|
|
return 1
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
echo "Sysupgrade is not yet supported on $board."
|
|
|
|
return 1
|
|
|
|
}
|