[FFmpeg-devel] [PATCH 3/3] avformat/ffmdec: Only return EAGAIN if a server is attached
Andreas Cadhalpun
andreas.cadhalpun at googlemail.com
Fri Nov 20 19:34:50 CET 2015
On 20.11.2015 03:26, Michael Niedermayer wrote:
> From: Michael Niedermayer <michael at niedermayer.cc>
>
> This should fix a infinite loop
>
> Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> ---
> libavformat/ffmdec.c | 9 +++++++--
> 1 file changed, 7 insertions(+), 2 deletions(-)
>
> diff --git a/libavformat/ffmdec.c b/libavformat/ffmdec.c
> index c3850db..e7c1449 100644
> --- a/libavformat/ffmdec.c
> +++ b/libavformat/ffmdec.c
> @@ -49,7 +49,10 @@ static int ffm_is_avail_data(AVFormatContext *s, int size)
> } else {
> if (pos == ffm->write_index) {
> /* exactly at the end of stream */
> - return AVERROR(EAGAIN);
> + if (ffm->server_attached)
> + return AVERROR(EAGAIN);
> + else
> + return AVERROR_INVALIDDATA;
> } else if (pos < ffm->write_index) {
> avail_size = ffm->write_index - pos;
> } else {
> @@ -59,8 +62,10 @@ static int ffm_is_avail_data(AVFormatContext *s, int size)
> avail_size = (avail_size / ffm->packet_size) * (ffm->packet_size - FFM_HEADER_SIZE) + len;
> if (size <= avail_size)
> return 1;
> - else
> + else if (ffm->server_attached)
> return AVERROR(EAGAIN);
> + else
> + return AVERROR_INVALIDDATA;
> }
>
> static int ffm_resync(AVFormatContext *s, int state)
>
This reliably fixes the infinite EAGAIN loops. Thanks a lot!
I haven't tested ffserver, but assuming you did and it still works,
this patch is fine.
Best regards,
Andreas
More information about the ffmpeg-devel
mailing list