]> git.sesse.net Git - ffmpeg/commitdiff
avformat/msf: add support for ATRAC3 codec
authorPaul B Mahol <onemda@gmail.com>
Thu, 15 Sep 2016 14:57:48 +0000 (16:57 +0200)
committerPaul B Mahol <onemda@gmail.com>
Thu, 15 Sep 2016 14:59:31 +0000 (16:59 +0200)
Signed-off-by: Paul B Mahol <onemda@gmail.com>
libavformat/msf.c

index 0551e9bc24381e27b06540b98fdc3970578c87ca..24654e65698560c36bd03124bfe1410db1f9e8d5 100644 (file)
@@ -44,6 +44,7 @@ static int msf_read_header(AVFormatContext *s)
 {
     unsigned codec, align, size;
     AVStream *st;
+    int ret;
 
     avio_skip(s->pb, 4);
 
@@ -68,6 +69,17 @@ static int msf_read_header(AVFormatContext *s)
     case 0: st->codecpar->codec_id = AV_CODEC_ID_PCM_S16BE; break;
     case 3: st->codecpar->block_align = 16 * st->codecpar->channels;
             st->codecpar->codec_id = AV_CODEC_ID_ADPCM_PSX; break;
+    case 4:
+    case 5:
+    case 6: st->codecpar->block_align = (codec == 4 ? 96 : codec == 5 ? 152 : 192) * st->codecpar->channels;
+            ret = ff_alloc_extradata(st->codecpar, 14);
+            if (ret < 0)
+                return ret;
+            memset(st->codecpar->extradata, 0, st->codecpar->extradata_size);
+            AV_WL16(st->codecpar->extradata, 1);
+            AV_WL16(st->codecpar->extradata+4, 4096);
+            AV_WL16(st->codecpar->extradata+10, 1);
+            st->codecpar->codec_id = AV_CODEC_ID_ATRAC3;    break;
     case 7: st->need_parsing = AVSTREAM_PARSE_FULL_RAW;
             st->codecpar->codec_id = AV_CODEC_ID_MP3;       break;
     default: