-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Run the full test suite on 32-bit platforms #9837
base: main
Are you sure you want to change the base?
Run the full test suite on 32-bit platforms #9837
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll defer to @fitzgen on the Pulley interpreter changes but a few thoughts on the conditional logic -- my main thought is that I'd prefer we didn't conflate "32-bit host" with "has no backend" and instead of a specific feature (or other method) meaning "we have a native codegen backend for the host platform"; seems less likely to cause unintentional issues later.
Subscribe to Label Actioncc @fitzgen
This issue or pull request has been labeled: "cranelift", "cranelift:area:aarch64", "cranelift:area:machinst", "pulley", "wasmtime:api"
Thus the following users have been cc'd because of the following labels:
To subscribe or unsubscribe from this label, edit the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just looked at the runtime and pulley changes themselves since Chris looked at the other parts.
crates/wasmtime/build.rs
Outdated
// Flag pulley as enabled unconditionally on 32-bit targets to ensure that | ||
// wasm is runnable by default like it is on other 64-bit native platforms. | ||
// Note that this doesn't actually enable the Cargo feature, it just changes | ||
// the cfg's passed to the crate, so for example care is still taken in | ||
// `Cargo.toml` to handle pulley-specific dependencies on 32-bit platforms. | ||
let target_pointer_width = std::env::var("CARGO_CFG_TARGET_POINTER_WIDTH").unwrap(); | ||
if target_pointer_width == "32" { | ||
println!("cargo:rustc-cfg=feature=\"pulley\""); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here I think it is worth explicitly checking against our ISAs supported by Cranelift.
crates/wasmtime/Cargo.toml
Outdated
# On 32-bit platforms where Cranelift currently doesn't have any supported host | ||
# unconditionally pull in the `pulley-interpreter` crate. Runtime support is | ||
# enabled via `build.rs` which prints `feature="pulley"` by default here and | ||
# compilation support, if enabled via the `cranelift` feature, is handled in the | ||
# `wasmtime-cranelift` crate enabling Pulley on 32-bit platforms. | ||
[target.'cfg(target_pointer_width = "32")'.dependencies] | ||
pulley-interpreter = { workspace = true } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't this happen automatically when the build script enables the feature?
Ok I've been thinking about how to clean this up. For the tests that @cfallin flagged I added logic to them all to check @fitzgen for your points though I'm not sure how to make it better. I'll note that the [target.'cfg(not(any(target_arch = "x86_64", target_arch = "aarch64", target_arch = "s390x", target_arch = "riscv64")))'.dependencies]
pulley-interpreter = { workspace = true } And then reflecting that same condition into This feels "zoomed out" enough to me that leaving |
That cfg is certainly annoying but seems like it is probably better than baking in new assumptions that we know are unlikely to be true for too long? |
To clarify though the precise assumption here is that 32-bit platforms don't have a Cranelift backend so pulley is pulled in as a dependency. This doesn't actually change any logic internally within Cranelift or Wasmtime, it just compiles in Pulley by default without a way to turn that off. That's only a problem with respect to binary size. If all of Cranelift's currently supported architectures are listed out here then that's duplicated in two places in Wasmtime (not counting the ones in Cranelift) and they're just going to get blindly added to in the future. Alternatively if Cranelift gets a 32-bit backend then that would be added as an exception to the cfg as-is when binary size becomes a problem. To me this is six-to-one-half-dozen-or-the-other where I have a preference for what's as-is as it's a managable cfg that's by-default workable for most platforms (it doesn't work for 64-bit platforms without a Cranelift backend). Listing out architectures individually feels "just as bad" to me basically. The main alternative to me is that we leave pulley disabled by default on all platforms, regardless of Cranelift support. That feels like a worse experience to me though because it means that Wasmtime only works by default on Cranelift-supported platforms, which if someone's new to Wasmtime they might not understand to enable the Pulley backend. |
ping @fitzgen on ^ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't feel strongly enough on the issue of cfg
s that I want to hold this up from landing. I do think writing out all the targets is slightly better than using pointer-width=32, but even better is running the full test suite on 32-bit platforms.
This commit switches to running the full test suite in its entirety (`./ci/run-tests.sh`) on 32-bit platforms in CI in addition to 64-bit platforms. This notably adds i686 and armv7 as architectures that are tested in CI. Lots of little fixes here and there were applied to a number of tests. Many tests just don't run on 32-bit platforms or a platform without Cranelift support, and they've been annotated as such where necessary. Other tests were adjusted to run on all platforms a few minor bug fixes are here as well. prtest:full
Don't require the `pulley` feature opt-in on 32-bit platforms to get wasm code running.
Default to pulley in `build.rs` rather than in `Cargo.toml` to make it easier to write down the condition and comment what's happening. This means that the `pulley-interpreter` crate and pulley support in Cranelift is always compiled in now and cannot be removed. This should hopefully be ok though as the `pulley-interpreter` crate is still conditionally used (meaning it can get GC'd) and the code-size of Cranelift is not as important as the runtime itself.
14e9250
to
b476a2e
Compare
Doing a bit of thinking on this, @fitzgen mind looking at the last commit? (b476a2e) It's a different strategy for enabling Pulley but it pulls the on-vs-off out of |
Label Messager: wasmtime:configIt looks like you are changing Wasmtime's configuration options. Make sure to
To modify this label's message, edit the To add new label messages or remove existing label messages, edit the |
I'll also call out the now-currently-last commit in this PR which is new and (somewhat) substantial. It resolves a segfault on CI which I could reproduce locally and was one of the items listed in #9747 namely that the setjmp/longjmp implementation for Pulley needed to restore callee-save state and this was the first time that turned up. |
This commit switches to running the full test suite in its entirety (
./ci/run-tests.sh
) on 32-bit platforms in CI in addition to 64-bit platforms. This notably adds i686 and armv7 as architectures that are tested in CI.Lots of little fixes here and there were applied to a number of tests. Many tests just don't run on 32-bit platforms or a platform without Cranelift support, and they've been annotated as such where necessary. Other tests were adjusted to run on all platforms a few minor bug fixes are here as well.