pchickey opened PR #6877 from bytecodealliance:pch/backpressure_2
to bytecodealliance:main
:
<!--
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
-->
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey edited PR #6877:
Backpressure design is being revised to take into account that any call with a
list<bytes>
argument is going to consume the resources of the callee, so the callee has to explicitly permit how much that is allowed to consume.Flushing is a way to request & observe the completion of a write. Since the write itself is non-blocking it cant report that it failed if that happens after the call is over. the explicit flush call allows the caller to wait for a write (or sequence of writes) to produce an error, or guarantee that it succeeded.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
alexcrichton submitted PR review.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
This I think wants to be abort-on-drop, and I suspect that should happen elsewhere too, so maybe a
AbortOnDropJoinHandle<T>
wrapper class?
alexcrichton created PR review comment:
s/return Err/bail/
alexcrichton created PR review comment:
Should this have a
flush
at the end of it as well? Otherwise as-is with this branch a "hello world" on the CLI with components doesn't currently actually print anything (theflush
being required to get tokio to wait for the output to actually reach the "actually write to stdio" thread)
alexcrichton created PR review comment:
I think this may not quite work because if the
await
is cancelled that means the task should be put back inself
?
alexcrichton created PR review comment:
I think the answer here is a 0-byte read?
alexcrichton created PR review comment:
I think the
?
here may propagateEWOULDBLOCK
to a fatal error?
alexcrichton created PR review comment:
Like below, I think this needs to handle the case where the
await
is cancelled but thetask
is restored intoself
alexcrichton created PR review comment:
Could this constant be abstracted elsewhere for this crate? I saw that tcp yeilds 1GB where this is 64k which is pretty different
alexcrichton created PR review comment:
For this, and below, could the error be threaded through to
die_in_worker
to be picked up on the next call to flush/write?
alexcrichton created PR review comment:
Should this perhaps delegate to
self.stream.flush().await
?
alexcrichton created PR review comment:
This part about all the queueing makes me a bit uneasy. I'd naively expect at-most-one thing here contractually and then we'd add vectors/etc as optimizations in the future maybe.
I think this stems though from the contract of flush/write? I'm personally of the opinion that we should change the WASI layer to only allow at most one operation at a time if we can, meaning that each stream has a single pollable which indicates the status of the pending operation, if any. I know @pchickey you were thinking we should allow concurrent flush/write, though.
Maybe we should jump on a call for a chat about this?
alexcrichton created PR review comment:
This raises a few questions to me:
- How is the number of written bytes signaled back?
- The
try_write
here I think returns EWOULDBLOCK, right?
alexcrichton created PR review comment:
Could this use one
Arc
instead ofArc
-per-field?
alexcrichton submitted PR review.
alexcrichton created PR review comment:
For reproducing this I've done:
$ cargo build -p wasi-preview1-component-adapter --target wasm32-wasi --features command --no-default-features $ cat foo.rs fn main() { println!("wat"); } $ rustc foo.rs --target wasm32-wasi $ wasm-tools component new ./foo.wasm -o foo.component.wasm --adapt ./target/wasm32-wasi/debug/wasi_snapshot_preview1.wasm $ cargo run --features component-model -- --wasm-features component-model ./foo.component.wasm
and no output comes out
pchickey updated PR #6877.
pchickey submitted PR review.
pchickey created PR review comment:
Yes, that was the intent. Fixed in 8a91dd
pchickey edited PR review comment.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
pchickey edited PR #6877:
Backpressure design is being revised to take into account that any call with a
list<bytes>
argument is going to consume the resources of the callee, so the callee has to explicitly permit how much that is allowed to consume.Flushing is a way to request & observe the completion of a write. Since the write itself is non-blocking it cant report that it failed if that happens after the call is over. the explicit flush call allows the caller to wait for a write (or sequence of writes) to produce an error, or guarantee that it succeeded.
Fixes #6811
pchickey updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt submitted PR review.
elliottt created PR review comment:
This should be resolved after merging in #6928.
elliottt updated PR #6877.
elliottt submitted PR review.
elliottt created PR review comment:
Works for me!
elliottt submitted PR review.
elliottt created PR review comment:
This method no longer exists, but that would have good!
elliottt updated PR #6877.
elliottt submitted PR review.
elliottt created PR review comment:
Great point!
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
alexcrichton created PR review comment:
Syntax-wise, is it possible to write this as
s.write_read().await?
?
alexcrichton created PR review comment:
Could 2048 be a documented constant here? That seems a little small to have as a budget, but we can always change it later.
alexcrichton created PR review comment:
This feels a little odd to me in the sense that the trap/context make sense if this is going to be a trap/complete failure but this is also being wrapped up in
LastOperationFailed
below additionally. My guess, having not read further yet, is that there's error handling ofOutputStreamError
which makes this not always a trap. This looks like, given the wrapper on this line though, that it's always a trap?I'll dig in more when seeing the error handling.
alexcrichton created PR review comment:
Should this use
preview2::spawn
to handle the sync case too?
alexcrichton created PR review comment:
Question on this, is the intention that the host will consume output from a
MemoryOutputBuffer
incrementally, freeing up space in the pipe? Or is the intention that everything is collected and then the pipe is completely done and no more data can ever be put in?
alexcrichton created PR review comment:
Could the error be handled here to detect EWOULDLBOCK? I'm worried about spurious writable notifications from above causing the write here to immediately return "WOULDBLOCK", but being able to handle that
alexcrichton submitted PR review:
This all looks great to me, thanks again so much for pushing on this @pchickey and @elliottt!
I've got a number of minor comments but everything looks great :+1:
alexcrichton submitted PR review:
This all looks great to me, thanks again so much for pushing on this @pchickey and @elliottt!
I've got a number of minor comments but everything looks great :+1:
alexcrichton created PR review comment:
Could this be:
if let Some(handle) = &mut self.write_handle { handle.await... }
alexcrichton created PR review comment:
Like way up a above IMO this should be
.unwrap
or.expect
to propagate a panic rather than hiding it under a trap
alexcrichton created PR review comment:
Could this use
e.source()
? Otherwise errors will get double-printed because the error is printed inDisplay
above and would additionally be printed when thesource
is printed here
alexcrichton created PR review comment:
Oh actually I think I'm totally wrong. I think this is handling the
Result
layer of the spawned task which is propagating panics.In that case, could
unwrap
orexpect
be used here instead ofcontext
/map_err
?
pchickey updated PR #6877.
pchickey edited PR #6877:
Backpressure design is being revised to take into account that any call with a
list<bytes>
argument is going to consume the resources of the callee, so the callee has to explicitly permit how much that is allowed to consume.Flushing is a way to request & observe the completion of a write. Since the write itself is non-blocking it cant report that it failed if that happens after the call is over. the explicit flush call allows the caller to wait for a write (or sequence of writes) to produce an error, or guarantee that it succeeded.
Fixes #6811
This PR changes the wit interfaces, therefore we are leaving it as a draft until after WasmCon & Componentize the World (Sept 6-8) so that wasmtime's
main
reflects a consistent set of interfaces for demos and hacking at those events.We plan to merge this PR to main on Monday, Sept 11. We will then backport it as a cherry-pick to the 13.0 release branch so that these changes get included in the wasmtime 13 release as well.
pchickey submitted PR review.
pchickey created PR review comment:
yes, this should be an expect instead of a trap.
pchickey submitted PR review.
pchickey created PR review comment:
The intention is that writes get collected up to the stated capacity, then no more are accepted.
We could return Err(OutputStreamError::Closed) once capacity is reached, but I wasn't really sure.
We basically only use this type to collect output in tests.
pchickey updated PR #6877.
pchickey submitted PR review.
pchickey created PR review comment:
fxied
pchickey submitted PR review.
pchickey created PR review comment:
Thanks, I frequently get that one wrong
pchickey updated PR #6877.
pchickey submitted PR review.
pchickey created PR review comment:
done
pchickey submitted PR review.
pchickey created PR review comment:
thanks, done
pchickey submitted PR review.
pchickey created PR review comment:
i changed AbortOnDropJoinHandle's Future impl to always unwrap the task panics
pchickey updated PR #6877.
pchickey submitted PR review.
pchickey created PR review comment:
I upped it to 4096 because thats what we let blocking-write-and-flush accept
pchickey edited PR review comment.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey has marked PR #6877 as ready for review.
pchickey requested wasmtime-core-reviewers for a review on PR #6877.
pchickey requested fitzgen for a review on PR #6877.
pchickey requested wasmtime-default-reviewers for a review on PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
pchickey updated PR #6877.
elliottt updated PR #6877.
pchickey has enabled auto merge for PR #6877.
elliottt has disabled auto merge for PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
alexcrichton updated PR #6877.
alexcrichton requested wasmtime-fuzz-reviewers for a review on PR #6877.
alexcrichton requested wasmtime-compiler-reviewers for a review on PR #6877.
elliottt updated PR #6877.
alexcrichton updated PR #6877.
elliottt updated PR #6877.
elliottt updated PR #6877.
elliottt merged PR #6877.
Last updated: Jan 24 2025 at 00:11 UTC