Stream: git-wasmtime

Topic: wasmtime / issue #5181 Cranelift: use egraphs by default


view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 16:21):

fitzgen opened issue #5181:

It should be enabled by default. We should also define what the requirements we need to meet to enable it by default are.

cc @cfallin @jameysharp

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 16:21):

fitzgen labeled issue #5181:

It should be enabled by default. We should also define what the requirements we need to meet to enable it by default are.

cc @cfallin @jameysharp

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 16:21):

fitzgen labeled issue #5181:

It should be enabled by default. We should also define what the requirements we need to meet to enable it by default are.

cc @cfallin @jameysharp

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 17:15):

jameysharp commented on issue #5181:

As far as I know there are two specific reasons we haven't done this yet:

  1. Compile speed regresses a little bit with egraphs turned on.
  2. We were encountering some fuzzing failures.

We have some ideas that might get the egraphs optimizer to parity with the current implementation and we want to play with those.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 17:25):

cfallin commented on issue #5181:

Indeed; to add a little more, the overall approach I want to take is to integrate the egraph data structure more completely into the DataFlowGraph. Basically, the PrimaryMap of ValueDefs can take the place of the "eclass nodes" in cranelift-egraph currently: alongside the other kinds of defs (instruction output, blockparam, alias), we can have a "union" kind. Then the multi-definition aspect of the aegraph can be represented directly in the CLIF.

Then the only other difference is that we can take "pure" insts and not place them in blocks before elaboration. So the egraph-mode becomes:

There are a bunch of nice outcomes from that (and once I saw it, I realized we basically must go this way, and a separate egraph doesn't make sense anymore):

I want to build all of this first, and suspect that when I do, the perf regressions we're seeing should go away. The reason for holding back before then is both because of the regression but also because if the design is going to change, we should do that before we rely on it as the default path.

I'm currently 100%-coding-time on another project but will hopefully be able to come back to this sometime soon-ish; @jameysharp and I have talked about collaborating on its implementation as well.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 17:44):

bjorn3 commented on issue #5181:

Would it be possible to replace Layout with a different type while the function is in aegraph form, but keep DataFlowGraph in both cases? This would extend to more alternative representations like VSDG/sea of nodes or something with structured control flow (for eg wasm or spirv generation) with minimal (or no) changes to the core ir while at the same time minimizing code duplication.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 02 2022 at 17:47):

cfallin commented on issue #5181:

Yep, we could go further in that direction as well; that's an interesting direction to explore.

view this post on Zulip Wasmtime GitHub notifications bot (Jan 19 2023 at 23:46):

cfallin closed issue #5181:

It should be enabled by default. We should also define what the requirements we need to meet to enable it by default are.

cc @cfallin @jameysharp


Last updated: Jan 24 2025 at 00:11 UTC