X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/9c0d199275f54f1b1f1e972f6cdcda067c941e88..ff70f4cf192a562c664400e6c20d202b83aa1c14:/package/base-files/files/sbin/mount_root?ds=sidebyside diff --git a/package/base-files/files/sbin/mount_root b/package/base-files/files/sbin/mount_root index 1aa7db725..2d73dac53 100755 --- a/package/base-files/files/sbin/mount_root +++ b/package/base-files/files/sbin/mount_root @@ -1,58 +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 /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