Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0xricksanchez/afl_runner
AFLPlusPlus command generator to make the best use of multiple cores
https://github.com/0xricksanchez/afl_runner
afl aflplusplus fuzzer fuzzing multiprocessing multithreading tmux
Last synced: 2 months ago
JSON representation
AFLPlusPlus command generator to make the best use of multiple cores
- Host: GitHub
- URL: https://github.com/0xricksanchez/afl_runner
- Owner: 0xricksanchez
- Created: 2024-01-21T08:13:08.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-07T07:24:35.000Z (11 months ago)
- Last Synced: 2024-04-07T11:02:57.411Z (10 months ago)
- Topics: afl, aflplusplus, fuzzer, fuzzing, multiprocessing, multithreading, tmux
- Language: Rust
- Homepage: https://crates.io/crates/afl_runner
- Size: 26.4 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# AFL Runner
[![Crates.io](https://img.shields.io/crates/v/afl_runner.svg)](https://crates.io/crates/afl_runner)
[![License](https://img.shields.io/badge/license%20-%20Apache%202.0%20-%20blue)](LICENSE)`AFL_Runner` is a modern CLI tool designed to streamline running efficient multi-core [AFLPlusPlus](https://github.com/AFLplusplus/AFLplusplus) campaigns. The default configuration is based on the section [_Using multiple cores_](https://aflplus.plus/docs/fuzzing_in_depth/#c-using-multiple-cores) of the official documentation.
- [AFL Runner](#afl-runner)
- [Getting Started π](#getting-started-)
- [Prerequisites](#prerequisites)
- [Installation](#installation)
- [Features β¨](#features-)
- [What is not? β](#what-is-not-)
- [Roadmap πΊοΈ](#roadmap-)
- [Usage Example π‘](#usage-example-)
- [Showcase π₯](#showcase-)
- [Contributing π€](#contributing-)
- [License π](#license-)## Getting Started π
Currently, this tool should work on all \*NIX flavor operating-systems.
### Prerequisites
- [Rust (nightly) toolchain](https://www.rust-lang.org/tools/install) π¦
- [AFLPlusPlus](https://github.com/AFLplusplus/AFLplusplus)
- [pgrep](https://man7.org/linux/man-pages/man1/pgrep.1.html)
- [TMUX](https://github.com/tmux/tmux) || [screen](https://www.gnu.org/software/screen/) (Optional)### Installation
You can compile `AFL_Runner` yourself...:
```bash
git clone https://github.com/0xricksanchez/AFL_Runner.git
cd AFL_Runner
cargo build --release
./target/release/aflr --help
```...or install directly via [crates.io](https://crates.io/crates/afl_runner):
```bash
cargo install afl_runner
aflr --help
```## Features β¨
`AFL_Runner` allows you to set the most necessary AFLPlusplus flags and mimics the AFLplusplus syntax for these options:
- Supported AFLplusplus flags:
- [x] Corpus directory
- [x] Output directory
- [x] Dictionary file/directory
- [x] Custom `afl-fuzz` binary path for all instances
- [x] Supply arguments to target binary (including @@)
- [x] Amount of runner commands to generate
- [x] Support for \*SAN, CMPLOG, CMPCOV binaries- Other features:
- [x] `Tmux` or `screen` option to automatically create an appropriate layout for all runners
- [x] TUI
- [x] Provide a configuration file via `--config` to make sharing/storing per project configurations easier
- [x] Automatically read out a configuration named `aflr_cfg.toml` in the `CWD` when no `--config` was supplied_Note_: Arguments supplied over the command-line take precedence over any configuration file options.
### What is not? β
`AFL_Runner` aims to be a plug & play solution for when you're at a stage of fuzzing campaign where all that is left is running a multi-core setup.
So, this tool is **not** (yet) a helper for:- Compiling a target in multiple flavors
- Preparing a good initial seed corpus
- Providing a decent dictionary to boost code-coverage
- Debugging a fuzzing campaign### Roadmap πΊοΈ
- [ ] Add remote option π
- [ ] Native integration for [statsd](https://registry.hub.docker.com/r/prom/statsd-exporter)
- [ ] Add more configuration options
- [ ] Add more sensible defaults for other options
- [ ] Allow AFLPlusPlus forks to be used on some amount of runners## Usage Example π‘
Here's an example of generating AFL++ commands with `AFL_Runner`:
![AFL_Runner_cmd_gen](img/gen.gif)
_Note_: Supplying the \*SAN, CMPLOG, or CMPCOV binaries is optional and if omitted all invocations just contain the (mandatory) instrumented target instead.
## Showcase π₯
`AFL_Runner` also includes a terminal user interface (TUI) for monitoring the fuzzing campaign progress.
The following demo can be found in `examples/` and can be build locally by running `cargo make` from the root directory of the project.The example builds a recent version of _libxml2_ four times with different compile-time instrumentations:
1. plain AFL++ instrumentation
2. Address-Sanitizer (ASan)
3. CMPCOV, and
4. CMPLOG.Afterwards, the necessary commands for 16 instances are being generated, which then are executed in a dedicated TMUX session.
Finally, a custom TUI offered by \*_AFL Runner_ is tracking the progress of the fuzzing campaign in a centralized space:![AFL_Runner demo](img/demo.gif)
_Note_: The TUI can be used as a **full** replacement for `afl-whatsup` by using `afl_runner tui `!
## Contributing π€
Contributions are welcome! Please feel free to submit a pull request or open an issue for any bugs, feature requests, or improvements.
Any other support is also more than welcome :).## License π
This project is licensed under the Apache License. See the [LICENSE](LICENSE) file for details.
[πΌ Back to top](#afl-runner)