Do not eliminate casts from FP types when optimizing narrow stores #53667
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.
An optimization in morph was deleting casts on the RHS of a narrow store if the cast-to-type
was wider than the type being stored. This is only valid for casts from integral types, as the backend
does not handle
STOREIND(byte*, double)
, nor is there an instruction to go from anXMM
register to a narrow memory location on x86/x64.The issue is not reproducible right now because
fgMorphCast
wraps the casts in question, but it is an invalid IR transformation nonetheless, and similar code infgMorphSmpOpOptional
guards against non-integral sources.Also, while I was there, modernized the code a little bit.