Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rework Frida instrumentation to decouple it from FuzzerOptions and add FridaInstrumentationHelperBuilder #1523

Merged
merged 8 commits into from
Sep 20, 2023

Conversation

fabianfreyer
Copy link
Collaborator

Currently the Frida helper is very dependent on using the FuzzerOptions from libafl_bolts. However, there is no reason it has to be, and Frida mode should totally be usable without needing clap or the like.

@fabianfreyer fabianfreyer force-pushed the feat/rework-frida-helper branch 3 times, most recently from bd47c07 to de7d12f Compare September 19, 2023 20:52
Instead, keep the actual values that are needed. This allows us to make
a builder for FridaInstrumentationBuilder in a subsequent commit.
Mostly code movement here, sets up replacing `new` with a builder. The
one exception is the introduction of a lifetime bound on RT, which needs
to outlive the transformer. This could be generic, but there's probably
no reason to introduce an additional lifetime.

However, because of this lifetime introduction, this is _technically_ a
breaking change.
Instead of passing a slice of modules to instrument, and re-building the
modulemap, pass a Ref-counted module map directly to the initialization.
@fabianfreyer fabianfreyer force-pushed the feat/rework-frida-helper branch 3 times, most recently from 0e729f0 to c84b16b Compare September 19, 2023 21:49
@fabianfreyer fabianfreyer marked this pull request as ready for review September 19, 2023 21:49
@fabianfreyer fabianfreyer force-pushed the feat/rework-frida-helper branch 3 times, most recently from 61fc9db to ff6e06e Compare September 19, 2023 22:46
fabianfreyer and others added 4 commits September 20, 2023 01:34
Move all the initialization into Default::default with sensible defaults
and override parameters set from options in new.
The only option AsanError uses is whether to continue on error. Instead
of keeping a whole clone of the options around, just store that single
boolean value.
* Implement Default::default to get a good default AsanRuntime
@fabianfreyer fabianfreyer force-pushed the feat/rework-frida-helper branch from ff6e06e to 05e57f2 Compare September 19, 2023 23:34
@fabianfreyer fabianfreyer changed the title WIP: Rework Frida instrumentation to decouple it from FuzzerOptions Rework Frida instrumentation to decouple it from FuzzerOptions Sep 19, 2023
@domenukk domenukk requested a review from s1341 September 19, 2023 23:41
@fabianfreyer fabianfreyer changed the title Rework Frida instrumentation to decouple it from FuzzerOptions Rework Frida instrumentation to decouple it from FuzzerOptions and add FridaInstrumentationHelperBuilder Sep 19, 2023
@domenukk domenukk merged commit 7f0a4f1 into AFLplusplus:main Sep 20, 2023
@domenukk
Copy link
Member

Thank you!

@s1341
Copy link
Collaborator

s1341 commented Sep 21, 2023

Sorry didn't get a chance to review till now. Looks good!

domenukk pushed a commit that referenced this pull request Sep 27, 2023
* Fix frida libpng after PR1523

* fmt

* Fix

* Clippy
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants