Fix argument extension on riscv64 for Wasmtime builtins #10069
Merged
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.
This commit fixes a crash found in the CI of #10040. That PR itself isn't the fault per-se but rather uncovered a preexisting issue on riscv64. According to riscv64's ABI docs it looks like arguments are all expected to be sign-extended, whereas currently in Wasmtime all host signatures are zero-extended on all platforms. This commit applies two changes to fix this:
A new
TargetIsa::default_argument_extension
method was added which is now used instead of unconditionally usinguext
to apply to all arguments/results.While I was here I went ahead and split apart things where the wasm signature of a builtin doesn't use
uext
orsext
. The host signature still does, however, which means that any extension necessary happens in the trampoline we generate per-libcall as opposed to at all callsites.I'm not certain that all platforms require
uext
but I've left theTargetIsa
implementation asuext
for now with a comment explaining why. Currently the only non-uext
platforms are riscv64, which issext
to fix the issue from #10040, and Pulley which is "none" as things work differently there.