-
Notifications
You must be signed in to change notification settings - Fork 9
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
Fix various SIMD constraints #103
Conversation
Here is the original condition for line 5:
and the main difference seems to be the absence of the condition The real question though, is "why that condition disappeared". |
One thing I don't understand: why are these actually independent if-conditions, and not else-if branches? At most one of the original reduction rules can apply, so shouldn't they be translated into mutually exclusive code paths? |
The main reason was that there are some cases where: the prose for first reduction rule looks like:
and the prose for second reduction rule looks like:
Inserting the second prose as the else-branch of the top level if-branch for first prose would make a wrong prose, Instead, it was implemented as the simple concatenation of independent if-branches for now, |
I see. But that seems quite problematic, because it now requires negating and spelling out all previous (implicit & explicit) conditions for every consecutive case, which is brittle and makes the prose more verbose and less faithful to the formal rules — one goal of the spec was to keep them as close as possible. Do you have an example of the scenario you describe? How often does that come up? |
I think it was related to an automatically inferred side condition, though I can't recall the exact scenario. I believe that happened quite rarely anyway, so I would try making every branches as else-branches, see if there's any problem with that, and see if I can handle that. |
By the way, it seems that the current reductions rules for This is the parsed IL for the previous version:
and here is the parsed IL for the new version:
The main difference is the last argument (which has type (And if the prose-generation was "perfect", these rules should be translated as a prose containing So, the fundamental reason for test failure seems to be the non-deterministic reduction rules. Whether the prose uses else-branch or not seems to be an orthogonal issue. |
That's an excellent point. The intuition was that a meta variable never has an iterated type by itself (so that we have to write x? or x*), which arguably is what one would expect given this notation. But the elaborator happily inferred iterated types, so indeed the rules were interpreted as overlapping. I changed it to not do that, and after that, these are now correctly recognised as singletons and the tests pass again. That also produced more natural translations for various other rules (see commit) and uncovered a bug where I still used Thanks for the help! That unblocks this PR. I'm still uneasy about not using else-branches (which is closely related to the assumption of full coverage and turning the last condition into an assertion that we discussed last week — I don't think that even works without if-else), but we can resolve that separately. |
This PR adds various syntactic constraints on SIMD operators that were still missing. However, I ran into strange behaviour with the interpreter now failing some tests.
I added some extra checks in the interpreter backend to get a proper error and now have:
Apparently, this is while executing the test
at simd_conversions.wast:182, which invokes the simple function
Something appears to go wrong with the interpretation of the reduction rules for VCVTOP. The prose for execution looks okay to me:
But when interpreting the above instruction, it somehow seems to fall through to step 5. I don't understand why.
@ShinWonho, @f52985, any idea?