[FFmpeg-devel] [PATCH 05/10] publisher.c: Add allocation failure checks.

Stephan Holljes klaxa1337 at googlemail.com
Mon May 28 21:27:06 EEST 2018


Signed-off-by: Stephan Holljes <klaxa1337 at googlemail.com>
---
 publisher.c | 20 ++++++++++++++++++++
 1 file changed, 20 insertions(+)

diff --git a/publisher.c b/publisher.c
index 2e96f2f..9374c41 100644
--- a/publisher.c
+++ b/publisher.c
@@ -97,17 +97,37 @@ void publisher_init(struct PublisherContext **pub, char *stream_name)
 {
     int i;
     struct PublisherContext *pc = (struct PublisherContext*) av_malloc(sizeof(struct PublisherContext));
+    if (!pc) {
+        av_log(NULL, AV_LOG_ERROR, "Could not allocate publisher context.\n");
+        return;
+    }
     pc->nb_threads = 8;
     pc->stream_name = stream_name;
     pc->current_segment_id = -1;
     pc->shutdown = 0;
     pc->buffer = av_fifo_alloc_array(sizeof(struct Segment), MAX_SEGMENTS);
+    if (!pc->buffer) {
+        av_log(NULL, AV_LOG_ERROR, "Could not allocate publisher buffer.\n");
+        av_free(pc);
+        return;
+    }
     pc->fs_buffer = av_fifo_alloc_array(sizeof(struct Segment), MAX_SEGMENTS);
+    if (!pc->fs_buffer) {
+        av_log(NULL, AV_LOG_ERROR, "Could not allocate publisher fast-start buffer.\n");
+        av_fifo_free(pc->buffer);
+        av_free(pc);
+        return;
+    }
     pthread_mutex_init(&pc->buffer_lock, NULL);
     pthread_mutex_init(&pc->fs_buffer_lock, NULL);
     for (i = 0; i < MAX_CLIENTS; i++) {
         struct Client *c = &pc->clients[i];
         c->buffer = av_fifo_alloc_array(sizeof(struct Segment), MAX_SEGMENTS);
+        if (!c->buffer) {
+            av_log(NULL, AV_LOG_ERROR, "Could not allocate client buffer.\n");
+            publisher_free(pc);
+            return;
+        }
         c->ofmt_ctx = NULL;
         c->ffinfo = NULL;
         c->id = i;
-- 
2.16.2



More information about the ffmpeg-devel mailing list