Skip to content
/ Fuzzing Public

Fuzzing tutorial with easy-to-learn labs ๐Ÿš€

License

Notifications You must be signed in to change notification settings

yuawn/Fuzzing

Repository files navigation

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