cfallin labeled issue #1090:
I think cranelift-preopt was separated from cranelift-codegen because we assume that, in general, the input IR has been generated by an optimizing compiler (namely, one that ran constant folding). This being said, in our use case, when translating wasm to clif, we're likely to introduce redundancies and constant-foldable instructions that aren't obvious to catch (because we're operating on one wasm binary opcode at a time). There was also another instance of constant-foldable operations being emitted by legalization recently.
In principle, every pass that takes IR and augments it (by adding more IR nodes) is likely to introduce redundancies / constant-foldable instructions. I'd like someone to get more data on this, but how would people feel about putting the cranelift-preopt constant folding facilities into codegen instead?
bjorn3 commented on issue #1090:
This could be merged into the egraph impl, right?
jameysharp commented on issue #1090:
I didn't know cranelift-preopt existed. Wow. Looks like 1) most of it is covered by
cprop.isle
in the egraph work already; 2) the cranelift-preopt rules forudiv
are wrong in two ways I think?We should add appropriate floating-point rules to
cprop.isle
, but even without that I'd be inclined to just delete this crate, unless somebody has objections.
bjorn3 commented on issue #1090:
No objections from me. I don't use it in cg_clif.
jameysharp closed issue #1090:
I think cranelift-preopt was separated from cranelift-codegen because we assume that, in general, the input IR has been generated by an optimizing compiler (namely, one that ran constant folding). This being said, in our use case, when translating wasm to clif, we're likely to introduce redundancies and constant-foldable instructions that aren't obvious to catch (because we're operating on one wasm binary opcode at a time). There was also another instance of constant-foldable operations being emitted by legalization recently.
In principle, every pass that takes IR and augments it (by adding more IR nodes) is likely to introduce redundancies / constant-foldable instructions. I'd like someone to get more data on this, but how would people feel about putting the cranelift-preopt constant folding facilities into codegen instead?
Last updated: Jan 24 2025 at 00:11 UTC