alexcrichton opened PR #9845 from alexcrichton:optimize-bounds-check
to bytecodealliance:main
:
This commit implements an optimization when lowering Wasm bytecode to CLIF to skip a bounds check when the offset in memory is statically known. This comes up in C/C++/Rust when
static
memory is addressed for example where LLVM emits ani32.const 0
as the base address and puts the address of the variable in theoffset
instruction field. This isn't necessary for 64-bit platforms but when explicit bounds-checks are required this can help to eliminate a constant-true bounds-check.<!--
Please make sure you include the following information:
If this work has been discussed elsewhere, please include a link to that
conversation. If it was discussed in an issue, just mention "issue #...".Explain why this change is needed. If the details are in an issue already,
this can be brief.Our development process is documented in the Wasmtime book:
https://docs.wasmtime.dev/contributing-development-process.htmlPlease ensure all communication follows the code of conduct:
https://github.com/bytecodealliance/wasmtime/blob/main/CODE_OF_CONDUCT.md
-->
alexcrichton requested wasmtime-compiler-reviewers for a review on PR #9845.
alexcrichton requested fitzgen for a review on PR #9845.
alexcrichton requested wasmtime-core-reviewers for a review on PR #9845.
sunfishcode submitted PR review.
sunfishcode created PR review comment:
Could you add a few tests with interesting non-zero offsets as well?
sunfishcode created PR review comment:
Imm64(zero_extended.signed())
sunfishcode created PR review comment:
let zero_extended = (self.0.unsigned() << delta) >> delta;
sunfishcode created PR review comment:
Would it make sense to specify a max, like
(memory 1 2)
, so that this can test for loads that are in-bounds on the minimum but not the maximum?
sunfishcode created PR review comment:
I'm confused; if it's a signed integer of the given width, why would we zero-extend it? It looks like this function ends with
.signed()
, but the one user of this function callsunsigned()
on the result.
fitzgen created PR review comment:
so that this can test for loads that are in-bounds on the minimum but not the maximum?
I think this should be "in bounds of the maximum but not the minimum", but yeah +1
fitzgen created PR review comment:
Just to make this larger function a little bit less of a monolith, could we factor this snippet out into its own helper?
fitzgen submitted PR review:
LGTM modulo a nitpick below and Dan's comments as well.
fitzgen edited PR review comment.
alexcrichton created PR review comment:
Oops this is a copy/paste typo
alexcrichton submitted PR review.
alexcrichton updated PR #9845.
alexcrichton has enabled auto merge for PR #9845.
alexcrichton merged PR #9845.
Last updated: Jan 24 2025 at 00:11 UTC