mirror of
https://github.com/ghostty-org/ghostty.git
synced 2026-04-06 07:38:21 +00:00
1.6 KiB
1.6 KiB
AFL++ Fuzzer for Libghostty
- Build all fuzzer with
zig build - The list of available fuzzers is in
build.zig(search forfuzzers). - Run a specific fuzzer with
zig build run-<name>(e.g.zig build run-parser) - Corpus directories follow the naming convention
corpus/<fuzzer>-<variant>(e.g.corpus/parser-initial,corpus/stream-cmin). - After running
afl-cmin/afl-tmin, runcorpus/sanitize-filenames.shbefore committing to replace colons with underscores (colons are invalid on Windows NTFS).
Important: stdin-based input
The instrumented binaries (afl.c harness) read fuzz input from stdin,
not from a file argument. This affects how you invoke AFL++ tools:
-
afl-fuzz: Uses shared-memory fuzzing automatically;@@works because AFL writes directly to shared memory, bypassing file I/O. -
afl-showmap: Must pipe input via stdin, not@@:cat testcase | afl-showmap -o map.txt -- zig-out/bin/fuzz-stream -
afl-cmin: Do not use@@. RequiresAFL_NO_FORKSRV=1with the bash version due to a bug in the Pythonafl-cmin(AFL++ 4.35c):AFL_NO_FORKSRV=1 /opt/homebrew/Cellar/afl++/4.35c/libexec/afl-cmin.bash \ -i afl-out/fuzz-stream/default/queue -o corpus/stream-cmin \ -- zig-out/bin/fuzz-stream -
afl-tmin: Also requiresAFL_NO_FORKSRV=1, no@@:AFL_NO_FORKSRV=1 afl-tmin -i <input> -o <output> -- zig-out/bin/fuzz-stream
If you pass @@ or a filename argument, afl-showmap/afl-cmin/afl-tmin
will see only ~4 tuples (the C main paths) and produce useless results.