Merged enhancements submitted by Stereo, thanks, closes #188 and #189
[openwrt.git] / openwrt / package / base-files / default / sbin / mount_root
index 32a6ee5..e855b41 100755 (executable)
@@ -1,10 +1,16 @@
 #!/bin/sh
 . /etc/nvram.sh
 #!/bin/sh
 . /etc/nvram.sh
+is_clean() {
+       grep Broadcom /proc/cpuinfo 2>&- >&- || return 0
+       OFFSET="$((0x$(dd if=/dev/mtdblock/1 bs=1 skip=$((0x14)) count=2 2>&- | hexdump | grep 0000000 | cut -d ' ' -f 2) - 1))"
+       dd if=/dev/mtdblock/1 bs=1 skip=$OFFSET count=1 2>&- | hexdump -v | grep ' 0000' > /dev/null && return 255 || return 0
+}
+
 if [ "$1" != "failsafe" ]; then 
        mount | grep jffs2 >&-
        if [ $? = 0 ] ; then
                if [ $(cat /proc/mtd | wc -l) = 6 ]; then
 if [ "$1" != "failsafe" ]; then 
        mount | grep jffs2 >&-
        if [ $? = 0 ] ; then
                if [ $(cat /proc/mtd | wc -l) = 6 ]; then
-                       [ -f /proc/sys/diag ] && echo 5 > /proc/sys/diag
+                       echo 5 > /proc/sys/diag
                        mtd unlock linux
                        mtd erase OpenWrt
                        jffs2root --move
                        mtd unlock linux
                        mtd erase OpenWrt
                        jffs2root --move
@@ -14,6 +20,11 @@ if [ "$1" != "failsafe" ]; then
                fi
        else
                if [ -z "$(nvram get no_root_swap)" ]; then
                fi
        else
                if [ -z "$(nvram get no_root_swap)" ]; then
+                       is_clean || {
+                               mtd erase OpenWrt
+                               mtd unlock linux
+                               jffs2root --clean
+                       }
                        mtd unlock OpenWrt
                        mount -t jffs2 /dev/mtdblock/4 /jffs
                        pivot_root /jffs /jffs/rom
                        mtd unlock OpenWrt
                        mount -t jffs2 /dev/mtdblock/4 /jffs
                        pivot_root /jffs /jffs/rom
This page took 0.022419 seconds and 4 git commands to generate.