-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreadme.txt
51 lines (43 loc) · 1.65 KB
/
readme.txt
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
"Try .so fuzzing and mesure code coverage!"
1. Build
# make
# echo a | LD_LIBRARY_PATH=./ ./hello
# make clean
2. AFL
# make libpathcov.so fuzzer CC=afl-gcc
# LD_LIBRARY_PATH=./ afl-fuzz -m none -i ./fuzz/in -o ./out -- ./fuzz/fuzzer
3. AFL@Docker
# docker build -t fz:1 .
# docker run -itd --privileged --name fz fz:1
# docker exec -it fz /bin/bash -c "echo core >/proc/sys/kernel/core_pattern"
# docker exec -it fz /bin/bash -c "echo performance | tee cpu*/cpufreq/scaling_governor"
# docker exec -it fz /root/AFL/afl-fuzz -m none -i /root/pathcov/fuzz/in -o /root/out -- /root/pathcov/fuzz/fuzzer
# docker cp fz:/root/out .
4. Libfuzzer
# make libpathcov.so fuzzer0 CC=clang
# LD_LIBRARY_PATH=./ ./fuzzer0 >/dev/null -max_total_time=30 -print_final_stats=1
5. Libfuzzer@Docker
# docker build -t fz:0 .
6. カバレッジ計測について
6.1 AFL
・前提
- カレントディレクトリがpathcovディレクトリ
- 検出したテストケースがout/queue/id*に格納されている
- lcovをインストール済み
$ sudo apt install lcov
・カバレッジ計測用にビルドし直すため、
$ rm ./libpathcov.so
・makefileの3行目のコメントアウトを削除
CFLAG = -g -Wall -fprofile-arcs -ftest-coverage -coverage
・以下のようにビルドを実行
$ make
・キュー内の全てのテストケースを実行
$ for tc in ./out/queue/*; do cat $tc | LD_LIBRARY_PATH=./ ./hello; done
・LCOVでカバレッジ情報をHTMLとして出力
$ lcov -c -d . -o cov.info
$ genhtml -o cov cov.info
・Webブラウザで出力結果を確認
$ firefox ./cov/index.html
6.2 Libfuzzer
・(検討中)
/verifsec