diff options
3 files changed, 60 insertions, 34 deletions
diff --git a/meta/recipes-core/initrdscripts/initramfs-framework/finish b/meta/recipes-core/initrdscripts/initramfs-framework/finish index d09bbb8bed..717383ebac 100755 --- a/meta/recipes-core/initrdscripts/initramfs-framework/finish +++ b/meta/recipes-core/initrdscripts/initramfs-framework/finish | |||
@@ -8,39 +8,6 @@ finish_enabled() { | |||
8 | 8 | ||
9 | finish_run() { | 9 | finish_run() { |
10 | if [ -n "$ROOTFS_DIR" ]; then | 10 | if [ -n "$ROOTFS_DIR" ]; then |
11 | if [ -n "$bootparam_rootdelay" ]; then | ||
12 | debug "Sleeping for $rootdelay second(s) to wait root to settle..." | ||
13 | sleep $bootparam_rootdelay | ||
14 | fi | ||
15 | |||
16 | if [ -n "$bootparam_root" ]; then | ||
17 | debug "No e2fs compatible filesystem has been mounted, mounting $bootparam_root..." | ||
18 | |||
19 | if [ "`echo ${bootparam_root} | cut -c1-5`" = "UUID=" ]; then | ||
20 | root_uuid=`echo $bootparam_root | cut -c6-` | ||
21 | bootparam_root="/dev/disk/by-uuid/$root_uuid" | ||
22 | fi | ||
23 | |||
24 | if [ -e "$bootparam_root" ]; then | ||
25 | flags="" | ||
26 | if [ -n "$bootparam_ro" ]; then | ||
27 | if [ -n "$bootparam_rootflags" ]; then | ||
28 | bootparam_rootflags="$bootparam_rootflags," | ||
29 | fi | ||
30 | bootparam_rootflags="${bootparam_rootflags}ro" | ||
31 | fi | ||
32 | if [ -n "$bootparam_rootflags" ]; then | ||
33 | flags="$flags -o$bootparam_rootflags" | ||
34 | fi | ||
35 | if [ -n "$bootparam_rootfstype" ]; then | ||
36 | flags="$flags -t$bootparam_rootfstype" | ||
37 | fi | ||
38 | mount $flags $bootparam_root $ROOTFS_DIR | ||
39 | else | ||
40 | msg "root '$bootparam_root' doesn't exist." | ||
41 | fi | ||
42 | fi | ||
43 | |||
44 | if [ ! -d $ROOTFS_DIR/dev ]; then | 11 | if [ ! -d $ROOTFS_DIR/dev ]; then |
45 | fatal "ERROR: There's no '/dev' on rootfs." | 12 | fatal "ERROR: There's no '/dev' on rootfs." |
46 | fi | 13 | fi |
diff --git a/meta/recipes-core/initrdscripts/initramfs-framework/rootfs b/meta/recipes-core/initrdscripts/initramfs-framework/rootfs new file mode 100644 index 0000000000..5790d8cb8b --- /dev/null +++ b/meta/recipes-core/initrdscripts/initramfs-framework/rootfs | |||
@@ -0,0 +1,57 @@ | |||
1 | #!/bin/sh | ||
2 | # Copyright (C) 2011 O.S. Systems Software LTDA. | ||
3 | # Licensed on MIT | ||
4 | |||
5 | rootfs_enabled() { | ||
6 | return 0 | ||
7 | } | ||
8 | |||
9 | rootfs_run() { | ||
10 | if [ -z "$ROOTFS_DIR" ]; then | ||
11 | return | ||
12 | fi | ||
13 | C=0 | ||
14 | delay=${bootparam_rootdelay:-1} | ||
15 | timeout=${bootparam_roottimeout:-5} | ||
16 | while [ ! -d $ROOTFS_DIR/dev ]; do | ||
17 | if [ $(( $C * $delay )) -gt $timeout ]; then | ||
18 | fatal "root '$bootparam_root' doesn't exist or does not contain a /dev." | ||
19 | fi | ||
20 | |||
21 | if [ -n "$bootparam_root" ]; then | ||
22 | debug "No e2fs compatible filesystem has been mounted, mounting $bootparam_root..." | ||
23 | |||
24 | if [ "`echo ${bootparam_root} | cut -c1-5`" = "UUID=" ]; then | ||
25 | root_uuid=`echo $bootparam_root | cut -c6-` | ||
26 | bootparam_root="/dev/disk/by-uuid/$root_uuid" | ||
27 | fi | ||
28 | |||
29 | if [ -e "$bootparam_root" ]; then | ||
30 | flags="" | ||
31 | if [ -n "$bootparam_ro" ] && ! echo "$bootparam_rootflags" | grep -w -q "ro"; then | ||
32 | if [ -n "$bootparam_rootflags" ]; then | ||
33 | bootparam_rootflags="$bootparam_rootflags," | ||
34 | fi | ||
35 | bootparam_rootflags="${bootparam_rootflags}ro" | ||
36 | fi | ||
37 | if [ -n "$bootparam_rootflags" ]; then | ||
38 | flags="$flags -o$bootparam_rootflags" | ||
39 | fi | ||
40 | if [ -n "$bootparam_rootfstype" ]; then | ||
41 | flags="$flags -t$bootparam_rootfstype" | ||
42 | fi | ||
43 | mount $flags $bootparam_root $ROOTFS_DIR | ||
44 | if [ -d $ROOTFS_DIR/dev ]; then | ||
45 | break | ||
46 | else | ||
47 | # It is unlikely to change, but keep trying anyway. | ||
48 | # Perhaps we pick a different device next time. | ||
49 | umount $ROOTFS_DIR | ||
50 | fi | ||
51 | fi | ||
52 | fi | ||
53 | debug "Sleeping for $delay second(s) to wait root to settle..." | ||
54 | sleep $delay | ||
55 | C=$(( $C + 1 )) | ||
56 | done | ||
57 | } | ||
diff --git a/meta/recipes-core/initrdscripts/initramfs-framework_1.0.bb b/meta/recipes-core/initrdscripts/initramfs-framework_1.0.bb index e5cf9cb4dd..89e153d348 100644 --- a/meta/recipes-core/initrdscripts/initramfs-framework_1.0.bb +++ b/meta/recipes-core/initrdscripts/initramfs-framework_1.0.bb | |||
@@ -8,6 +8,7 @@ PR = "r2" | |||
8 | inherit allarch | 8 | inherit allarch |
9 | 9 | ||
10 | SRC_URI = "file://init \ | 10 | SRC_URI = "file://init \ |
11 | file://rootfs \ | ||
11 | file://finish \ | 12 | file://finish \ |
12 | file://mdev \ | 13 | file://mdev \ |
13 | file://udev \ | 14 | file://udev \ |
@@ -21,6 +22,7 @@ do_install() { | |||
21 | 22 | ||
22 | # base | 23 | # base |
23 | install -m 0755 ${WORKDIR}/init ${D}/init | 24 | install -m 0755 ${WORKDIR}/init ${D}/init |
25 | install -m 0755 ${WORKDIR}/rootfs ${D}/init.d/90-rootfs | ||
24 | install -m 0755 ${WORKDIR}/finish ${D}/init.d/99-finish | 26 | install -m 0755 ${WORKDIR}/finish ${D}/init.d/99-finish |
25 | 27 | ||
26 | # mdev | 28 | # mdev |
@@ -47,7 +49,7 @@ PACKAGES = "${PN}-base \ | |||
47 | initramfs-module-e2fs \ | 49 | initramfs-module-e2fs \ |
48 | initramfs-module-debug" | 50 | initramfs-module-debug" |
49 | 51 | ||
50 | FILES_${PN}-base = "/init /init.d/99-finish /dev" | 52 | FILES_${PN}-base = "/init /init.d/90-rootfs /init.d/99-finish /dev" |
51 | 53 | ||
52 | SUMMARY_initramfs-module-mdev = "initramfs support for mdev" | 54 | SUMMARY_initramfs-module-mdev = "initramfs support for mdev" |
53 | RDEPENDS_initramfs-module-mdev = "${PN}-base busybox-mdev" | 55 | RDEPENDS_initramfs-module-mdev = "${PN}-base busybox-mdev" |