bjorn3 commented on issue #5409:
This was producing iconsts with set high bits beyond their types' width, which is not legal.
I thought backends were supposed to mask it. I believe cg_clif sometimes sign extends immediates.
cfallin commented on issue #5409:
This was producing iconsts with set high bits beyond their types' width, which is not legal.
I thought backends were supposed to mask it. I believe cg_clif sometimes sign extends immediates.
Hmm, it seems we discussed this and filed #3059 a while ago, and haven't done any thinking about it since. I suspect that we aren't doing such masking everywhere we need to be, and requiring rules everywhere to do the masking (e.g., const-folding an
icmp eq
would require comparing only the relevant bits) seems cumbersome. I'd rather we have an invariant that values stay in range.For now I guess we can keep the status quo, but we should think about this some more (on that issue probably)!
jameysharp commented on issue #5409:
BTW I'm curious if the new optimization rules have any impact on any benchmarks. Do these patterns show up in any CLIF we're generating from wasm, or do our current benchmarks compile to the same sequence of instructions either way? Not terribly important but if this is a significant win for some reason, that'd be nice to know.
cfallin commented on issue #5409:
That's a good question, re: the
icmp
folding; I didn't do tests on this. Honestly I'd be somewhat surprised if they did though, given that the benchmarks are optimized.wasm
s and the sorts of redundancies that show up in the translated CLIF are not usually things that const-folding applies to.
cfallin commented on issue #5409:
And, to follow up, a quick smoketest with
bz2
shows no runtime impact with the additionalicmp
folding roles.
Last updated: Jan 24 2025 at 00:11 UTC