1*6a54128fSAndroid Build Coastguard WorkerOUT=$test_name.log 2*6a54128fSAndroid Build Coastguard WorkerEXP=$test_dir/expect 3*6a54128fSAndroid Build Coastguard WorkerE2FSCK=../e2fsck/e2fsck 4*6a54128fSAndroid Build Coastguard Worker 5*6a54128fSAndroid Build Coastguard WorkerNAMELEN=255 6*6a54128fSAndroid Build Coastguard WorkerDIRENT_SZ=8 7*6a54128fSAndroid Build Coastguard WorkerBLOCKSZ=1024 8*6a54128fSAndroid Build Coastguard WorkerINODESZ=128 9*6a54128fSAndroid Build Coastguard WorkerDIRENT_PER_LEAF=$((BLOCKSZ / (NAMELEN + DIRENT_SZ))) 10*6a54128fSAndroid Build Coastguard WorkerHEADER=32 11*6a54128fSAndroid Build Coastguard WorkerINDEX_SZ=8 12*6a54128fSAndroid Build Coastguard WorkerINDEX_L1=$(((BLOCKSZ - HEADER) / INDEX_SZ)) 13*6a54128fSAndroid Build Coastguard WorkerINDEX_L2=$(((BLOCKSZ - DIRENT_SZ) / INDEX_SZ)) 14*6a54128fSAndroid Build Coastguard WorkerDIRBLK=$((2 + INDEX_L1 * INDEX_L2)) 15*6a54128fSAndroid Build Coastguard WorkerENTRIES=$((DIRBLK * DIRENT_PER_LEAF)) 16*6a54128fSAndroid Build Coastguard WorkerEXT4_LINK_MAX=65000 17*6a54128fSAndroid Build Coastguard Workerif [ $ENTRIES -lt $((EXT4_LINK_MAX + 10)) ]; then 18*6a54128fSAndroid Build Coastguard Worker ENTRIES=$((EXT4_LINK_MAX + 10)) 19*6a54128fSAndroid Build Coastguard Worker DIRBLK=$((ENTRIES / DIRENT_PER_LEAF + 3)) 20*6a54128fSAndroid Build Coastguard Workerfi 21*6a54128fSAndroid Build Coastguard Worker# directory leaf blocks plus inode count and 25% for the rest of the fs 22*6a54128fSAndroid Build Coastguard WorkerFSIZE=$(((DIRBLK + EXT4_LINK_MAX * ((BLOCKSZ + INODESZ) / BLOCKSZ)) * 5 / 4)) 23*6a54128fSAndroid Build Coastguard Worker 24*6a54128fSAndroid Build Coastguard Worker$MKE2FS -b 1024 -O large_dir,uninit_bg -N $((ENTRIES + 50)) \ 25*6a54128fSAndroid Build Coastguard Worker -I $INODESZ -F $TMPFILE $FSIZE > $OUT.new 2>&1 26*6a54128fSAndroid Build Coastguard WorkerRC=$? 27*6a54128fSAndroid Build Coastguard Workerif [ $RC -eq 0 ]; then 28*6a54128fSAndroid Build Coastguard Worker{ 29*6a54128fSAndroid Build Coastguard Worker # First some initial fs setup to create indexed dir 30*6a54128fSAndroid Build Coastguard Worker echo "mkdir /foo" 31*6a54128fSAndroid Build Coastguard Worker echo "cd /foo" 32*6a54128fSAndroid Build Coastguard Worker touch $TMPFILE.tmp 33*6a54128fSAndroid Build Coastguard Worker echo "write $TMPFILE.tmp foofile" 34*6a54128fSAndroid Build Coastguard Worker i=0 35*6a54128fSAndroid Build Coastguard Worker while test $i -lt $DIRENT_PER_LEAF ; do 36*6a54128fSAndroid Build Coastguard Worker printf "mkdir d%0254u\n" $i 37*6a54128fSAndroid Build Coastguard Worker i=$((i + 1)); 38*6a54128fSAndroid Build Coastguard Worker done 39*6a54128fSAndroid Build Coastguard Worker echo "expand ./" 40*6a54128fSAndroid Build Coastguard Worker printf "mkdir d%0254u\n" $i 41*6a54128fSAndroid Build Coastguard Worker} | $DEBUGFS -w $TMPFILE > /dev/null 2>> $OUT.new 42*6a54128fSAndroid Build Coastguard Worker RC=$? 43*6a54128fSAndroid Build Coastguard Worker # e2fsck should optimize the dir to become indexed 44*6a54128fSAndroid Build Coastguard Worker $E2FSCK -yfD $TMPFILE >> $OUT.new 2>&1 45*6a54128fSAndroid Build Coastguard Worker status=$? 46*6a54128fSAndroid Build Coastguard Worker echo Exit status is $status >> $OUT.new 47*6a54128fSAndroid Build Coastguard Workerfi 48*6a54128fSAndroid Build Coastguard Worker 49*6a54128fSAndroid Build Coastguard Workerif [ $RC -eq 0 ]; then 50*6a54128fSAndroid Build Coastguard Worker{ 51*6a54128fSAndroid Build Coastguard Worker START=$SECONDS 52*6a54128fSAndroid Build Coastguard Worker i=$(($DIRENT_PER_LEAF+1)) 53*6a54128fSAndroid Build Coastguard Worker last=$i 54*6a54128fSAndroid Build Coastguard Worker echo "cd /foo" 55*6a54128fSAndroid Build Coastguard Worker while test $i -lt $ENTRIES ; do 56*6a54128fSAndroid Build Coastguard Worker ELAPSED=$((SECONDS - START)) 57*6a54128fSAndroid Build Coastguard Worker if test $((i % 5000)) -eq 0 -a $ELAPSED -gt 10; then 58*6a54128fSAndroid Build Coastguard Worker RATE=$(((i - last) / ELAPSED)) 59*6a54128fSAndroid Build Coastguard Worker echo "$test_name: $i/$ENTRIES links, ${ELAPSED}s @ $RATE/s" >&2 60*6a54128fSAndroid Build Coastguard Worker START=$SECONDS 61*6a54128fSAndroid Build Coastguard Worker last=$i 62*6a54128fSAndroid Build Coastguard Worker fi 63*6a54128fSAndroid Build Coastguard Worker if test $i -lt $((EXT4_LINK_MAX + 10)); then 64*6a54128fSAndroid Build Coastguard Worker printf "mkdir d%0254u\n" $i 65*6a54128fSAndroid Build Coastguard Worker else 66*6a54128fSAndroid Build Coastguard Worker printf "ln foofile f%0254u\n" $i 67*6a54128fSAndroid Build Coastguard Worker fi 68*6a54128fSAndroid Build Coastguard Worker i=$((i + 1)) 69*6a54128fSAndroid Build Coastguard Worker done 70*6a54128fSAndroid Build Coastguard Worker} | $DEBUGFS -w $TMPFILE > /dev/null 2>> $OUT.new 71*6a54128fSAndroid Build Coastguard Worker RC=$? 72*6a54128fSAndroid Build Coastguard Workerfi 73*6a54128fSAndroid Build Coastguard Worker 74*6a54128fSAndroid Build Coastguard Workerif [ $RC -eq 0 ]; then 75*6a54128fSAndroid Build Coastguard Worker $E2FSCK -yfD $TMPFILE >> $OUT.new 2>&1 76*6a54128fSAndroid Build Coastguard Worker status=$? 77*6a54128fSAndroid Build Coastguard Worker echo Exit status is $status >> $OUT.new 78*6a54128fSAndroid Build Coastguard Worker sed -f $cmd_dir/filter.sed -e "s;$TMPFILE;test.img;" $OUT.new > $OUT 79*6a54128fSAndroid Build Coastguard Worker rm -f $OUT.new 80*6a54128fSAndroid Build Coastguard Worker 81*6a54128fSAndroid Build Coastguard Worker cmp -s $OUT $EXP 82*6a54128fSAndroid Build Coastguard Worker RC=$? 83*6a54128fSAndroid Build Coastguard Workerfi 84*6a54128fSAndroid Build Coastguard Workerif [ $RC -eq 0 ]; then 85*6a54128fSAndroid Build Coastguard Worker echo "$test_name: $test_description: ok" 86*6a54128fSAndroid Build Coastguard Worker touch $test_name.ok 87*6a54128fSAndroid Build Coastguard Workerelse 88*6a54128fSAndroid Build Coastguard Worker echo "$test_name: $test_description: failed" 89*6a54128fSAndroid Build Coastguard Worker diff -u $EXP $OUT > $test_name.failed 90*6a54128fSAndroid Build Coastguard Workerfi 91