blob: 8a97495ed8f59799afc247b2fc56c126689ceda8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
#!/bin/sh
who=$(id -u)
if [ $who -ne 0 ]; then
echo 'Exit. System update must be run as root.'
exit 1
fi
if [ -x /sbin/mtd ];then
updatecmd="mtd -r write - linux"
else
updatecmd="gunzip -c | tar -xf -"
fi
system=$(awk '/system type/ { print $5 }' /proc/cpuinfo 2>/dev/null)
check_exit() {
if [ $? -ne 0 ];then
echo "Update failed."
exit 1
fi
}
prepare() {
cd /
if [ -x /sbin/cfgfs ];then
umount -f /etc
fi
mount -o remount,rw /
if [ "$system" == "RB532" ];then
mount -t yaffs2 /dev/mtdblock0 /boot
elif [ "$system" == "FOXG20" ];then
mount -t vfat /dev/mmcblk0p1 /boot
fi
}
extract_from_file() {
prepare
cat $1 | eval $updatecmd
check_exit
}
extract_from_ssh() {
prepare
ssh $1 "cat $2" | eval $updatecmd
check_exit
}
extract_from_http() {
prepare
wget -O - $1 | eval $updatecmd
check_exit
}
case $1 in
file://*|/*)
url=$(echo $1|sed -e "s#file://##")
echo "Updating system from $1"
extract_from_file $url
;;
ssh://*)
host=$(echo $1|sed -e "s#ssh://\(.*\):.*#\1#")
file=$(echo $1|sed -e "s#ssh://.*:\(.*\)#\1#")
echo "Updating system from $1"
extract_from_ssh $host $file
;;
http://*|ftp://*)
echo "Updating system from $1"
extract_from_http $1
;;
*)
echo "No or wrong uri given. exit."
echo "Use one of the following uri:"
echo "http://myserver/myupdate.tar.gz"
echo "ssh://myuser@myserver:/my/path/myupdate.tar.gz"
echo "file:///mypath/myupdate.tar.gz"
exit 1
;;
esac
sync
if [ -x /sbin/cfgfs ];then
mount -o bind /etc /tmp/.cfgfs/root
fi
if [ "$system" == "RB532" ];then
umount -f /boot
elif [ "$system" == "FOXG20" ];then
umount -f /boot
fi
echo "Update sucessful. You should reboot now."
|