boot.sh 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. #!/bin/sh
  2. # Copyright (C) 2006-2010 OpenWrt.org
  3. # Copyright (C) 2010 Vertical Communications
  4. mount() {
  5. /bin/busybox mount "$@"
  6. }
  7. boot_hook_splice_start() {
  8. export -n PI_HOOK_SPLICE=1
  9. }
  10. boot_hook_splice_finish() {
  11. local hook
  12. for hook in $PI_STACK_LIST; do
  13. local v; eval "v=\${${hook}_splice:+\$${hook}_splice }$hook"
  14. export -n "${hook}=${v% }"
  15. export -n "${hook}_splice="
  16. done
  17. export -n PI_HOOK_SPLICE=
  18. }
  19. boot_hook_init() {
  20. local hook="${1}_hook"
  21. export -n "PI_STACK_LIST=${PI_STACK_LIST:+$PI_STACK_LIST }$hook"
  22. export -n "$hook="
  23. }
  24. boot_hook_add() {
  25. local hook="${1}_hook${PI_HOOK_SPLICE:+_splice}"
  26. local func="${2}"
  27. [ -n "$func" ] && {
  28. local v; eval "v=\$$hook"
  29. export -n "$hook=${v:+$v }$func"
  30. }
  31. }
  32. boot_hook_shift() {
  33. local hook="${1}_hook"
  34. local rvar="${2}"
  35. local v; eval "v=\$$hook"
  36. [ -n "$v" ] && {
  37. local first="${v%% *}"
  38. [ "$v" != "${v#* }" ] && \
  39. export -n "$hook=${v#* }" || \
  40. export -n "$hook="
  41. export -n "$rvar=$first"
  42. return 0
  43. }
  44. return 1
  45. }
  46. boot_run_hook() {
  47. local hook="$1"
  48. local func
  49. while boot_hook_shift "$hook" func; do
  50. local ran; eval "ran=\$PI_RAN_$func"
  51. [ -n "$ran" ] || {
  52. export -n "PI_RAN_$func=1"
  53. $func "$1" "$2"
  54. }
  55. done
  56. }
  57. find_mtd_part() {
  58. local PART="$(grep "\"$1\"" /proc/mtd | awk -F: '{print $1}')"
  59. local PREFIX=/dev/mtdblock
  60. PART="${PART##mtd}"
  61. [ -d /dev/mtdblock ] && PREFIX=/dev/mtdblock/
  62. echo "${PART:+$PREFIX$PART}"
  63. }
  64. jffs2_ready () {
  65. mtdpart="$(find_mtd_part rootfs_data)"
  66. [ -z "$mtdpart" ] && return 1
  67. magic=$(hexdump $mtdpart -n 4 -e '4/1 "%02x"')
  68. [ "$magic" != "deadc0de" ]
  69. }
  70. dupe() { # <new_root> <old_root>
  71. cd $1
  72. echo -n "creating directories... "
  73. {
  74. cd $2
  75. find . -xdev -type d
  76. echo "./dev ./overlay ./mnt ./proc ./tmp"
  77. # xdev skips mounted directories
  78. cd $1
  79. } | xargs mkdir -p
  80. echo "done"
  81. echo -n "setting up symlinks... "
  82. for file in $(cd $2; find . -xdev -type f;); do
  83. case "$file" in
  84. ./rom/note) ;; #nothing
  85. ./etc/config*|\
  86. ./usr/lib/opkg/info/*) cp -af $2/$file $file;;
  87. *) ln -sf /rom/${file#./*} $file;;
  88. esac
  89. done
  90. for file in $(cd $2; find . -xdev -type l;); do
  91. cp -af $2/${file#./*} $file
  92. done
  93. echo "done"
  94. }
  95. pivot() { # <new_root> <old_root>
  96. mount -o move /proc $1/proc && \
  97. pivot_root $1 $1$2 && {
  98. mount -o move $2/dev /dev
  99. mount -o move $2/tmp /tmp
  100. mount -o move $2/sys /sys 2>&-
  101. mount -o move $2/overlay /overlay 2>&-
  102. return 0
  103. }
  104. }
  105. fopivot() { # <rw_root> <ro_root> <dupe?>
  106. root=$1
  107. {
  108. if grep -q mini_fo /proc/filesystems; then
  109. mount -t mini_fo -o base=/,sto=$1 "mini_fo:$1" /mnt 2>&- && root=/mnt
  110. else
  111. mount --bind / /mnt
  112. mount --bind -o union "$1" /mnt && root=/mnt
  113. fi
  114. } || {
  115. [ "$3" = "1" ] && {
  116. mount | grep "on $1 type" 2>&- 1>&- || mount -o bind $1 $1
  117. dupe $1 $rom
  118. }
  119. }
  120. pivot $root $2
  121. }
  122. ramoverlay() {
  123. mkdir -p /tmp/root
  124. mount -t tmpfs -o mode=0755 root /tmp/root
  125. fopivot /tmp/root /rom 1
  126. }