-
Notifications
You must be signed in to change notification settings - Fork 634
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
Only return Poll::Ready
from Sender::poll_flush
if the channel is empty
#2746
base: master
Are you sure you want to change the base?
Only return Poll::Ready
from Sender::poll_flush
if the channel is empty
#2746
Conversation
Poll::Ready
from Sender
if the channel is emptyPoll::Ready
from Sender::poll_flush
if the channel is empty
Miri is detecting a deadlock but I am not quite sure why. Help is much appreciated. |
Okay, I think I found the problem. I've replaced that with This makes me wonder whether this might perhaps be a fairly intrusive change for the ecosystem. I still think that this is the more correct behaviour but I wonder, how many people are relying on |
Not sure why https://github.com/rust-lang/futures-rs/actions/runs/5046514587/jobs/9052136457?pr=2746#step:5:326 is failing. It passes locally. Help would be appreciated. |
…156) Currently, we have a `garbage_collect` function that checks whether any of our streams have been dropped. This can cause a race condition where the channel between a `Stream` and the `Connection` still has pending frames for a stream but dropping a stream causes us to already send a `FIN` flag for the stream. We fix this by maintaining a single channel for each stream. When a stream gets dropped, the `Receiver` becomes disconnected. We use this information to queue the correct frame (`FIN` vs `RST`) into the buffer. At this point, all previous frames have already been processed and the race condition is thus not present. Additionally, this also allows us to implement `Stream::poll_flush` by forwarding to the underlying `Sender`. Note that at present day, this only checks whether there is _space_ in the channel, not whether the items have been emitted by the `Receiver`. We have a PR upstream that might fix this: rust-lang/futures-rs#2746 Fixes: #117.
Thanks for the PR.
armv7 failure is unrelated to this PR (should be fixed by rebase).
Yeah, I'm not open to introducing a patch that may introduce hard-to-debug deadlocks. (even if it is in a breaking release) |
To be fair, it only occurs if both sender and receiver are polled by the same task. I think that is a rather unlikely situation because you could also just push and pop a |
520b76f
to
228f75b
Compare
Any chance this will be merged someday? |
I've found it to be very surprising behaviour that
poll_flush
on aSender
returnsPoll::Ready
despite the channel not being empty. This PR attempts to fix this by checking the number of messages in the channel and parking the task if is > 0.Resolves: #2504.