5 [ -x /usr
/bin
/ldd
] || ldd
() { LD_TRACE_LOADED_OBJECTS
=1 $
*; }
6 libs
() { ldd $
* 2>/dev
/null |
sed -r 's/(.* => )?(.*) .*/\2/'; }
8 install_file
() { # <file> [ <file> ... ]
10 dest
="$RAM_ROOT/$file"
11 [ -f $file -a ! -f $dest ] && {
12 dir
="$(dirname $dest)"
19 install_bin
() { # <file> [ <symlink> ... ]
22 [ -x "$src" ] && files
="$src $(libs $src)"
25 for link
in "$@"; do {
26 dest
="$RAM_ROOT/$link"
27 dir
="$(dirname $dest)"
29 [ -f "$dest" ] ||
ln -s $src $dest
33 supivot
() { # <new_root> <old_root>
34 /bin
/mount |
grep "on $1 type" 2>&- 1>&- ||
/bin
/mount
-o bind $1 $1
35 mkdir
-p $1$2 $1/proc
$1/sys
$1/dev
$1/tmp
$1/overlay
&& \
36 /bin
/mount
-o noatime
,move
/proc
$1/proc
&& \
37 pivot_root
$1 $1$2 ||
{
42 /bin
/mount
-o noatime
,move
$2/sys
/sys
43 /bin
/mount
-o noatime
,move
$2/dev
/dev
44 /bin
/mount
-o noatime
,move
$2/tmp
/tmp
45 /bin
/mount
-o noatime
,move
$2/overlay
/overlay
2>&-
49 run_ramfs
() { # <command> [...]
50 install_bin
/bin
/busybox
/bin
/ash
/bin
/sh
/bin
/mount
/bin
/umount \
51 /sbin
/pivot_root
/sbin
/reboot
/bin
/sync
/bin
/dd /bin
/grep \
52 /bin
/cp /bin
/mv /bin
/tar /usr
/bin
/md5sum "/usr/bin/[" /bin
/dd \
53 /bin
/vi
/bin
/ls /bin
/cat /usr
/bin
/awk /usr
/bin
/hexdump \
54 /bin
/sleep /bin
/zcat
/usr
/bin
/bzcat
/usr
/bin
/printf /usr
/bin
/wc \
55 /bin
/cut
/usr
/bin
/printf /bin
/sync
/bin
/mkdir
/bin
/rmdir \
56 /bin
/rm /usr
/bin
/basename /bin
/kill /bin
/chmod /usr
/bin
/find
58 install_bin
/bin
/uclient-fetch
/bin
/wget
60 install_bin
/sbin
/mount_root
61 install_bin
/sbin
/snapshot
62 install_bin
/sbin
/snapshot_tool
63 install_bin
/usr
/sbin
/ubiupdatevol
64 install_bin
/usr
/sbin
/ubiattach
65 install_bin
/usr
/sbin
/ubiblock
66 install_bin
/usr
/sbin
/ubiformat
67 install_bin
/usr
/sbin
/ubidetach
68 install_bin
/usr
/sbin
/ubirsvol
69 install_bin
/usr
/sbin
/ubirmvol
70 install_bin
/usr
/sbin
/ubimkvol
71 install_bin
/usr
/sbin
/partx
72 install_bin
/usr
/sbin
/losetup
73 install_bin
/usr
/sbin
/mkfs.ext4
74 for file in $RAMFS_COPY_BIN; do
75 install_bin
${file//:/ }
77 install_file
/etc
/resolv.conf
/lib
/*.sh
/lib
/functions
/*.sh
/lib
/upgrade
/*.sh
$RAMFS_COPY_DATA
79 [ -L "/lib64" ] && ln -s /lib
$RAM_ROOT/lib64
81 supivot
$RAM_ROOT /mnt ||
{
82 echo "Failed to switch over to ramfs. Please reboot."
86 /bin
/mount
-o remount
,ro
/mnt
89 grep /overlay
/proc
/mounts
> /dev
/null
&& {
90 /bin
/mount
-o noatime
,remount
,ro
/overlay
91 /bin
/umount
-l /overlay
94 # spawn a new shell from ramdisk to reduce the probability of cache issues
95 exec /bin
/busybox ash
-c "$*"
98 kill_remaining
() { # [ <signal> ]
99 local sig
="${1:-TERM}"
100 echo -n "Sending $sig to remaining processes ... "
103 local my_ppid
=$
(cut
-d' ' -f4 /proc
/$my_pid/stat
)
104 local my_ppisupgraded
=
105 grep -q upgraded
/proc
/$my_ppid/cmdline
>/dev
/null
&& {
106 local my_ppisupgraded
=1
110 for stat
in /proc
/[0-9]*/stat
; do
111 [ -f "$stat" ] ||
continue
113 local pid name state ppid rest
114 read pid name state ppid rest
< $stat
115 name
="${name#(}"; name
="${name%)}"
118 read cmdline
< /proc
/$pid/cmdline
120 # Skip kernel threads
121 [ -n "$cmdline" ] ||
continue
123 if [ $$
-eq 1 ] ||
[ $my_ppid -eq 1 ] && [ -n "$my_ppisupgraded" ]; then
124 # Running as init process, kill everything except me
125 if [ $pid -ne $$
] && [ $pid -ne $my_ppid ]; then
127 kill -$sig $pid 2>/dev
/null
131 # Skip essential services
132 *procd
*|
*ash
*|
*init
*|
*watchdog
*|
*ssh*|
*dropbear
*|
*telnet*|
*login
*|
*hostapd
*|
*wpa_supplicant
*|
*nas
*|
*relayd
*) : ;;
136 if [ $pid -ne $$
] && [ $ppid -ne $$
]; then
138 kill -$sig $pid 2>/dev
/null
148 local arg
="$1"; shift
155 local default
="$1"; shift;
156 local answer
="$default"
158 [ "$INTERACTIVE" -eq 1 ] && {
160 0) echo -n "$* (y/N): ";;
161 *) echo -n "$* (Y/n): ";;
167 *) answer
="$default";;
174 [ "$VERBOSE" -ge 1 ] && echo "$@"
178 /bin
/mount |
awk '($3 ~ /^\/$/) && ($5 !~ /rootfs/) { print $5 }'
181 get_image
() { # <source> [ <command> ]
187 http
://*|
ftp://*) cmd
="wget -O- -q";;
190 if [ -z "$conc" ]; then
191 local magic
="$(eval $cmd \"$from\" 2>/dev/null | dd bs=2 count=1 2>/dev/null | hexdump -n 2 -e '1/1 "%02x
"')"
198 eval "$cmd \"$from\" 2>/dev/null ${conc:+| $conc}"
202 (get_image
"$@" |
dd bs
=2 count
=1 |
hexdump -v -n 2 -e '1/1 "%02x"') 2>/dev
/null
206 (get_image
"$@" |
dd bs
=4 count
=1 |
hexdump -v -n 4 -e '1/1 "%02x"') 2>/dev
/null
209 export_bootdevice
() {
210 local cmdline uuid disk uevent
211 local MAJOR MINOR DEVNAME DEVTYPE
213 if read cmdline
< /proc
/cmdline
; then
216 disk
="${cmdline##*block2mtd=}"
220 disk
="${cmdline##*root=}"
226 PARTUUID
=[a-f0-9
][a-f0-9
][a-f0-9
][a-f0-9
][a-f0-9
][a-f0-9
][a-f0-9
][a-f0-9
]-02)
227 uuid
="${disk#PARTUUID=}"
229 for disk
in $
(find /dev
-type b
); do
230 set -- $
(dd if=$disk bs
=1 skip
=440 count
=4 2>/dev
/null |
hexdump -v -e '4/1 "%02x "')
231 if [ "$4$3$2$1" = "$uuid" ]; then
232 uevent
="/sys/class/block/${disk##*/}/uevent"
238 uevent
="/sys/class/block/${disk##*/}/uevent"
242 if [ -e "$uevent" ]; then
245 export BOOTDEV_MAJOR
=$MAJOR
246 export BOOTDEV_MINOR
=$MINOR
254 export_partdevice
() {
255 local var
="$1" offset
="$2"
256 local uevent MAJOR MINOR DEVNAME DEVTYPE
258 for uevent
in /sys
/class
/block
/*/uevent
; do
260 if [ $BOOTDEV_MAJOR = $MAJOR -a $
(($BOOTDEV_MINOR + $offset)) = $MINOR -a -b "/dev/$DEVNAME" ]; then
261 export "$var=$DEVNAME"
269 get_partitions
() { # <device> <filename>
273 if [ -b "$disk" -o -f "$disk" ]; then
274 v
"Reading partition table from $filename..."
276 local magic
="$(hexdump -v -n 2 -s 0x1FE -e '1/2 "0x
%04X
"' "$disk")"
277 if [ "$magic" != 0xAA55 ]; then
278 v
"Invalid partition table on $disk"
282 rm -f "/tmp/partmap.$filename"
285 for part
in 1 2 3 4; do
286 set -- $
(hexdump -v -n 12 -s "$((0x1B2 + $part * 16))" -e '3/4 "0x%08X "' "$disk")
288 local type="$(($1 % 256))"
292 [ $type -gt 0 ] ||
continue
294 printf "%2d %5d %7d\n" $part $lba $num >> "/tmp/partmap.$filename"
299 jffs2_copy_config
() {
300 if grep rootfs_data
/proc
/mtd
>/dev
/null
; then
302 mtd
-e rootfs_data jffs2write
"$CONF_TAR" rootfs_data
305 mtd jffs2write
"$CONF_TAR" rootfs
309 # Flash firmware to MTD partition
311 # $(1): path to image
312 # $(2): (optional) pipe command to extract firmware, e.g. dd bs=n skip=m
313 default_do_upgrade
() {
315 if [ "$SAVE_CONFIG" -eq 1 ]; then
316 get_image
"$1" "$2" | mtd
$MTD_CONFIG_ARGS -j "$CONF_TAR" write - "${PART_NAME:-image}"
318 get_image
"$1" "$2" | mtd
write - "${PART_NAME:-image}"
323 v
"Performing system upgrade..."
324 if type 'platform_do_upgrade' >/dev
/null
2>/dev
/null
; then
325 platform_do_upgrade
"$ARGV"
327 default_do_upgrade
"$ARGV"
330 if [ "$SAVE_CONFIG" -eq 1 ] && type 'platform_copy_config' >/dev
/null
2>/dev
/null
; then
334 v
"Upgrade completed"
335 [ -n "$DELAY" ] && sleep "$DELAY"
336 ask_bool
1 "Reboot" && {
337 v
"Rebooting system..."
341 echo b
2>/dev
/null
>/proc
/sysrq-trigger