X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/3c976d44328e065945d327ed87ad4b03dc1ff8f4..cf7cf41639c0f70201b49d30be156ee18cd33ea3:/package/base-files/files/sbin/mount_root diff --git a/package/base-files/files/sbin/mount_root b/package/base-files/files/sbin/mount_root index f1d93bafc..2d73dac53 100755 --- a/package/base-files/files/sbin/mount_root +++ b/package/base-files/files/sbin/mount_root @@ -1,57 +1,26 @@ #!/bin/sh -# Copyright (C) 2006 OpenWrt.org -. /etc/functions.sh +# Copyright (C) 2006-2010 OpenWrt.org +# Copyright (C) 2010 Vertical Communications -mkdir -p /dev/pts /dev/shm -mount none /dev/pts -t devpts -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 -# 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 +for pi_source_file in /lib/preinit/*; do + . $pi_source_file +done -echo "$HOTPLUG" > /proc/sys/kernel/hotplug +# Override function that doesn't apply to use of mount_root as a command rather +# than as part of preinit -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 /proc/mtd >/dev/null 2>/dev/null && { - mtd unlock rootfs - grep rootfs_data /proc/mtd >/dev/null 2>/dev/null && { - . /bin/firstboot - 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 - } - } - } || mount -o remount,rw /dev/root / -} +boot_run_hook preinit_mount_root