nutdec: add malloc check and fix const to non-const conversion warnings
authorMans Rullgard <mans@mansr.com>
Wed, 18 Apr 2012 19:48:36 +0000 (20:48 +0100)
committerMans Rullgard <mans@mansr.com>
Wed, 18 Apr 2012 22:54:20 +0000 (23:54 +0100)
Signed-off-by: Mans Rullgard <mans@mansr.com>
libavformat/nutdec.c

index 004a2ea255b66ffeeeba14096bce7d0e8b06d1c1..f3cb4d88384c127e21149c8645085a9eff4251c9 100644 (file)
@@ -305,14 +305,18 @@ static int decode_main_header(NUTContext *nut)
         GET_V(nut->header_count, tmp < 128U)
         nut->header_count++;
         for (i = 1; i < nut->header_count; i++) {
+            uint8_t *hdr;
             GET_V(nut->header_len[i], tmp > 0 && tmp < 256);
             rem -= nut->header_len[i];
             if (rem < 0) {
                 av_log(s, AV_LOG_ERROR, "invalid elision header\n");
                 return AVERROR_INVALIDDATA;
             }
-            nut->header[i] = av_malloc(nut->header_len[i]);
-            avio_read(bc, nut->header[i], nut->header_len[i]);
+            hdr = av_malloc(nut->header_len[i]);
+            if (!hdr)
+                return AVERROR(ENOMEM);
+            avio_read(bc, hdr, nut->header_len[i]);
+            nut->header[i] = hdr;
         }
         assert(nut->header_len[0] == 0);
     }