tomaka commented on Issue #2537:
The CI failure looks unrelated to the PR:
rust-lld: error while loading shared libraries: libLLVM-11-rust-1.49.0-stable.so: cannot open shared object file: No such file or director
bjorn3 commented on Issue #2537:
This is for https://github.com/tomaka/redshirt, right?
tomaka commented on Issue #2537:
This is for https://github.com/tomaka/redshirt, right?
Indeed! My current plan to fork everything and add (back)
no-std
compatibility. I'm upstreaming a few changes which I think are uncontroversial.Since redshirt isn't my actual job and the holiday season coming to an end, the chances of actually implementing
no-std
compatibility any time soon are pretty low, but I wanted to get something going.
tomaka edited a comment on Issue #2537:
This is for https://github.com/tomaka/redshirt, right?
Indeed! My current plan to fork everything and add (back)
no-std
compatibility in hacky ways. I'm upstreaming a few changes which I think are uncontroversial.Since redshirt isn't my actual job and the holiday season coming to an end, the chances of actually implementing
no-std
compatibility any time soon are pretty low, but I wanted to get something going.
tomaka edited a comment on Issue #2537:
This is for https://github.com/tomaka/redshirt, right?
Indeed! My current plan to fork everything and add (back)
no-std
compatibility potentially in hacky ways (e.g. thethiserror
dependency is fundamentally incompatible with no-std, so I'm changing it). I'm upstreaming a few changes which I think are uncontroversial.Since redshirt isn't my actual job and the holiday season coming to an end, the chances of actually implementing
no-std
compatibility any time soon are pretty low, but I wanted to get something going.
tomaka edited a comment on Issue #2537:
This is for https://github.com/tomaka/redshirt, right?
Indeed! My current plan to fork everything and add (back)
no-std
compatibility potentially in hacky ways (e.g. thethiserror
dependency is fundamentally incompatible with no-std, so I'm changing it). I'm upstreaming a few changes which I think are uncontroversial.Since redshirt isn't my actual job and the holiday season is coming to an end, the chances of actually implementing
no-std
compatibility any time soon are pretty low, but I wanted to get something going.
alexcrichton commented on Issue #2537:
We have a somewhat lengthy documentation section about why
#![no_std]
isn't currently used, would you be able to comment as to how your use case fits into that?
tomaka commented on Issue #2537:
The patch to switch to #![no_std] is small, why not accept it?
Ah sorry, I've seen this but a long time ago, and forgot the existence of this section.
I'm building (on my free time) an operating system that executes Wasm programs on bare metal, directly in ring 0.
For platforms without support for the Rust standard library the JIT compiler of Wasmtime often won't run on the platform as well. The JIT compiler requires mmap (or an equivalent), and presence of mmap often implies presence of a libc which means Rust's std library works.
I can somewhat easily implement mmap (assuming
MAP_ANONYMOUS
) and threads on bare metal, but implementing a shim of libc or standard library full ofunimplemented!()
expressions just forwasmtime
to work seems kind of "wrong", and way more efforts than forking wasmtime and replacing the platform-specific code with my own.
tomaka edited a comment on Issue #2537:
The patch to switch to #![no_std] is small, why not accept it?
Ah sorry, I've seen this but a long time ago, and forgot the existence of this section.
I'm building (on my free time) an operating system that executes Wasm programs on bare metal, directly in ring 0.
It's already functional, but terribly slow as it's usingwasmi
the interpreter.For platforms without support for the Rust standard library the JIT compiler of Wasmtime often won't run on the platform as well. The JIT compiler requires mmap (or an equivalent), and presence of mmap often implies presence of a libc which means Rust's std library works.
I can somewhat easily implement mmap (assuming
MAP_ANONYMOUS
) and threads on bare metal, but implementing a shim of libc or standard library full ofunimplemented!()
expressions just forwasmtime
to work seems kind of "wrong", and way more efforts than forking wasmtime and replacing the platform-specific code with my own.
alexcrichton commented on Issue #2537:
I would personally recommend for your use case that using
std
is the way to go. The standard library already has targets like wasm itself which return errors for any unsupported operations (likestd::thread
), and if you're usingstd
then this and other crates (likewasmparser
) would just work.
bjorn3 commented on Issue #2537:
I would personally recommend for your use case that using std is the way to go.
That would require forking the standard library.
The standard library already has targets like wasm itself which return errors for any unsupported operations (like std::thread), and if you're using std then this and other crates (like wasmparser) would just work.
Honestly that just feels like a hack. It shouldn't be possible to call functions when the kind of action (threads, filesystem, processes) doesn't exist at all on the target. The benefit of the current core, alloc, std split is that you can somewhat guarantee that code only depends on things that they should depend on. If the target doesn't support env vars and cranelift depends on libstd it is very easy to introduce a use of an env var to for example enable debug output. This would then break running cranelift on that target. By having cranelift depend only on core and alloc, this isn't possible.
tomaka commented on Issue #2537:
If the objective is for the
std
to compile for every single platform, how wouldwasmtime
know that a certain feature isunimplemented!
or not?If I'm using
wasmtime 0.68
, how can I know thatwasmtime 0.69
or one of its dependencies doesn't sometimes callstd::fs::File::open
, which isunimplemented!
and unimplementable?When it comes to
wasm32-unknown-unknown
, which is the one platform right now whosestd
hasunimplemented!()
portions, the outcome is that half of the Rust ecosystem uses#[cfg(not(target_os = "unknown")]]
and uses Cargo features likewasm-bindgen
orstdweb
to know what to replace thestd
with.
tomaka edited a comment on Issue #2537:
If the objective is for the
std
to compile for every single platform, how wouldwasmtime
know that a certain feature isunimplemented!
or not?If I'm using
wasmtime 0.68
, how can I know thatwasmtime 0.69
or one of its dependencies doesn't sometimes callstd::fs::File::open
, which isunimplemented!
and unimplementable?When it comes to
wasm32-unknown-unknown
, which is the one platform right now whosestd
hasunimplemented!()
portions, the outcome is that half of the Rust ecosystem uses#[cfg(not(target_os = "unknown")]]
and uses Cargo features likewasm-bindgen
orstdweb
to know what to replace thestd
with. Instead of standardizing a list of features available to all crates, puttingunimplemented!()
causes an "un-standardization", as people replace thestd
with an alternative.
tomaka edited a comment on Issue #2537:
If the objective is for the
std
to compile for every single platform, how wouldwasmtime
know that a certain feature isunimplemented!
or not?If I'm using
wasmtime 0.68
, how can I know thatwasmtime 0.69
or one of its dependencies doesn't sometimes callstd::fs::File::open
, which isunimplemented!
and unimplementable?When it comes to
wasm32-unknown-unknown
, which is the one platform right now whosestd
hasunimplemented!()
portions, the outcome is that half of the Rust ecosystem uses#[cfg(not(target_os = "unknown")]]
and uses Cargo features likewasm-bindgen
orstdweb
to know what to replace thestd
with. Instead of standardizing a list of features available to all crates, puttingunimplemented!()
caused an "un-standardization", as people replace thestd
with an alternative.
tomaka edited a comment on Issue #2537:
If the objective is for the
std
to compile for every single platform, how wouldwasmtime
know that a certain feature isunimplemented!
or not?If I'm using
wasmtime 0.68
, how can I know thatwasmtime 0.69
or one of its dependencies doesn't sometimes callstd::fs::File::open
, which isunimplemented!
and unimplementable?When it comes to
wasm32-unknown-unknown
, which is the one widely-used platform right now whosestd
hasunimplemented!()
portions, the outcome is that half of the Rust ecosystem uses#[cfg(not(target_os = "unknown")]]
and uses Cargo features likewasm-bindgen
orstdweb
to know what to replace thestd
with. Instead of standardizing a list of features available to all crates, puttingunimplemented!()
caused an "un-standardization", as people replace thestd
with an alternative.
alexcrichton commented on Issue #2537:
Call it a hack, call it a fork, the reality is that either libstd compiles for your platform or you force literally all users of your platform to not use
std
. Not usingstd
has quite a large cost because there's lots of crates that would otherwise work (like this andwasmparser
). Additionally not usingstd
is not very idiomatic, weird workarounds, imports, etc, are required to get things compiling. Nothing is guaranteed to work anyway unless you're running on the platforms itself. I do not believe there is an objectively correct answer as to whether you should be able to call a function that always returns an error. @bjorn3 you think you shouldn't be able to do that, I disagree.I don't know why
std
wouldn't have the objective of compiling for all platforms. How doeswasmtime
today know if a feature is unimplemented or not? Someone runs the code and sends a PR to handle their platform if it dooesn't work. You have no guarantee future versions will continue to work, but you never have a guarantee about that unless your target is added to Wasmtime's CI. In no way does usingno_std
here provide you with any degree of guarantee that things will always work into the future.Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime. Are all Rust ecosystem crates expected to cater to all hobbyist's whims?
bjorn3 commented on Issue #2537:
Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime.
Wasmtime interacts a lot with the outside world due to memory mapping, filesystem accesses and terminal accesses. Cranelift on the other hand doesn't interact with the outside world. It only requires a memory allocator because using a large fixed size chunk of memory is inefficient and would complicate code. The Cranelift embedded may or may not interact with the outside world, but Cranelift itself is a observably equivalent to a function from clif ir to bytes. (ignoring OOM's)
tomaka commented on Issue #2537:
Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime. Are all Rust ecosystem crates expected to cater to all hobbyist's whims?
I mentioned "so feel free to close this PR if it is inappropriate.". I legitimately didn't remember that there was a guideline against small no-std-compatibility PRs.
all it a hack, call it a fork, the reality is that either libstd compiles for your platform or you force literally all users of your platform to not use std. Not using std has quite a large cost because there's lots of crates that would otherwise work (like this and wasmparser). Additionally not using std is not very idiomatic, weird workarounds, imports, etc, are required to get things compiling.
I'm of the complete opposite view.
I have personally been some traumatised trying to make a big project work for
wasm32-unknown-unknown
that I've restarted the codebase from scratch with a strictno_std
requirement, because in practice it's what works. Going through the hundreds of direct and indirect dependencies figuring out how they use theirwasm-bindgen
features and fixing issues because they use features that aren't implemented drove me insane. I have absolutely no intention of doing the same thing forwasmtime
.
tomaka edited a comment on Issue #2537:
Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime. Are all Rust ecosystem crates expected to cater to all hobbyist's whims?
I mentioned "so feel free to close this PR if it is inappropriate.". I legitimately didn't remember that there was a guideline against small no-std-compatibility PRs.
all it a hack, call it a fork, the reality is that either libstd compiles for your platform or you force literally all users of your platform to not use std. Not using std has quite a large cost because there's lots of crates that would otherwise work (like this and wasmparser). Additionally not using std is not very idiomatic, weird workarounds, imports, etc, are required to get things compiling.
I'm of the complete opposite view.
I have personally been somewhat traumatised trying to make a big project work for
wasm32-unknown-unknown
that I've restarted the codebase from scratch with a strictno_std
requirement, because in practice it's what works. Going through the hundreds of direct and indirect dependencies figuring out how they use theirwasm-bindgen
features and fixing issues because they use features that aren't implemented drove me insane. I have absolutely no intention of doing the same thing forwasmtime
.
tomaka edited a comment on Issue #2537:
Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime. Are all Rust ecosystem crates expected to cater to all hobbyist's whims?
I mentioned "so feel free to close this PR if it is inappropriate.". I legitimately didn't remember that there was a guideline against small no-std-compatibility PRs.
all it a hack, call it a fork, the reality is that either libstd compiles for your platform or you force literally all users of your platform to not use std. Not using std has quite a large cost because there's lots of crates that would otherwise work (like this and wasmparser). Additionally not using std is not very idiomatic, weird workarounds, imports, etc, are required to get things compiling.
I'm of the complete opposite view.
I have personally been somewhat traumatised trying to make a big project work for
wasm32-unknown-unknown
that I've restarted the codebase from scratch with a strictno_std
requirement, because in practice, I cannot stress it enough, it's what works. Going through the hundreds of direct and indirect dependencies figuring out how they use theirwasm-bindgen
features and fixing issues because they use features that aren't implemented drove me insane. I have absolutely no intention of doing the same thing forwasmtime
.
tomaka edited a comment on Issue #2537:
Overall I feel there's an imbalance here when a hobbyist's personal project impacts the idioms in a project like Wasmtime. Are all Rust ecosystem crates expected to cater to all hobbyist's whims?
I mentioned "so feel free to close this PR if it is inappropriate.". I legitimately didn't remember that there was a guideline against small no-std-compatibility PRs.
all it a hack, call it a fork, the reality is that either libstd compiles for your platform or you force literally all users of your platform to not use std. Not using std has quite a large cost because there's lots of crates that would otherwise work (like this and wasmparser). Additionally not using std is not very idiomatic, weird workarounds, imports, etc, are required to get things compiling.
I'm of the complete opposite view.
I have personally been somewhat traumatised trying to make a big project work for
wasm32-unknown-unknown
that I've restarted the codebase from scratch with a strictno_std
requirement, because in practice, I cannot stress this enough, it's what works. Going through the hundreds of direct and indirect dependencies figuring out how they use theirwasm-bindgen
features and fixing issues because they use features that aren't implemented drove me insane. I have absolutely no intention of doing the same thing forwasmtime
.
tomaka commented on Issue #2537:
To repeat my opinion, as someone who now has a lot of experience in
no_std
compatibility, forkingwasmtime
to make it no-std-compatible seems tremendously easier and more sane than writing a customstd
implementation full of shim functions.
tomaka edited a comment on Issue #2537:
To repeat my opinion, as someone who now has a lot of experience in
no_std
compatibility, forkingwasmtime
to make it no-std-compatible (and, I guess, without upstreaming patches) seems tremendously easier and more sane than writing a customstd
implementation full of shim functions.
alexcrichton commented on Issue #2537:
To be clear, I'm speaking my personal opinions here, I don't represent all contributors to this project. I would recommend you prototype the
std
-based solution to get an idea for how hard it might be, there's been upstream work to make new targets very easy to add tostd
. There's also nothing set in stone for how hobbyist targets are handled in libstd, I'm happy to have a conversation about how to best support that if you'd like, but if you'd rather not have such a conversation that's ok too.
cfallin commented on Issue #2537:
Speaking only about Cranelift, the effort to make the core compiler crates no_std (and keep them that way) does not seem too bad -- swap/add some
use
statements and maybe add a CI job to grep forstd::
in certain directories -- and I'd be happy to review such a thing if others in the project were onboard. (This would need changes in theregalloc
crate as well.) I can certainly see the value in having a nice, portable, minimal-dependencies JIT compiler library (as @bjorn3 says, in theory a compiler should need nothing other than memory allocation). I'd defer to others on the rest of Wasmtime; the runtime portability issue seems like a much more difficult question.
Last updated: Jan 24 2025 at 00:11 UTC