This fixes issues mainly seen when mounting eMMC devices:

The wildcard /sys/block/${DEVBASE}/${DEVBASE}*1 matches both "mmcblk0p1"
and "mmcblk0boot1" for example, and this results in syntax errors. Fix this
by searching for a "partition" file instead, which only exists for real
partitions and not 'fakes' like the eMMC extra's.

When mount fails, the mountpoint file is left behind, causing later attempts
at auto-mounting it to fail. If mount fails, remove the mountpoint, leaving
the system in the state as it was before the mount attempt.

Signed-off-by: Mike Looijmans <[email protected]>
---
 meta/recipes-core/busybox/files/mdev-mount.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/meta/recipes-core/busybox/files/mdev-mount.sh 
b/meta/recipes-core/busybox/files/mdev-mount.sh
index b4385a1..130e947 100644
--- a/meta/recipes-core/busybox/files/mdev-mount.sh
+++ b/meta/recipes-core/busybox/files/mdev-mount.sh
@@ -25,7 +25,7 @@ case "$ACTION" in
                fi
                # check for full-disk partition
                if [ "${DEVBASE}" = "${MDEV}" ] ; then
-                       if [ -d /sys/block/${DEVBASE}/${DEVBASE}*1 ] ; then
+                       if [ -f /sys/block/${DEVBASE}/${DEVBASE}*1/partition ] 
; then
                                # Partition detected, just quit
                                exit 0
                        fi
@@ -43,7 +43,7 @@ case "$ACTION" in
                then
                        MOUNTPOINT="${MDEV_AUTOMOUNT_ROOT}/$MDEV"
                        mkdir -p "$MOUNTPOINT"
-                       mount -t auto /dev/$MDEV "$MOUNTPOINT"
+                       mount -t auto /dev/$MDEV "$MOUNTPOINT" || rmdir 
"$MOUNTPOINT"
                fi
                ;;
        remove)
-- 
1.9.1

-- 
_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.openembedded.org/mailman/listinfo/openembedded-core

Reply via email to