X-Git-Url: https://git.enpas.org/?a=blobdiff_plain;f=package%2Fbase-files%2Ffiles%2Fsbin%2Fmount_root;h=033dfda29f6424e3ddb2db3db86ed0e46039c1ff;hb=bab04c244dd1758e3376ca1caaad7ca09706d2dc;hp=a77a7f645311b70966e15ac7b6e701e5b3a1b7cc;hpb=6853d4d1ef87e8740a293d7c8e548099dfce5949;p=openwrt.git diff --git a/package/base-files/files/sbin/mount_root b/package/base-files/files/sbin/mount_root index a77a7f6453..033dfda29f 100755 --- a/package/base-files/files/sbin/mount_root +++ b/package/base-files/files/sbin/mount_root @@ -1,59 +1,26 @@ #!/bin/sh -# Copyright (C) 2006 OpenWrt.org -. /etc/functions.sh +# Copyright (C) 2006-2010 OpenWrt.org +# Copyright (C) 2010 Vertical Communications -mount none /proc -t proc +# Initialize hook variables et by pulling in from preinit -size=$(awk '/MemTotal:/ {l=5242880;mt=($2*1024);print((s=mt/2) /dev/null; then - mount none /dev -t devfs - M0=/dev/pty/m0 - M1=/dev/pty/m1 - HOTPLUG=/sbin/hotplug-call -else - mount -t sysfs none /sys - mount -t tmpfs tmpfs /dev -o size=512K - mknod /dev/console c 5 1 - mkdir /dev/shm - /sbin/hotplug2 --no-persistent --coldplug --set-rules-file /etc/hotplug2-init.rules - M0=/dev/ptmx - M1=/dev/ptmx - HOTPLUG= -fi +. /lib/functions/boot.sh -mkdir -p /dev/pts /dev/shm -mount none /dev/pts -t devpts +for pi_source_file in /lib/preinit/*; do + . $pi_source_file +done -# the shell really doesn't like having stdin/out closed -# that's why we use /dev/pty/m0 and m1 as replacement -# for /dev/console if there's no serial console available -dd if=/dev/console of=/dev/null bs=1 count=0 >/dev/null 2>/dev/null || \ - exec <$M0 >$M1 2>&0 +# Override function that doesn't apply to use of mount_root as a command rather +# than as part of preinit -echo "$HOTPLUG" > /proc/sys/kernel/hotplug - -jffs2_ready () { - mtdpart="$(find_mtd_part rootfs_data)" - magic=$(hexdump $mtdpart -n 4 -e '4/1 "%02x"') - [ "$magic" != "deadc0de" ] +preinit_echo() { + echo "$@" } -[ failsafe != "$1" ] && { - grep rootfs_data /proc/mtd >/dev/null 2>/dev/null && { - . /bin/firstboot - mtd unlock rootfs_data - jffs2_ready && { - echo "switching to jffs2" - mount "$(find_mtd_part rootfs_data)" /jffs -t jffs2 && \ - fopivot /jffs /rom - } || { - echo "jffs2 not ready yet; using ramdisk" - ramoverlay - } - } || { - mtd unlock rootfs - mount -o remount,rw /dev/root / - } -} +boot_run_hook mount_root