rockchip: clk: rk3288: limit gpll and cpll init to SPL build
[oweals/u-boot.git] / test / fs / fs-test.sh
index 96158983aece637d0cd05b56863afc43ccdfe1dd..b19486419e9209dce3386ca56fbf7ab540b23bce 100755 (executable)
@@ -9,14 +9,14 @@
 # It currently tests the fs/sb and native commands for ext4 and fat partitions
 # Expected results are as follows:
 # EXT4 tests:
-# fs-test.sb.ext4.out: Summary: PASS: 17 FAIL: 2
-# fs-test.ext4.out: Summary: PASS: 10 FAIL: 9
-# fs-test.fs.ext4.out: Summary: PASS: 10 FAIL: 9
+# fs-test.sb.ext4.out: Summary: PASS: 23 FAIL: 0
+# fs-test.ext4.out: Summary: PASS: 23 FAIL: 0
+# fs-test.fs.ext4.out: Summary: PASS: 23 FAIL: 0
 # FAT tests:
-# fs-test.sb.fat.out: Summary: PASS: 17 FAIL: 2
-# fs-test.fat.out: Summary: PASS: 19 FAIL: 0
-# fs-test.fs.fat.out: Summary: PASS: 19 FAIL: 0
-# Total Summary: TOTAL PASS: 92 TOTAL FAIL: 22
+# fs-test.sb.fat.out: Summary: PASS: 23 FAIL: 0
+# fs-test.fat.out: Summary: PASS: 20 FAIL: 3
+# fs-test.fs.fat.out: Summary: PASS: 20 FAIL: 3
+# Total Summary: TOTAL PASS: 132 TOTAL FAIL: 6
 
 # pre-requisite binaries list.
 PREREQ_BINS="md5sum mkfs mount umount dd fallocate mkdir"
