Merge commit '4733a12dd17a91d606e0079ff9bb48b9f419cbef'
authorMichael Niedermayer <michaelni@gmx.at>
Mon, 8 Jun 2015 21:05:01 +0000 (23:05 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Mon, 8 Jun 2015 21:05:01 +0000 (23:05 +0200)
* commit '4733a12dd17a91d606e0079ff9bb48b9f419cbef':
  rtpdec_asf: Check memory allocation and free memory on error

Conflicts:
libavformat/rtpdec_asf.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
libavformat/rtpdec_asf.c

@@@ -106,8 -102,9 +106,10 @@@ int ff_wms_parse_sdp_a_line(AVFormatCon
          AVDictionary *opts = NULL;
          int len = strlen(p) * 6 / 8;
          char *buf = av_mallocz(len);
 +        AVInputFormat *iformat;
  
+         if (!buf)
+             return AVERROR(ENOMEM);
          av_base64_decode(buf, p, len);
  
          if (rtp_asf_fix_header(buf, len) < 0)
          if (rt->asf_ctx) {
              avformat_close_input(&rt->asf_ctx);
          }
-         if (!(rt->asf_ctx = avformat_alloc_context()))
++
 +        if (!(iformat = av_find_input_format("asf")))
 +            return AVERROR_DEMUXER_NOT_FOUND;
++
+         rt->asf_ctx = avformat_alloc_context();
+         if (!rt->asf_ctx) {
+             av_free(buf);
              return AVERROR(ENOMEM);
+         }
          rt->asf_ctx->pb      = &pb;
          av_dict_set(&opts, "no_resync_search", "1", 0);
 -        ret = avformat_open_input(&rt->asf_ctx, "", &ff_asf_demuxer, &opts);
 +
 +        if ((ret = ff_copy_whitelists(rt->asf_ctx, s)) < 0) {
 +            av_dict_free(&opts);
 +            return ret;
 +        }
 +
 +        ret = avformat_open_input(&rt->asf_ctx, "", iformat, &opts);
          av_dict_free(&opts);
-         if (ret < 0)
+         if (ret < 0) {
+             av_free(buf);
              return ret;
+         }
          av_dict_copy(&s->metadata, rt->asf_ctx->metadata, 0);
          rt->asf_pb_pos = avio_tell(&pb);
          av_free(buf);