• Stars
    star
    153
  • Rank 243,368 (Top 5 %)
  • Language
    C++
  • License
    MIT License
  • Created over 2 years ago
  • Updated about 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Fuzzing tutorial with easy-to-learn labs 🚀

Fuzzing

Fuzzing tutorial with easy to learn labs.

Lessons

Lesson keyword Lab
Lesson 00 - Fuzzing with AFL++ afl-cc, afl-clang-lto, fuzzing ✅
Lesson 01 - Use sanitizer to catch silent bugs AddressSanitizer(ASAN) ✅
Lesson 02 - Improve code coverage using dictionary dictionary, branch constraint, split-comparison ✅
Lesson 03 - Parallel fuzzing: combine the advantages of each fuzzer parallel fuzzing, seed pool syncing ✅
Lesson 04 - Increase fuzzing performance by persistent mode fuzzing harness, persistent mode ✅
Lesson 05 - Write a LLVM Pass to do binary instrumentation LLVM Pass, binary instrumentation ✅
Lesson 06 - Integrate custom LLVM Pass into AFL++ custom LLVM Pass in AFL++, integration example ✅
Lesson 07 - Playing symbolic execution on a maze with KLEE symbolic execution, KLEE ✅

Setup

./setup.sh
make

Environment

Name Version
Ubuntu 20.04, 22.04
LLVM (clang, lld) 14.0.6
AFL++ 4.01c
KLEE v2.3