aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorPeter Ross <pross@xvid.org>2008-08-04 07:35:07 +0000
committerPeter Ross <pross@xvid.org>2008-08-04 07:35:07 +0000
commit51c3861e1663a1e4e9ea465176e68d82e98cc6e9 (patch)
treef2fc470ee40dc0cc666d1088bc901d223f50e2d3 /libavformat
parentbb89b0bc9d82153712c13db00b80e2edcbf697a4 (diff)
downloadffmpeg-51c3861e1663a1e4e9ea465176e68d82e98cc6e9.tar.gz
Add D-Cinema audio muxer
Originally committed as revision 14531 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/Makefile1
-rw-r--r--libavformat/allformats.c2
-rw-r--r--libavformat/daud.c35
3 files changed, 37 insertions, 1 deletions
diff --git a/libavformat/Makefile b/libavformat/Makefile
index 2d681a707f..8c62a36665 100644
--- a/libavformat/Makefile
+++ b/libavformat/Makefile
@@ -33,6 +33,7 @@ OBJS-$(CONFIG_BFI_DEMUXER) += bfi.o
OBJS-$(CONFIG_C93_DEMUXER) += c93.o vocdec.o voc.o
OBJS-$(CONFIG_CRC_MUXER) += crcenc.o
OBJS-$(CONFIG_DAUD_DEMUXER) += daud.o
+OBJS-$(CONFIG_DAUD_MUXER) += daud.o
OBJS-$(CONFIG_DIRAC_DEMUXER) += raw.o
OBJS-$(CONFIG_DIRAC_MUXER) += raw.o
OBJS-$(CONFIG_DSICIN_DEMUXER) += dsicin.o
diff --git a/libavformat/allformats.c b/libavformat/allformats.c
index 6441ca996c..eab3a924f7 100644
--- a/libavformat/allformats.c
+++ b/libavformat/allformats.c
@@ -68,7 +68,7 @@ void av_register_all(void)
REGISTER_DEMUXER (BFI, bfi);
REGISTER_DEMUXER (C93, c93);
REGISTER_MUXER (CRC, crc);
- REGISTER_DEMUXER (DAUD, daud);
+ REGISTER_MUXDEMUX (DAUD, daud);
REGISTER_MUXDEMUX (DIRAC, dirac);
REGISTER_DEMUXER (DSICIN, dsicin);
REGISTER_MUXDEMUX (DTS, dts);
diff --git a/libavformat/daud.c b/libavformat/daud.c
index 5f04e7aaee..c0626dfb24 100644
--- a/libavformat/daud.c
+++ b/libavformat/daud.c
@@ -47,6 +47,24 @@ static int daud_packet(AVFormatContext *s, AVPacket *pkt) {
return ret;
}
+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)
+{
+ put_be16(s->pb, pkt->size);
+ put_be16(s->pb, 0x8010); // unknown
+ put_buffer(s->pb, pkt->data, pkt->size);
+ put_flush_packet(s->pb);
+ return 0;
+}
+
+#if CONFIG_DAUD_DEMUXER
AVInputFormat daud_demuxer = {
"daud",
NULL_IF_CONFIG_SMALL("D-Cinema audio format"),
@@ -58,3 +76,20 @@ AVInputFormat daud_demuxer = {
NULL,
.extensions = "302",
};
+#endif
+
+#ifdef CONFIG_DAUD_MUXER
+AVOutputFormat daud_muxer =
+{
+ "daud",
+ NULL_IF_CONFIG_SMALL("D-Cinema audio format"),
+ NULL,
+ "302",
+ 0,
+ CODEC_ID_PCM_S24DAUD,
+ CODEC_ID_NONE,
+ daud_write_header,
+ daud_write_packet,
+ .flags= AVFMT_NOTIMESTAMPS,
+};
+#endif