123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- From: Matthias Schiffer <mschiffer@universe-factory.net>
- Date: Sun, 23 Apr 2017 23:33:14 +0200
- Subject: base-files: sysupgrade cleanup
- Some functions only used by stage2 are moved there from common.sh.
- One piece that could still use more cleanup is platform_pre_upgrade: many
- targets reference files from there are aren't available in the ramfs, so
- we need to evaluate it before the switch; conversely, flash writes happen
- in that function on some targets. Targets that do the latter should be
- fixed eventually to use platform_do_upgrade for that purpose.
- Signed-off-by: Matthias Schiffer <mschiffer@universe-factory.net>
- diff --git a/package/base-files/files/lib/upgrade/common.sh b/package/base-files/files/lib/upgrade/common.sh
- index 6f8e408401906666db945a981100962139fc7d32..b18463f6b8e81d871b27146c00d061941ac6a2ec 100644
- --- a/package/base-files/files/lib/upgrade/common.sh
- +++ b/package/base-files/files/lib/upgrade/common.sh
- @@ -30,106 +30,6 @@ install_bin() { # <file> [ <symlink> ... ]
- }; done
- }
-
- -supivot() { # <new_root> <old_root>
- - /bin/mount | grep "on $1 type" 2>&- 1>&- || /bin/mount -o bind $1 $1
- - mkdir -p $1$2 $1/proc $1/sys $1/dev $1/tmp $1/overlay && \
- - /bin/mount -o noatime,move /proc $1/proc && \
- - pivot_root $1 $1$2 || {
- - /bin/umount -l $1 $1
- - return 1
- - }
- -
- - /bin/mount -o noatime,move $2/sys /sys
- - /bin/mount -o noatime,move $2/dev /dev
- - /bin/mount -o noatime,move $2/tmp /tmp
- - /bin/mount -o noatime,move $2/overlay /overlay 2>&-
- - return 0
- -}
- -
- -run_ramfs() { # <command> [...]
- - install_bin /bin/busybox /bin/ash /bin/sh /bin/mount /bin/umount \
- - /sbin/pivot_root /sbin/reboot /bin/sync /bin/dd /bin/grep \
- - /bin/cp /bin/mv /bin/tar /usr/bin/md5sum "/usr/bin/[" /bin/dd \
- - /bin/vi /bin/ls /bin/cat /usr/bin/awk /usr/bin/hexdump \
- - /bin/sleep /bin/zcat /usr/bin/bzcat /usr/bin/printf /usr/bin/wc \
- - /bin/cut /usr/bin/printf /bin/sync /bin/mkdir /bin/rmdir \
- - /bin/rm /usr/bin/basename /bin/kill /bin/chmod /usr/bin/find \
- - /bin/mknod
- -
- - install_bin /sbin/mtd
- - install_bin /sbin/mount_root
- - install_bin /sbin/snapshot
- - install_bin /sbin/snapshot_tool
- - install_bin /usr/sbin/ubiupdatevol
- - install_bin /usr/sbin/ubiattach
- - install_bin /usr/sbin/ubiblock
- - install_bin /usr/sbin/ubiformat
- - install_bin /usr/sbin/ubidetach
- - install_bin /usr/sbin/ubirsvol
- - install_bin /usr/sbin/ubirmvol
- - install_bin /usr/sbin/ubimkvol
- - install_bin /usr/sbin/partx
- - install_bin /usr/sbin/losetup
- - install_bin /usr/sbin/mkfs.ext4
- - for file in $RAMFS_COPY_BIN; do
- - install_bin ${file//:/ }
- - done
- - install_file /etc/resolv.conf /lib/*.sh /lib/functions/*.sh /lib/upgrade/*.sh $RAMFS_COPY_DATA
- -
- - [ -L "/lib64" ] && ln -s /lib $RAM_ROOT/lib64
- -
- - supivot $RAM_ROOT /mnt || {
- - echo "Failed to switch over to ramfs. Please reboot."
- - exit 1
- - }
- -
- - /bin/mount -o remount,ro /mnt
- - /bin/umount -l /mnt
- -
- - grep /overlay /proc/mounts > /dev/null && {
- - /bin/mount -o noatime,remount,ro /overlay
- - /bin/umount -l /overlay
- - }
- -
- - # spawn a new shell from ramdisk to reduce the probability of cache issues
- - exec /bin/busybox ash -c "$*"
- -}
- -
- -kill_remaining() { # [ <signal> [ <loop> ] ]
- - local sig="${1:-TERM}"
- - local loop="${2:-0}"
- - local run=true
- - local stat
- -
- - echo -n "Sending $sig to remaining processes ... "
- -
- - while $run; do
- - run=false
- - for stat in /proc/[0-9]*/stat; do
- - [ -f "$stat" ] || continue
- -
- - local pid name state ppid rest
- - read pid name state ppid rest < $stat
- - name="${name#(}"; name="${name%)}"
- -
- - # Skip PID1, ourself and our children
- - [ $pid -ne 1 -a $pid -ne $$ -a $ppid -ne $$ ] || continue
- -
- - local cmdline
- - read cmdline < /proc/$pid/cmdline
- -
- - # Skip kernel threads
- - [ -n "$cmdline" ] || continue
- -
- - echo -n "$name "
- - kill -$sig $pid 2>/dev/null
- -
- - [ $loop -eq 1 ] && run=true
- - done
- - done
- - echo ""
- -}
- -
- run_hooks() {
- local arg="$1"; shift
- for func in "$@"; do
- diff --git a/package/base-files/files/lib/upgrade/stage2 b/package/base-files/files/lib/upgrade/stage2
- index 4e2aa3a23c3bab07a795762a30a4d4f701081934..cc8047d988e39ca9ba27d2588744aad469d1d978 100755
- --- a/package/base-files/files/lib/upgrade/stage2
- +++ b/package/base-files/files/lib/upgrade/stage2
- @@ -24,6 +24,104 @@ export CONF_TAR=/tmp/sysupgrade.tgz
- include /lib/upgrade
-
-
- +supivot() { # <new_root> <old_root>
- + /bin/mount | grep "on $1 type" 2>&- 1>&- || /bin/mount -o bind $1 $1
- + mkdir -p $1$2 $1/proc $1/sys $1/dev $1/tmp $1/overlay && \
- + /bin/mount -o noatime,move /proc $1/proc && \
- + pivot_root $1 $1$2 || {
- + /bin/umount -l $1 $1
- + return 1
- + }
- +
- + /bin/mount -o noatime,move $2/sys /sys
- + /bin/mount -o noatime,move $2/dev /dev
- + /bin/mount -o noatime,move $2/tmp /tmp
- + /bin/mount -o noatime,move $2/overlay /overlay 2>&-
- + return 0
- +}
- +
- +switch_to_ramfs() {
- + install_bin /bin/busybox /bin/ash /bin/sh /bin/mount /bin/umount \
- + /sbin/pivot_root /sbin/reboot /bin/sync /bin/dd /bin/grep \
- + /bin/cp /bin/mv /bin/tar /usr/bin/md5sum "/usr/bin/[" /bin/dd \
- + /bin/vi /bin/ls /bin/cat /usr/bin/awk /usr/bin/hexdump \
- + /bin/sleep /bin/zcat /usr/bin/bzcat /usr/bin/printf /usr/bin/wc \
- + /bin/cut /usr/bin/printf /bin/sync /bin/mkdir /bin/rmdir \
- + /bin/rm /usr/bin/basename /bin/kill /bin/chmod /usr/bin/find \
- + /bin/mknod
- +
- + install_bin /sbin/mtd
- + install_bin /sbin/mount_root
- + install_bin /sbin/snapshot
- + install_bin /sbin/snapshot_tool
- + install_bin /usr/sbin/ubiupdatevol
- + install_bin /usr/sbin/ubiattach
- + install_bin /usr/sbin/ubiblock
- + install_bin /usr/sbin/ubiformat
- + install_bin /usr/sbin/ubidetach
- + install_bin /usr/sbin/ubirsvol
- + install_bin /usr/sbin/ubirmvol
- + install_bin /usr/sbin/ubimkvol
- + install_bin /usr/sbin/partx
- + install_bin /usr/sbin/losetup
- + install_bin /usr/sbin/mkfs.ext4
- + for file in $RAMFS_COPY_BIN; do
- + install_bin ${file//:/ }
- + done
- + install_file /etc/resolv.conf /lib/*.sh /lib/functions/*.sh /lib/upgrade/*.sh $RAMFS_COPY_DATA
- +
- + [ -L "/lib64" ] && ln -s /lib $RAM_ROOT/lib64
- +
- + supivot $RAM_ROOT /mnt || {
- + echo "Failed to switch over to ramfs. Please reboot."
- + exit 1
- + }
- +
- + /bin/mount -o remount,ro /mnt
- + /bin/umount -l /mnt
- +
- + grep /overlay /proc/mounts > /dev/null && {
- + /bin/mount -o noatime,remount,ro /overlay
- + /bin/umount -l /overlay
- + }
- +}
- +
- +kill_remaining() { # [ <signal> [ <loop> ] ]
- + local sig="${1:-TERM}"
- + local loop="${2:-0}"
- + local run=true
- + local stat
- +
- + echo -n "Sending $sig to remaining processes ... "
- +
- + while $run; do
- + run=false
- + for stat in /proc/[0-9]*/stat; do
- + [ -f "$stat" ] || continue
- +
- + local pid name state ppid rest
- + read pid name state ppid rest < $stat
- + name="${name#(}"; name="${name%)}"
- +
- + # Skip PID1, ourself and our children
- + [ $pid -ne 1 -a $pid -ne $$ -a $ppid -ne $$ ] || continue
- +
- + local cmdline
- + read cmdline < /proc/$pid/cmdline
- +
- + # Skip kernel threads
- + [ -n "$cmdline" ] || continue
- +
- + echo -n "$name "
- + kill -$sig $pid 2>/dev/null
- +
- + [ $loop -eq 1 ] && run=true
- + done
- + done
- + echo ""
- +}
- +
- +
- killall -9 telnetd
- killall -9 dropbear
- killall -9 ash
- @@ -44,7 +142,8 @@ fi
-
- if [ -n "$(rootfs_type)" ]; then
- echo "Switching to ramdisk..."
- - run_ramfs "$COMMAND"
- -else
- - exec /bin/busybox ash -c "$COMMAND"
- + switch_to_ramfs
- fi
- +
- +# Exec new shell from ramfs
- +exec /bin/busybox ash -c "$COMMAND"
- diff --git a/package/base-files/files/sbin/sysupgrade b/package/base-files/files/sbin/sysupgrade
- index 2d67371ef74b4b970076a069e97f4fd6a1e0bc95..200a0e520b5df8bcc208f4d8fd731756e94294fb 100755
- --- a/package/base-files/files/sbin/sysupgrade
- +++ b/package/base-files/files/sbin/sysupgrade
- @@ -1,7 +1,5 @@
- #!/bin/sh
-
- -[ "$1" = "nand" ] && exec /lib/upgrade/stage2 "$2" "$3"
- -
- . /lib/functions.sh
- . /lib/functions/system.sh
-
|