[Ffmpeg-cvslog] CVS: ffmpeg/libavformat movenc.c,1.72,1.73
Baptiste Coudurier CVS
bcoudurier
Sat May 13 22:05:05 CEST 2006
Update of /cvsroot/ffmpeg/ffmpeg/libavformat
In directory mail:/var2/tmp/cvs-serv12323/libavformat
Modified Files:
movenc.c
Log Message:
add pcm 24/32 le/be support
Index: movenc.c
===================================================================
RCS file: /cvsroot/ffmpeg/ffmpeg/libavformat/movenc.c,v
retrieving revision 1.72
retrieving revision 1.73
diff -u -d -r1.72 -r1.73
--- movenc.c 13 May 2006 18:45:29 -0000 1.72
+++ movenc.c 13 May 2006 20:05:02 -0000 1.73
@@ -224,6 +224,14 @@
return 0x11;
}
+static int mov_write_enda_tag(ByteIOContext *pb)
+{
+ put_be32(pb, 10);
+ put_tag(pb, "enda");
+ put_be16(pb, 1); /* little endian */
+ return 10;
+}
+
static unsigned int descrLength(unsigned int len)
{
int i;
@@ -242,10 +250,8 @@
static int mov_write_esds_tag(ByteIOContext *pb, MOVTrack* track) // Basic
{
- int decoderSpecificInfoLen;
offset_t pos = url_ftell(pb);
-
- decoderSpecificInfoLen = track->vosLen ? descrLength(track->vosLen):0;
+ int decoderSpecificInfoLen = track->vosLen ? descrLength(track->vosLen):0;
put_be32(pb, 0); // size
put_tag(pb, "esds");
@@ -302,17 +308,18 @@
put_be32(pb, 12); /* size */
put_tag(pb, "frma");
- put_tag(pb, "mp4a");
-
- put_be32(pb, 12); /* size */
- put_tag(pb, "mp4a");
- put_be32(pb, 0);
+ put_le32(pb, track->tag);
- mov_write_esds_tag(pb, track);
+ if (track->enc->codec_id == CODEC_ID_AAC) {
+ put_be32(pb, 12); /* size */
+ put_tag(pb, "mp4a");
+ put_be32(pb, 0);
- put_be32(pb, 12); /* size */
- put_tag(pb, "srcq");
- put_be32(pb, 0x40);
+ mov_write_esds_tag(pb, track);
+ } else if (track->enc->codec_id == CODEC_ID_PCM_S24LE ||
+ track->enc->codec_id == CODEC_ID_PCM_S32LE) {
+ mov_write_enda_tag(pb);
+ }
put_be32(pb, 8); /* size */
put_be32(pb, 0); /* null tag */
@@ -331,6 +338,10 @@
{ CODEC_ID_AMR_WB, MKTAG('s', 'a', 'w', 'b') },
{ CODEC_ID_PCM_S16BE, MKTAG('t', 'w', 'o', 's') },
{ CODEC_ID_PCM_S16LE, MKTAG('s', 'o', 'w', 't') },
+ { CODEC_ID_PCM_S24BE, MKTAG('i', 'n', '2', '4') },
+ { CODEC_ID_PCM_S24LE, MKTAG('i', 'n', '2', '4') },
+ { CODEC_ID_PCM_S32BE, MKTAG('i', 'n', '3', '2') },
+ { CODEC_ID_PCM_S32LE, MKTAG('i', 'n', '3', '2') },
{ CODEC_ID_MP3, MKTAG('.', 'm', 'p', '3') },
{ CODEC_ID_NONE, 0 },
};
@@ -338,6 +349,10 @@
static int mov_write_audio_tag(ByteIOContext *pb, MOVTrack* track)
{
offset_t pos = url_ftell(pb);
+ int version = track->mode == MODE_MOV &&
+ (track->enc->codec_id == CODEC_ID_AAC ||
+ track->enc->codec_id == CODEC_ID_PCM_S32LE ||
+ track->enc->codec_id == CODEC_ID_PCM_S24LE);
put_be32(pb, 0); /* size */
put_le32(pb, track->tag); // store it byteswapped
@@ -346,10 +361,7 @@
put_be16(pb, 1); /* Data-reference index, XXX == 1 */
/* SoundDescription */
- if(track->mode == MODE_MOV && track->enc->codec_id == CODEC_ID_AAC)
- put_be16(pb, 1); /* Version 1 */
- else
- put_be16(pb, 0); /* Version 0 */
+ put_be16(pb, version); /* Version */
put_be16(pb, 0); /* Revision level */
put_be32(pb, 0); /* Reserved */
@@ -369,20 +381,23 @@
put_be16(pb, track->timescale); /* Time scale */
put_be16(pb, 0); /* Reserved */
- if(track->mode == MODE_MOV && track->enc->codec_id == CODEC_ID_AAC) {
+ if(version == 1) {
/* SoundDescription V1 extended info */
put_be32(pb, track->enc->frame_size); /* Samples per packet */
- put_be32(pb, 1536); /* Bytes per packet */
- put_be32(pb, 2); /* Bytes per frame */
+ put_be32(pb, track->sampleDuration); /* Bytes per frame */
+ put_be32(pb, 8); /* Bytes per sample */
put_be32(pb, 2); /* Bytes per sample */
}
if(track->enc->codec_id == CODEC_ID_AAC) {
- if( track->mode == MODE_MOV ) mov_write_wave_tag(pb, track);
- else mov_write_esds_tag(pb, track);
- }
- if(track->enc->codec_id == CODEC_ID_AMR_NB)
+ if (track->mode == MODE_MOV) mov_write_wave_tag(pb, track);
+ else mov_write_esds_tag(pb, track);
+ } else if(track->enc->codec_id == CODEC_ID_AMR_NB) {
mov_write_damr_tag(pb);
+ } else if(track->enc->codec_id == CODEC_ID_PCM_S24LE ||
+ track->enc->codec_id == CODEC_ID_PCM_S32LE) {
+ mov_write_wave_tag(pb, track);
+ }
return updateSize (pb, pos);
}
@@ -1604,6 +1619,14 @@
case CODEC_ID_PCM_S16LE:
samplesInChunk = size/(2*enc->channels);
break;
+ case CODEC_ID_PCM_S24BE:
+ case CODEC_ID_PCM_S24LE:
+ samplesInChunk = size/(3*enc->channels);
+ break;
+ case CODEC_ID_PCM_S32BE:
+ case CODEC_ID_PCM_S32LE:
+ samplesInChunk = size/(4*enc->channels);
+ break;
default:
samplesInChunk = 1;
}
More information about the ffmpeg-cvslog
mailing list