SanitizerCoverage(SanCov)是 LLVM 提供的轻量级覆盖率反馈机制,通过 -fsanitize-coverage=trace-pc-guard 编译插桩,为 libFuzzer 提供基本块/边缘覆盖信息,需用 clang 编译、安全解析输入、关注 cov/ft 指标并可结合 llvm-cov 生成报告。

在 C++ 模糊测试中,SanitizerCoverage(即 SanCov)是 LLVM 提供的轻量级、低开销覆盖率反馈机制,它不依赖外部插桩工具(如 AFL 的 afl-clang-fast),而是通过编译器内置支持,为 libFuzzer 等基于覆盖率的模糊器提供基本块(Basic Block)、边缘(Edge)或函数级覆盖信息。它不是独立 fuzzing 工具,而是 libFuzzer 的“眼睛”——让模糊器知道“哪里还没跑过”,从而智能变异输入。
关键在于用 clang++(推荐 clang 12+)开启 -fsanitize-coverage=trace-pc-guard,这是 libFuzzer 推荐的模式,平衡精度与性能:
-O2(优化不影响 coverage 插桩)和 -g(便于调试崩溃);-fno-omit-frame-pointer(某些 sanitizer 模式需要,libFuzzer 默认要求);示例编译命令:
clang++ -O2 -g -fsanitize=address,undefined \ -fsanitize-coverage=trace-pc-guard \ -stdlib=libc++ \ target.cpp \ -o target_fuzz \ /path/to/libFuzzer.a
入口函数必须严格为 extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size),且不能调用 exit()、printf()(除非重定向)等干扰 fuzz loop 的操作:
立即学习“C++免费学习笔记(深入)”;
Size 做边界检查,避免越界读;__builtin_trap() 或 abort() 手动标记逻辑错误(如解析出非法状态);static 局部变量或 LLVMFuzzerInitialize 回调中,避免每次调用重复开销。libFuzzer 运行时会实时打印覆盖率相关指标,重点关注 cov: N(已覆盖基本块数)和 ft: M(新发现的转化路径数):
-print_final_stats=1 查看总覆盖块数、执行速度(execs/sec);-use_value_profile=1 启用值轮廓(Value Profile),提升对分支条件(如 if (x == 0xdeadbeef))的敏感度;-runs=1000000 或 -max_total_time=3600 控制资源;crash-* 文件中,超时/内存泄漏分别存为 timeout-* / leak-*。提示:若 cov 长期不增长,说明输入空间未有效探索——检查 fuzz target 是否过早返回、是否遗漏关键分支、或是否存在强校验(如 magic header)阻碍变异。
SanCov 支持细粒度控制,可通过编译选项调整反馈粒度:
trace-pc:轻量但易受 inline 影响;trace-pc-guard(推荐)更稳定;trace-cmp + use_value_profile 可捕获比较操作的常量值;__attribute__((no_sanitize_coverage)) 标记不希望插桩的函数(如日志、监控代码);llvm-cov 生成 HTML 覆盖率报告:llvm-cov show ./target_fuzz -instr-profile=default.profdata(需先运行时加 -dump_coverage=1 生成 profdata);-max_total_time=60 快速验证回归,配合 -detect_leaks=1 检查内存泄漏。基本上就这些。SanitizerCoverage 本身不复杂,但容易忽略编译一致性、输入安全边界和反馈信号解读——真正发挥价值,在于让模糊器“看得更清”,而不是“跑得更快”。
以上就是c++++如何使用SanitizerCoverage进行覆盖率引导的模糊测试_c++ Fuzzing进阶【安全】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号