Stream: cranelift

Topic: oss-fuzz for regalloc.rs?


view this post on Zulip Chris Fallin (Nov 18 2020 at 22:17):

Hi all -- I'm looking at how to strengthen the fuzzing story for the new CL backend. As part of this, I think we should be running the regalloc checker-based fuzz targets on some continuous basis. Wasmtime is already on Google's oss-fuzz but a targeted setup for regalloc with the specific dataflow-checker oracle would be much more powerful, I think.

So, what do folks think about applying to have regalloc.rs a part of oss-fuzz? cc @fitzgen (he/him) @Benjamin Bouvier @Julian Seward

Modular register allocator algorithms. Contribute to bytecodealliance/regalloc.rs development by creating an account on GitHub.
Modular register allocator algorithms. Contribute to bytecodealliance/regalloc.rs development by creating an account on GitHub.
OSS-Fuzz - continuous fuzzing of open source software. - google/oss-fuzz

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:18):

if we are already moving regalloc.rs into the same repo, I think it makes more sense to just wait for that to happen, at which point we should get the fuzzing on oss-fuzz naturally

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:19):

Ah, so I think the latest story on that is that we want to keep it in a separate crate

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:19):

(we will have to move the fuzz target definitions themselves into the top level fuzz crate. the actual fuzz target definition can simply be a function call to the "real" fuzz target, similar to a bunch of our existing fuzz targets work)

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:19):

oh for sure, it can still be a separate crate, but are we rethinking including it in the repo?

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:20):

err, sorry, s/crate/repo/

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:20):

I believe the main concerns were CI time and appearance of independence/reusability

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:20):

in that case it probably makes sense to copy what we do for the wasm-tools fuzz targets

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:21):

They shoehorn into wasmtime's oss-fuzz allocation somehow?

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:22):

OSS-Fuzz - continuous fuzzing of open source software. - google/oss-fuzz
OSS-Fuzz - continuous fuzzing of open source software. - google/oss-fuzz

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:23):

Excellent, this answers many questions, thanks! (I wasn't sure whether it would be ok to piggyback on wasmtime's fuzz time within the spirit of the rules but I suppose we use it anyway so this just targets fuzzing more precisely)

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:24):

as an aside, while you're here -- do we have a good differential-fuzzing story for wasmtime yet? (I've just started digging through all the configs/targets)

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:24):

we have something set up but it hasn't really found anything

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:25):

I'd love to do old-backend vs. new-backend and new-backend vs. native (or at least the latter)

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:25):

I think it is hard to use just coverage to guide differential fuzzing, I don't know

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:25):

hmm, yeah, I haven't played with this too much before either

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:25):

anyway I'll keep digging -- thanks!

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:25):

https://github.com/bytecodealliance/wasmtime/blob/main/crates/fuzzing/src/oracles.rs#L119

Standalone JIT-style runtime for WebAssembly, using Cranelift - bytecodealliance/wasmtime

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:27):

to reuse this approach with new vs old backend, we would need a way to compile both the old and new backends and be able to choose on a per-module basis which one we were using

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:28):

Yes, I suppose I was envisioning something much hackier that would drive two wasmtime binaries from a shell script and compare outputs, or something like that

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:28):

I think one would need something similar for wasmtime vs. native

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:29):

iirc this is how csmith-based fuzzing works but I haven't looked at that in a long time...?

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:30):

yeah that would probably be better than exposing backends in our config, but it also doesn't really fit into the oss-fuzz model, which is essentially "we give them a libfuzzer-using binary" and doesn't really work well with external processes

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:32):

yeah, I don't think you can link csmith as a library, I think you have to spawn it. maybe worth doing a quick grep over oss-fuzz to see if anything is using csmith, and if so then we could probably spawn our own processes too

view this post on Zulip fitzgen (he/him) (Nov 18 2020 at 22:32):

would ideally have something running in-process so that libfuzzer gets that coverage feedback

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:33):

I suppose one could shell out to csmith and the compiler and then dlopen the result for the native half of the comparison

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:33):

compilation happens in toplevel process so all the coverage guidance is driven at least from that

view this post on Zulip Chris Fallin (Nov 18 2020 at 22:34):

ok, I'll play with this more (and look at what other folks may be doing). thanks!

view this post on Zulip Alex Crichton (Nov 18 2020 at 22:40):

Adding regalloc to our config should be pretty easy, I'd recommend modeling after what wasm-tools is doing

view this post on Zulip Alex Crichton (Nov 18 2020 at 22:41):

for diffing the old/new backend I think that'd be pretty easy so long as they were both compiled into cranelift, we'd need some sort of Config option to select and you could diff the result of two Instances within two stores

view this post on Zulip Alex Crichton (Nov 18 2020 at 22:41):

one store with the old backend and one with the new

view this post on Zulip Chris Fallin (Nov 18 2020 at 23:00):

Hmm, actually, I think this is the best way to go -- differential execution-backend-X on different Stores; we could diff against a wasm bytecode-level interpreter at some point, too. Would certainly give more throughput than shelling out to a compiler

view this post on Zulip Benjamin Bouvier (Nov 19 2020 at 07:37):

+1 for fuzzing regalloc, thanks! (Maybe disable the linear scan fuzz target first; while it appears to be working, it's still experimental and i'd like to play with it more and change core parts of the algorithm.)

view this post on Zulip Benjamin Bouvier (Nov 19 2020 at 07:38):

Regarding differential fuzzing, maybe there'll be some hardship if you want to compile old-x64 vs new-x64, because of the experimental_x64 feature.

view this post on Zulip Benjamin Bouvier (Nov 19 2020 at 07:39):

And on the same topic of using that experimental_x64 feature: has the wasmtime fuzzing been done with this feature enabled, on ossfuzz? It could probably find a few issues, if it hasn't ever been enabld.

view this post on Zulip Alex Crichton (Nov 19 2020 at 16:01):

We don't have experimental_x64 on oss-fuzz yet, no

view this post on Zulip Alex Crichton (Nov 19 2020 at 16:02):

being a cargo feature instead of a runtime feature we'd have to build the binaries twice I believe, which would just be an edit to the oss-fuzz build script


Last updated: Jan 24 2025 at 00:11 UTC