X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/b96d21446846be7798eaa7db3cf314984d335407..e5a6579b59a0a071a183113be6a7ca44a2268fc6:/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 9a87fadba..eac4ef396 100755 --- a/package/base-files/files/sbin/mount_root +++ b/package/base-files/files/sbin/mount_root @@ -2,29 +2,55 @@ # Copyright (C) 2006 OpenWrt.org . /etc/functions.sh -mount none /proc -t proc -size=$(awk '/Mem:/ {l=5242880;print((s=$2/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/mdev -s + /sbin/hotplug2 --no-persistent --coldplug --set-rules-file /etc/hotplug2-init.rules + M0=/dev/ptmx + M1=/dev/ptmx + HOTPLUG= fi -mkdir -p /dev/pts + +mkdir -p /dev/pts /dev/shm mount none /dev/pts -t devpts +# 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 + +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" ] +} + [ 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 + 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 + 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 / + } || { + mtd unlock rootfs + mount -o remount,rw /dev/root / + } }