aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/spo_test.sh
blob: 219121499890efb500cf34cd6b33efe6f12fbb4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/bin/bash

MNT=/mnt/f2fs
DEV=/dev/sdb1
USER_DIR=/home/zeus
F2FS_DIR=$USER_DIR/f2fs_test

check_stop() {
	stop=`cat /tmp/stop`
	if [ $stop -eq 1 ]; then
		exit
	fi
}

case $1 in
start)
	echo 0 > /tmp/stop
	umount /mnt/*
	echo 3 > /proc/sys/vm/drop_caches
	echo 8 > /proc/sys/kernel/printk

	date >> $USER_DIR/por_result
	sync

	insmod $F2FS_DIR/src/fs/f2fs/f2fs.ko || exit

	echo Start checking F2FS without fsync
	check_stop
	fsck.f2fs $DEV -d 0 || exit
	mount -t f2fs -o disable_roll_forward $DEV $MNT || exit
	umount $MNT
	echo 3 > /proc/sys/vm/drop_caches

	echo Start checking F2FS with fsync
	check_stop
	fsck.f2fs $DEV -d 0 || exit
	mount -t f2fs $DEV $MNT || exit
	umount $MNT

	check_stop
	fsck.f2fs $DEV -d 0 || exit
	mount -t f2fs $DEV $MNT || exit

	count=`cat $USER_DIR/por_time`
	if [ $count -eq 20 ]; then
		echo Start rm all
		time rm -rf $MNT/* || exit
		echo 0 > $USER_DIR/por_time
		sync
	else
		echo $((count+1)) > $USER_DIR/por_time
	fi
	echo 8 > /proc/sys/kernel/printk
	echo Start fsstress
	date
	$F2FS_DIR/stress_test/fsstress/fsstress -z -f link=0 -f mkdir=3 -f mknod=3 -f rmdir=2 -f symlink=3 -f truncate=4 -f write=10 -f creat=10 -f unlink=5 -f rename=5 -f fsync=10 -p 10 -n 10000 -l 0 -d $MNT &
	RANDOM=`date '+%s'`
	rand=$[($RANDOM % 540) + 60]
	echo Start sleep: $rand seconds
	sleep $rand

	echo Reboot now
	check_stop
	echo b > /proc/sysrq-trigger
	;;
stop)
	killall -9 fsstress
	echo 1 > /tmp/stop
	;;
esac