博客
关于我
SymCC 使用教程
阅读量:472 次
发布时间:2019-03-06

本文共 1011 字,大约阅读时间需要 3 分钟。

SymCC 使用教程

项目介绍

SymCC 是一个基于 LLVM 的 C 和 C++ 编译器,它将混合执行(concolic execution)直接集成到二进制文件中。SymCC 可以作为 clang 和 clang++ 的替代品,用于软件开发。它通过编译时插入符号执行代码,显著提高了符号执行的速度,使其更接近原生执行速度。SymCC 是一个开源项目,遵循 GPL-3.0 许可证。

项目快速启动

安装依赖

在开始使用 SymCC 之前,需要确保系统中安装了必要的依赖项,包括 LLVM 和 Clang。可以通过以下命令安装这些依赖项:

sudo apt-get update
sudo apt-get install -y cmake llvm clang

克隆项目

首先,从 GitHub 克隆 SymCC 项目:

git clone https://github.com/eurecom-s3/symcc.git
cd symcc

构建项目

使用 CMake 构建 SymCC:

mkdir build
cd build
cmake -G "Unix Makefiles" ..
make

使用 SymCC 编译代码

使用 SymCC 编译 C 或 C++ 代码:

./symcc /path/to/your/source.c -o output

应用案例和最佳实践

应用案例

SymCC 可以用于各种安全相关的应用,例如:

  • 漏洞检测:通过符号执行分析程序路径,发现潜在的安全漏洞。
  • 模糊测试:结合模糊测试工具(如 AFL),提高测试覆盖率。

最佳实践

  • 结合 AFL 使用:SymCC 可以与 AFL(American Fuzzy Lop)结合使用,提高模糊测试的效率。
  • 优化编译选项:根据具体需求调整编译选项,以达到最佳性能。

典型生态项目

SymQEMU

SymQEMU 是一个基于 QEMU 的工具,它利用 SymCC 进行符号执行,扩展了 QEMU 的功能,使其能够执行符号执行。

LibAFL

LibAFL 是一个模糊测试库,支持与 SymCC 结合进行符号执行,提供了更强大的测试能力。

GNATfuzz

GNATfuzz 是一个 AdaCore 开发的工具,它集成了 SymCC,用于生成测试用例,提高代码覆盖率。

通过以上教程,您可以快速上手 SymCC,并了解其在安全领域的应用和相关生态项目。

转载地址:http://ximbz.baihongyu.com/

你可能感兴趣的文章
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>