boot.sh 3.0 KB

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