美文网首页
LAVA的编译与使用

LAVA的编译与使用

作者: YW23 | 来源:发表于2019-03-01 21:54 被阅读0次

一、LAVA简介

lava是一组用来评估漏洞检测工具的benchmark软件。

lava论文链接
lava下载地址

下载后,lava_corpus目录下有两组benchmark, 即LAVA-1, LAVA-M。本文主要介绍LAVA-M的编译。

二、LAVA-M的编译

LAVA-M包括四个软件:base64, md5sum, uniq, who
运行每个软件目录下的validate.sh脚本即可以成功编译已经嵌入了bug的软件。
以base64为例:
运行下面的命令即可将Bug嵌入到base64中,编译后的base64位于目录:lava_corpus/LAVA-M/base64/coreutils-8.24-lava-safe/lava-install/bin/中

$ cd LAVA-M/base64
$ ./validate.sh

在编译过程中如果有报错则可以考虑如下解决方案:

  1. 在运行./validate.sh的过程中,不要以root用户来运行(# ./validate.sh),, 而要以普通用户来运行($./validate.sh)。
  2. 需要安装 libacl, 命令为:
sudo apt-get install libacl1-dev
  1. validate.sh中的 --prefix要改为绝对路径,原脚本中提供的命令为
    ./configure --prefix=pwd/lava-install LIBS="-lacl" &> /dev/null
    如果编译不成功需要把'pwd'替换成绝对路径。

4、可以把make install 改为 sudo make install。

成功编译的结果为:


base64.png

对于Ubuntu系统来说,在32位上都可以成功编译,但是对于Ubuntu 16.04 64位的系统来说,在编译uniq时存在只能验证20/28个bugs.


uniq.png

这个问题是由于在64位的环境中, LAVA-M提供的输入并没有成功地触发所有28个嵌入的bugs。但是此时bug还是成功地嵌入到uniq这个软件中了。
并且我们发现LAVA-M中实际嵌入的bug数量是多于LAVA论文中所提到的。

软件 设计的bug数量 可能会触发的bug数量 LAVA输入可以触发的bug数量
base64 48 48 44
md5sum 61 61 57
who 2517 2467 2136
uniq 29 29 28

三、LAVA-M的使用

LAVA-M的四个软件中base64 和 md5sum是要加运行参数的,运行命令如下:

base64 -d $input
md5sum -c $input
who $input
uniq $input

相关文章

  • LAVA的编译与使用

    一、LAVA简介 lava是一组用来评估漏洞检测工具的benchmark软件。 lava论文链接lava下载地址 ...

  • LAVA编译和使用

    一、 LAVA下载、解压缩 lava下载后为tar.xz格式,解压缩方法: 二、LAVA内容 LAVA下有两个文...

  • AFL编译和使用LAVA_M

    使用AFL编译LAVA_M 在运行./validate.sh之前,设置CC和CXX的环境,运行命令: 可以通过en...

  • 夏威夷火山

    "Cascade of Lava" Lava Photos taken at Hawaii Volcanoes N...

  • lava

    http://www.lavaradio.com/m/program/7350?song_id=4707056

  • Swift--001:Swift编译 & SIL分析

    Swift与OC编译区别 swift与oc编译区别Swfit使用前端编译器swiftc,降级编译成IR,再通过后端...

  • Android编译与反编译相关命令

    由于经常使用到编译与反编译的相关命令,现将其记录下来以防忘记。 编译与反编译常用的命令。 1、解压APK 2、反编...

  • Engage in You

    As the wind yesterday, As the lava forever; That rolled u...

  • Jenkins(七)---jenkins项目编译测试发布由mav

    一、使用maven编译 (maven编译 与 测试 test 和打包 package 和 部署 install 类...

  • Xcode 10 ERROR:"...[CP] Cop

    Xcode 10报错 说明新版Xcode 默认使用New Build System编译,与旧版Xcode项目编译的...

网友评论

      本文标题:LAVA的编译与使用

      本文链接:https://www.haomeiwen.com/subject/azbjuqtx.html