[FFmpeg-devel] [PATCH] lavf/utils: remove loop on AVERROR(EAGAIN) in av_read_frame()

Stefano Sabatini stefasab at gmail.com
Mon Sep 24 20:53:59 CEST 2012


The loop was introduced in 64d340c62ad5954c1a834df2d26057135e771774,
which was likely breaking non blocking reads as it busy loops.
---
 libavformat/utils.c |   18 ++++++------------
 1 files changed, 6 insertions(+), 12 deletions(-)

diff --git a/libavformat/utils.c b/libavformat/utils.c
index 4f3529a..2a8fac1 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -1409,18 +1409,12 @@ int av_read_frame(AVFormatContext *s, AVPacket *pkt)
     AVStream *st;
 
     if (!genpts) {
-        while (1) {
-            ret = s->packet_buffer ?
-                read_from_packet_buffer(&s->packet_buffer, &s->packet_buffer_end, pkt) :
-                read_frame_internal(s, pkt);
-            if (ret < 0) {
-                if (ret == AVERROR(EAGAIN))
-                    continue;
-                else
-                    return ret;
-            }
-            goto return_packet;
-        }
+        ret = s->packet_buffer ?
+            read_from_packet_buffer(&s->packet_buffer, &s->packet_buffer_end, pkt) :
+            read_frame_internal(s, pkt);
+        if (ret < 0)
+            return ret;
+        goto return_packet;
     }
 
     for (;;) {
-- 
1.7.5.4



More information about the ffmpeg-devel mailing list