@@ -293,6 +293,29 @@ ${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_WRITE
 md5sum $addr \$filesize
 setenv filesize
 #
+
+# Next test case checks writing a file whose dirent
+# is the first in the block, which is always true for "."
+# The write should fail, but the lookup should work
+# Test Case 12 - Check directory traversal
+${PREFIX}${WRITE} host${SUFFIX} $addr ${FPATH}. 0x10
+
+# Read 1MB from small file
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_SMALL
+# Write it via "same directory", i.e. "." dirent
+# Test Case 13a - Check directory traversal
+${PREFIX}${WRITE} host${SUFFIX} $addr ${FPATH}./${FILE_WRITE}2 \$filesize
+mw.b $addr 00 100
+${PREFIX}load host${SUFFIX} $addr ${FPATH}./${FILE_WRITE}2
+# Test Case 13b - Check md5 of written to is same as the one read from
+md5sum $addr \$filesize
+setenv filesize
+mw.b $addr 00 100
+${PREFIX}load host${SUFFIX} $addr ${FPATH}${FILE_WRITE}2
+# Test Case 13c - Check md5 of written to is same as the one read from
+md5sum $addr \$filesize
+setenv filesize
+#
 reset
 
 EOF
@@ -329,9 +352,10 @@ function create_files() {
                        &> /dev/null
        fi
 
-       # Delete the small file which possibly is written as part of a
+       # Delete the small file copies which possibly are written as part of a
        # previous test.
        sudo rm -f "${MB1}.w"
+       sudo rm -f "${MB1}.w2"
 
        # Generate the md5sums of reads that we will test against small file
        dd if="${MB1}" bs=1M skip=0 count=1 2> /dev/null | md5sum > "$2"
@@ -386,7 +410,7 @@ check_md5() {
        # md5sum in u-boot has output of form:
        # md5 for 01000008 ... 01100007 ==> <md5>
        # the 7th field is the actual md5
-       md5_src=`grep -A3 "$1" "$2" | grep "md5 for" | tr -d '\r'`
+       md5_src=`grep -A2 "$1" "$2" | grep "md5 for" | tr -d '\r'`
        md5_src=($md5_src)
        md5_src=${md5_src[6]}
 
@@ -431,48 +455,60 @@ function check_results() {
        pass_fail "TC3: size of $4"
 
        # Check read full mb of 1MB.file
-       grep -A6 "Test Case 4a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 4a " "$1" | grep -q "filesize=100000"
        pass_fail "TC4: load of $3 size"
        check_md5 "Test Case 4b " "$1" "$2" 1 "TC4: load from $3"
 
        # Check first mb of 2.5GB.file
-       grep -A6 "Test Case 5a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 5a " "$1" | grep -q "filesize=100000"
        pass_fail "TC5: load of 1st MB from $4 size"
        check_md5 "Test Case 5b " "$1" "$2" 2 "TC5: load of 1st MB from $4"
 
        # Check last mb of 2.5GB.file
-       grep -A6 "Test Case 6a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 6a " "$1" | grep -q "filesize=100000"
        pass_fail "TC6: load of last MB from $4 size"
        check_md5 "Test Case 6b " "$1" "$2" 3 "TC6: load of last MB from $4"
 
        # Check last 1mb chunk of 2gb from 2.5GB file
-       grep -A6 "Test Case 7a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 7a " "$1" | grep -q "filesize=100000"
        pass_fail "TC7: load of last 1mb chunk of 2GB from $4 size"
        check_md5 "Test Case 7b " "$1" "$2" 4 \
                "TC7: load of last 1mb chunk of 2GB from $4"
 
        # Check first 1mb chunk after 2gb from 2.5GB file
-       grep -A6 "Test Case 8a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 8a " "$1" | grep -q "filesize=100000"
        pass_fail "TC8: load 1st MB chunk after 2GB from $4 size"
        check_md5 "Test Case 8b " "$1" "$2" 5 \
                "TC8: load 1st MB chunk after 2GB from $4"
 
        # Check 1mb chunk crossing the 2gb boundary from 2.5GB file
-       grep -A6 "Test Case 9a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 9a " "$1" | grep -q "filesize=100000"
        pass_fail "TC9: load 1MB chunk crossing 2GB boundary from $4 size"
        check_md5 "Test Case 9b " "$1" "$2" 6 \
                "TC9: load 1MB chunk crossing 2GB boundary from $4"
 
        # Check 2mb chunk from the last 1MB of 2.5GB file loads 1MB
-       grep -A6 "Test Case 10 " "$1" | grep -q "filesize=100000"
+       grep -A5 "Test Case 10 " "$1" | grep -q "filesize=100000"
        pass_fail "TC10: load 2MB from the last 1MB of $4 loads 1MB"
 
        # Check 1mb chunk write
-       grep -A3 "Test Case 11a " "$1" | \
-               egrep -q '1048576 bytes written|update journal'
+       grep -A2 "Test Case 11a " "$1" | grep -q '1048576 bytes written'
        pass_fail "TC11: 1MB write to $3.w - write succeeded"
        check_md5 "Test Case 11b " "$1" "$2" 1 \
                "TC11: 1MB write to $3.w - content verified"
+
+       # Check lookup of 'dot' directory
+       grep -A4 "Test Case 12 " "$1" | grep -q 'Unable to write file'
+       pass_fail "TC12: 1MB write to . - write denied"
+
+       # Check directory traversal
+       grep -A2 "Test Case 13a " "$1" | grep -q '1048576 bytes written'
+       pass_fail "TC13: 1MB write to ./$3.w2 - write succeeded"
+       check_md5 "Test Case 13b " "$1" "$2" 1 \
+               "TC13: 1MB read from ./$3.w2 - content verified"
+       check_md5 "Test Case 13c " "$1" "$2" 1 \
+               "TC13: 1MB read from $3.w2 - content verified"
+
        echo "** End $1"
 }
 
@@ -486,7 +522,12 @@ function test_fs_nonfs() {
        OUT_FILE="${OUT}.$1.${fs}.out"
        test_image $IMAGE $fs $SMALL_FILE $BIG_FILE $1 "" \
                > ${OUT_FILE} 2>&1
-       check_results $OUT_FILE $MD5_FILE_FS $SMALL_FILE $BIG_FILE
+       # strip out noise from fs code
+       grep -v -e "File System is consistent\|update journal finished" \
+               -e "reading .*\.file\|writing .*\.file.w" \
+               < ${OUT_FILE} > ${OUT_FILE}_clean
+       check_results ${OUT_FILE}_clean $MD5_FILE_FS $SMALL_FILE \
+               $BIG_FILE
        TOTAL_FAIL=$((TOTAL_FAIL + FAIL))
        TOTAL_PASS=$((TOTAL_PASS + PASS))
        echo "Summary: PASS: $PASS FAIL: $FAIL"