[FFmpeg-cvslog] fftools/ffmpeg_demux: factorize signalling end of demuxing

Anton Khirnov git at videolan.org
Mon Aug 8 17:27:52 EEST 2022


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Tue Mar 22 17:56:30 2022 +0100| [de9fb9fba7f6a7002ade2fe8c306a85fbf83e97d] | committer: Anton Khirnov

fftools/ffmpeg_demux: factorize signalling end of demuxing

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=de9fb9fba7f6a7002ade2fe8c306a85fbf83e97d
---

 fftools/ffmpeg_demux.c | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/fftools/ffmpeg_demux.c b/fftools/ffmpeg_demux.c
index d03210d9e6..d7dde1028f 100644
--- a/fftools/ffmpeg_demux.c
+++ b/fftools/ffmpeg_demux.c
@@ -18,6 +18,7 @@
 
 #include "ffmpeg.h"
 
+#include "libavutil/avassert.h"
 #include "libavutil/error.h"
 #include "libavutil/time.h"
 #include "libavutil/timestamp.h"
@@ -142,7 +143,6 @@ static void *input_thread(void *arg)
                 /* fallthrough to the error path */
             }
 
-            av_thread_message_queue_set_err_recv(f->in_thread_queue, ret);
             break;
         }
 
@@ -162,7 +162,7 @@ static void *input_thread(void *arg)
         msg.pkt = av_packet_alloc();
         if (!msg.pkt) {
             av_packet_unref(pkt);
-            av_thread_message_queue_set_err_recv(f->in_thread_queue, AVERROR(ENOMEM));
+            ret = AVERROR(ENOMEM);
             break;
         }
         av_packet_move_ref(msg.pkt, pkt);
@@ -181,11 +181,13 @@ static void *input_thread(void *arg)
                        "Unable to send packet to main thread: %s\n",
                        av_err2str(ret));
             av_packet_free(&msg.pkt);
-            av_thread_message_queue_set_err_recv(f->in_thread_queue, ret);
             break;
         }
     }
 
+    av_assert0(ret < 0);
+    av_thread_message_queue_set_err_recv(f->in_thread_queue, ret);
+
     return NULL;
 }
 



More information about the ffmpeg-cvslog mailing list