Do not leak on unsupported pixel format for theora.
---
 libavformat/sdp.c | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)

diff --git a/libavformat/sdp.c b/libavformat/sdp.c
index 186f83b..7c085a9 100644
--- a/libavformat/sdp.c
+++ b/libavformat/sdp.c
@@ -513,12 +513,6 @@ static char *sdp_write_media_attributes(char *buff, int 
size, AVCodecContext *c,
             break;
         case AV_CODEC_ID_THEORA: {
             const char *pix_fmt;
-            if (c->extradata_size)
-                config = xiph_extradata2config(c);
-            else
-                av_log(c, AV_LOG_ERROR, "Theora configuation info missing\n");
-            if (!config)
-                return NULL;
 
             switch (c->pix_fmt) {
             case AV_PIX_FMT_YUV420P:
@@ -535,6 +529,13 @@ static char *sdp_write_media_attributes(char *buff, int 
size, AVCodecContext *c,
                 return NULL;
             }
 
+            if (c->extradata_size)
+                config = xiph_extradata2config(c);
+            else
+                av_log(c, AV_LOG_ERROR, "Theora configuation info missing\n");
+            if (!config)
+                return NULL;
+
             av_strlcatf(buff, size, "a=rtpmap:%d theora/90000\r\n"
                                     "a=fmtp:%d delivery-method=inline; "
                                     "width=%d; height=%d; sampling=%s; "
-- 
1.8.5.1

_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to