mirror of
https://github.com/ghostty-org/ghostty.git
synced 2026-04-20 14:25:19 +00:00
1.4 KiB
1.4 KiB
AFL++ Fuzzer for Libghostty
- Fuzz targets:
fuzz-vt-parserandfuzz-vt-stream - Build all targets with
zig build - 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-vt-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-vt-stream/default/queue -o corpus/vt-stream-cmin \ -- zig-out/bin/fuzz-vt-stream -
afl-tmin: Also requiresAFL_NO_FORKSRV=1, no@@:AFL_NO_FORKSRV=1 afl-tmin -i <input> -o <output> -- zig-out/bin/fuzz-vt-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.