]> git.sesse.net Git - ffmpeg/blobdiff - libavformat/brstm.c
Merge commit 'd43a165bda0eae95f4c7a168c7d13d94966c1a09'
[ffmpeg] / libavformat / brstm.c
index bbdbcef6cbe31274e144bef83227fc2a09d640a6..aae2575fb73e25184589fc41c7029e4dd0dbee8e 100644 (file)
@@ -389,6 +389,16 @@ static int read_packet(AVFormatContext *s, AVPacket *pkt)
         codec->codec_id == AV_CODEC_ID_ADPCM_THP_LE) {
         uint8_t *dst;
 
+        if (!b->adpc) {
+            av_log(s, AV_LOG_ERROR, "adpcm_thp requires ADPC chunk, but none was found.\n");
+            return AVERROR_INVALIDDATA;
+        }
+        if (!b->table) {
+            b->table = av_mallocz(32 * codec->channels);
+            if (!b->table)
+                return AVERROR(ENOMEM);
+        }
+
         if (size > (INT_MAX - 32 - 4) ||
             (32 + 4 + size) > (INT_MAX / codec->channels) ||
             (32 + 4 + size) * codec->channels > INT_MAX - 8)