Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What are the reasons/motivation for this change?
#4845 (and #4844 (comment)) reveal undefined behaviors in the Yosys code. This PR aims to resolve them.
Explain how this is achieved.
b_width_capped
already exists for preventing arithmetic overflow, limiting the value ofb_width
to 30. This just changes the left shifts to also use it. The caveat of incorrect results for extremely large values ofa_width
still applies, as does the improbability of that actually happening. This fixes synth failure #4844 (or at least, the floating point exception; the circuit still isn't valid but I think that's fine).In the
nowrshmsk
handling,log2(0)
returns -inf, which gives undefined behaviour when casting to an int. So catch the case when the stride is 0 and just set the stride_width to 0.If applicable, please suggest to reviewers how they can test the change.
Follow instructions for testing #4845 on this branch