【AFL(十五)】LAVA-M服务器篇
最近写论文要用LAVA-M做测试集,但是遇到一个问题,在虚拟机成功的步骤在服务器却不行了,也就是之前的那两篇LAVA-M文章,最后得到原因是root模式下LAVA-M的自动化脚本不可用。
1. 进入 coreutils-8.24-lava-safe 文件夹:
然后配置环境,这里需要注意,一定要按照下面的命令(特别是加粗的部分):
CC=afl-gcc CXX=afl-g++ ./configure --prefix=`pwd`/lava-install LIBS="-lacl" FORCE_UNSAFE_CONFIGURE=1
否则有可能配置报错,如果这一步是ok的,后面就没什么问题了。
2. 编译
make (-j 12)
括号内的如果有多线程就加上,没有就去掉括号内的东西
3. 安装
make install
到这里基本就完成了,再用原来安装脚本的后半段进行测试
4. 测试
#!/bin/bash PROG="base64" PROGOPT="-d" INPUT_PATTERN="inputs/utmp-fuzzed-%s.b64" INPUT_CLEAN="inputs/utmp.b64" echo "Validating bugs..." cat validated_bugs | while read line ; do INPUT_FUZZ=$(printf "$INPUT_PATTERN" $line) { ./coreutils-8.24-lava-safe/lava-install/bin/${PROG} ${PROGOPT} ${INPUT_FUZZ} ; } &> /dev/null echo $line $? done > validated.txt awk 'BEGIN {valid = 0} $2 > 128 { valid += 1 } END { print "Validated", valid, "/", NR, "bugs" }' validated.txt echo "You can see validated.txt for the exit code of each buggy version."
放到一个单独的sh文件,并运行,(跟coreutils-8.24-lava-safe文件夹同级)
显示44/44就代表安装成功,0/44就是失败