xref: /aosp_15_r20/external/e2fsprogs/tests/f_large_dir/script (revision 6a54128f25917bfc36a8a6e9d722c04a0b4641b6)
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