Merge commit '0955e57ad07640574fc20ce0bea3c0b83982ada1'
authorMichael Niedermayer <michaelni@gmx.at>
Thu, 3 Jul 2014 19:42:16 +0000 (21:42 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Thu, 3 Jul 2014 19:42:16 +0000 (21:42 +0200)
* commit '0955e57ad07640574fc20ce0bea3c0b83982ada1':
  daud: split muxer and demuxer

Conflicts:
libavformat/Makefile

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

@@@ -106,13 -89,9 +106,13 @@@ OBJS-$(CONFIG_CAVSVIDEO_DEMUXER
  OBJS-$(CONFIG_CAVSVIDEO_MUXER)           += rawenc.o
  OBJS-$(CONFIG_CDG_DEMUXER)               += cdg.o
  OBJS-$(CONFIG_CDXL_DEMUXER)              += cdxl.o
 +OBJS-$(CONFIG_CINE_DEMUXER)              += cinedec.o
 +OBJS-$(CONFIG_CONCAT_DEMUXER)            += concatdec.o
  OBJS-$(CONFIG_CRC_MUXER)                 += crcenc.o
- OBJS-$(CONFIG_DAUD_DEMUXER)              += daud.o
- OBJS-$(CONFIG_DAUD_MUXER)                += daud.o
 +OBJS-$(CONFIG_DATA_DEMUXER)              += rawdec.o
 +OBJS-$(CONFIG_DATA_MUXER)                += rawdec.o
+ OBJS-$(CONFIG_DAUD_DEMUXER)              += dauddec.o
+ OBJS-$(CONFIG_DAUD_MUXER)                += daudenc.o
  OBJS-$(CONFIG_DFA_DEMUXER)               += dfa.o
  OBJS-$(CONFIG_DIRAC_DEMUXER)             += diracdec.o rawdec.o
  OBJS-$(CONFIG_DIRAC_MUXER)               += rawenc.o
@@@ -77,19 -55,5 +55,5 @@@ AVInputFormat ff_daud_demuxer = 
      .long_name      = NULL_IF_CONFIG_SMALL("D-Cinema audio"),
      .read_header    = daud_header,
      .read_packet    = daud_packet,
 -    .extensions     = "302",
 +    .extensions     = "302,daud",
  };
- #endif
- #if CONFIG_DAUD_MUXER
- AVOutputFormat ff_daud_muxer = {
-     .name         = "daud",
-     .long_name    = NULL_IF_CONFIG_SMALL("D-Cinema audio"),
-     .extensions   = "302",
-     .audio_codec  = AV_CODEC_ID_PCM_S24DAUD,
-     .video_codec  = AV_CODEC_ID_NONE,
-     .write_header = daud_write_header,
-     .write_packet = daud_write_packet,
-     .flags        = AVFMT_NOTIMESTAMPS,
- };
- #endif
index 0000000,416e895..99b18d3
mode 000000,100644..100644
--- /dev/null
@@@ -1,0 -1,54 +1,54 @@@
 - * This file is part of Libav.
+ /*
+  * D-Cinema audio muxer
+  * Copyright (c) 2005 Reimar Döffinger
+  *
 - * Libav is free software; you can redistribute it and/or
++ * This file is part of FFmpeg.
+  *
 - * Libav is distributed in the hope that it will be useful,
++ * FFmpeg is free software; you can redistribute it and/or
+  * modify it under the terms of the GNU Lesser General Public
+  * License as published by the Free Software Foundation; either
+  * version 2.1 of the License, or (at your option) any later version.
+  *
 - * License along with Libav; if not, write to the Free Software
++ * FFmpeg is distributed in the hope that it will be useful,
+  * but WITHOUT ANY WARRANTY; without even the implied warranty of
+  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+  * Lesser General Public License for more details.
+  *
+  * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
+  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+  */
+ #include "avformat.h"
+ static int daud_write_header(struct AVFormatContext *s)
+ {
+     AVCodecContext *codec = s->streams[0]->codec;
+     if (codec->channels!=6 || codec->sample_rate!=96000)
+         return -1;
+     return 0;
+ }
+ static int daud_write_packet(struct AVFormatContext *s, AVPacket *pkt)
+ {
+     if (pkt->size > 65535) {
+         av_log(s, AV_LOG_ERROR,
+                "Packet size too large for s302m. (%d > 65535)\n", pkt->size);
+         return -1;
+     }
+     avio_wb16(s->pb, pkt->size);
+     avio_wb16(s->pb, 0x8010); // unknown
+     avio_write(s->pb, pkt->data, pkt->size);
+     return 0;
+ }
+ AVOutputFormat ff_daud_muxer = {
+     .name         = "daud",
+     .long_name    = NULL_IF_CONFIG_SMALL("D-Cinema audio"),
+     .extensions   = "302",
+     .audio_codec  = AV_CODEC_ID_PCM_S24DAUD,
+     .video_codec  = AV_CODEC_ID_NONE,
+     .write_header = daud_write_header,
+     .write_packet = daud_write_packet,
+     .flags        = AVFMT_NOTIMESTAMPS,
+ };