Skip to content
Snippets Groups Projects
Commit d07585f0 authored by Bryan Huh's avatar Bryan Huh Committed by Michael Niedermayer
Browse files

avformat/async: Fix bug where async could not recover after seek to eof


When async issues its inner seek via ffurl_seek, it treats failures as
EOF being reached. This is not consistent with the behavior of other
protocols (e.g. http, cache) which continue to tolerate reads after
failed seeks, and therefore does not interact correctly with them.

A common pattern where this manifests itself is where avio_seek is
called with pos to be the end-of-file - the http range-request would
fail here, and async would set io_eof_reached to 1. The background
thread would then refuse to read more bytes, and subsequent reads would
only empty the fifo and end in an error.

Presumably the code may have expected subsequent seeks to unset the
io_eof_reached but this is not guaranteed to be true - a subsequent seek
that lands in the AVIOContext's buffer (the fact that the
previously-failed avio_seek leaves the AVIOContext's buffer intact also
suggests that follow-up reads are expected to be tolerated) would not be
issued to the async_seek function, and when that buffer is drained only
async_read calls would follow, leading to the same error just described.

Signed-off-by: default avatarMichael Niedermayer <michael@niedermayer.cc>
parent 5324109d
No related branches found
No related tags found
No related merge requests found
......@@ -195,19 +195,16 @@ static void *async_buffer_task(void *arg)
if (c->seek_request) {
seek_ret = ffurl_seek(c->inner, c->seek_pos, c->seek_whence);
if (seek_ret < 0) {
c->io_eof_reached = 1;
c->io_error = (int)seek_ret;
} else {
if (seek_ret >= 0) {
c->io_eof_reached = 0;
c->io_error = 0;
ring_reset(ring);
}
c->seek_completed = 1;
c->seek_ret = seek_ret;
c->seek_request = 0;
ring_reset(ring);
pthread_cond_signal(&c->cond_wakeup_main);
pthread_mutex_unlock(&c->mutex);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment