rtpenc: Fix memory leaks in the muxer open function
authorMartin Storsjö <martin@martin.st>
Sun, 17 Jun 2012 15:18:16 +0000 (18:18 +0300)
committerMartin Storsjö <martin@martin.st>
Sun, 17 Jun 2012 19:49:25 +0000 (22:49 +0300)
Also return a proper error code in these cases.

Signed-off-by: Martin Storsjö <martin@martin.st>
libavformat/rtpenc.c

index 71eeb7e..6752fb6 100644 (file)
@@ -198,11 +198,11 @@ static int rtp_write_header(AVFormatContext *s1)
         /* max_header_toc_size + the largest AMR payload must fit */
         if (1 + s->max_frames_per_packet + n > s->max_payload_size) {
             av_log(s1, AV_LOG_ERROR, "RTP max payload size too small for AMR\n");
-            return -1;
+            goto fail;
         }
         if (st->codec->channels != 1) {
             av_log(s1, AV_LOG_ERROR, "Only mono is supported\n");
-            return -1;
+            goto fail;
         }
     case CODEC_ID_AAC:
         s->num_frames = 0;
@@ -216,6 +216,10 @@ defaultcase:
     }
 
     return 0;
+
+fail:
+    av_freep(&s->buf);
+    return AVERROR(EINVAL);
 }
 
 /* send an rtcp sender report packet */