Commit 32442930 authored by Anton Khirnov's avatar Anton Khirnov Committed by Michael Niedermayer

lavf: use a new ffio_wfourcc macro instead of put_tag() where possible

Signed-off-by: 's avatarRonald S. Bultje <rsbultje@gmail.com>
(cherry picked from commit 0abdb293)
parent 853daff6
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include "avformat.h" #include "avformat.h"
#include "aiff.h" #include "aiff.h"
#include "avio_internal.h"
typedef struct { typedef struct {
int64_t form; int64_t form;
...@@ -43,10 +44,10 @@ static int aiff_write_header(AVFormatContext *s) ...@@ -43,10 +44,10 @@ static int aiff_write_header(AVFormatContext *s)
aifc = 1; aifc = 1;
/* FORM AIFF header */ /* FORM AIFF header */
put_tag(pb, "FORM"); ffio_wfourcc(pb, "FORM");
aiff->form = url_ftell(pb); aiff->form = url_ftell(pb);
avio_wb32(pb, 0); /* file length */ avio_wb32(pb, 0); /* file length */
put_tag(pb, aifc ? "AIFC" : "AIFF"); ffio_wfourcc(pb, aifc ? "AIFC" : "AIFF");
if (aifc) { // compressed audio if (aifc) { // compressed audio
enc->bits_per_coded_sample = 16; enc->bits_per_coded_sample = 16;
...@@ -55,13 +56,13 @@ static int aiff_write_header(AVFormatContext *s) ...@@ -55,13 +56,13 @@ static int aiff_write_header(AVFormatContext *s)
return -1; return -1;
} }
/* Version chunk */ /* Version chunk */
put_tag(pb, "FVER"); ffio_wfourcc(pb, "FVER");
avio_wb32(pb, 4); avio_wb32(pb, 4);
avio_wb32(pb, 0xA2805140); avio_wb32(pb, 0xA2805140);
} }
/* Common chunk */ /* Common chunk */
put_tag(pb, "COMM"); ffio_wfourcc(pb, "COMM");
avio_wb32(pb, aifc ? 24 : 18); /* size */ avio_wb32(pb, aifc ? 24 : 18); /* size */
avio_wb16(pb, enc->channels); /* Number of channels */ avio_wb16(pb, enc->channels); /* Number of channels */
...@@ -88,7 +89,7 @@ static int aiff_write_header(AVFormatContext *s) ...@@ -88,7 +89,7 @@ static int aiff_write_header(AVFormatContext *s)
} }
/* Sound data chunk */ /* Sound data chunk */
put_tag(pb, "SSND"); ffio_wfourcc(pb, "SSND");
aiff->ssnd = url_ftell(pb); /* Sound chunk size */ aiff->ssnd = url_ftell(pb); /* Sound chunk size */
avio_wb32(pb, 0); /* Sound samples data size */ avio_wb32(pb, 0); /* Sound samples data size */
avio_wb32(pb, 0); /* Data offset */ avio_wb32(pb, 0); /* Data offset */
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
*/ */
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "pcm.h" #include "pcm.h"
#include "riff.h" #include "riff.h"
...@@ -53,7 +54,7 @@ static int put_au_header(AVIOContext *pb, AVCodecContext *enc) ...@@ -53,7 +54,7 @@ static int put_au_header(AVIOContext *pb, AVCodecContext *enc)
{ {
if(!enc->codec_tag) if(!enc->codec_tag)
return -1; return -1;
put_tag(pb, ".snd"); /* magic number */ ffio_wfourcc(pb, ".snd"); /* magic number */
avio_wb32(pb, 24); /* header size */ avio_wb32(pb, 24); /* header size */
avio_wb32(pb, AU_UNKNOWN_SIZE); /* data size */ avio_wb32(pb, AU_UNKNOWN_SIZE); /* data size */
avio_wb32(pb, (uint32_t)enc->codec_tag); /* codec ID */ avio_wb32(pb, (uint32_t)enc->codec_tag); /* codec ID */
......
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
*/ */
#include "avformat.h" #include "avformat.h"
#include "avi.h" #include "avi.h"
#include "avio_internal.h"
#include "riff.h" #include "riff.h"
#include "libavutil/intreadwrite.h" #include "libavutil/intreadwrite.h"
...@@ -77,9 +78,9 @@ static int64_t avi_start_new_riff(AVFormatContext *s, AVIOContext *pb, ...@@ -77,9 +78,9 @@ static int64_t avi_start_new_riff(AVFormatContext *s, AVIOContext *pb,
} }
avi->riff_start = ff_start_tag(pb, "RIFF"); avi->riff_start = ff_start_tag(pb, "RIFF");
put_tag(pb, riff_tag); ffio_wfourcc(pb, riff_tag);
loff = ff_start_tag(pb, "LIST"); loff = ff_start_tag(pb, "LIST");
put_tag(pb, list_tag); ffio_wfourcc(pb, list_tag);
return loff; return loff;
} }
...@@ -107,7 +108,7 @@ static void avi_write_info_tag(AVIOContext *pb, const char *tag, const char *str ...@@ -107,7 +108,7 @@ static void avi_write_info_tag(AVIOContext *pb, const char *tag, const char *str
int len = strlen(str); int len = strlen(str);
if (len > 0) { if (len > 0) {
len++; len++;
put_tag(pb, tag); ffio_wfourcc(pb, tag);
avio_wl32(pb, len); avio_wl32(pb, len);
avio_put_str(pb, str); avio_put_str(pb, str);
if (len & 1) if (len & 1)
...@@ -175,7 +176,7 @@ static int avi_write_header(AVFormatContext *s) ...@@ -175,7 +176,7 @@ static int avi_write_header(AVFormatContext *s)
list1 = avi_start_new_riff(s, pb, "AVI ", "hdrl"); list1 = avi_start_new_riff(s, pb, "AVI ", "hdrl");
/* avi header */ /* avi header */
put_tag(pb, "avih"); ffio_wfourcc(pb, "avih");
avio_wl32(pb, 14 * 4); avio_wl32(pb, 14 * 4);
bitrate = 0; bitrate = 0;
...@@ -221,7 +222,7 @@ static int avi_write_header(AVFormatContext *s) ...@@ -221,7 +222,7 @@ static int avi_write_header(AVFormatContext *s)
for(i=0;i<n;i++) { for(i=0;i<n;i++) {
AVIStream *avist= s->streams[i]->priv_data; AVIStream *avist= s->streams[i]->priv_data;
list2 = ff_start_tag(pb, "LIST"); list2 = ff_start_tag(pb, "LIST");
put_tag(pb, "strl"); ffio_wfourcc(pb, "strl");
stream = s->streams[i]->codec; stream = s->streams[i]->codec;
...@@ -235,10 +236,10 @@ static int avi_write_header(AVFormatContext *s) ...@@ -235,10 +236,10 @@ static int avi_write_header(AVFormatContext *s)
av_log(s, AV_LOG_ERROR, "Subtitle streams other than DivX XSUB are not supported by the AVI muxer.\n"); av_log(s, AV_LOG_ERROR, "Subtitle streams other than DivX XSUB are not supported by the AVI muxer.\n");
return AVERROR_PATCHWELCOME; return AVERROR_PATCHWELCOME;
} }
case AVMEDIA_TYPE_VIDEO: put_tag(pb, "vids"); break; case AVMEDIA_TYPE_VIDEO: ffio_wfourcc(pb, "vids"); break;
case AVMEDIA_TYPE_AUDIO: put_tag(pb, "auds"); break; case AVMEDIA_TYPE_AUDIO: ffio_wfourcc(pb, "auds"); break;
// case AVMEDIA_TYPE_TEXT : put_tag(pb, "txts"); break; // case AVMEDIA_TYPE_TEXT : ffio_wfourcc(pb, "txts"); break;
case AVMEDIA_TYPE_DATA : put_tag(pb, "dats"); break; case AVMEDIA_TYPE_DATA : ffio_wfourcc(pb, "dats"); break;
} }
if(stream->codec_type == AVMEDIA_TYPE_VIDEO || if(stream->codec_type == AVMEDIA_TYPE_VIDEO ||
stream->codec_id == CODEC_ID_XSUB) stream->codec_id == CODEC_ID_XSUB)
...@@ -317,7 +318,7 @@ static int avi_write_header(AVFormatContext *s) ...@@ -317,7 +318,7 @@ static int avi_write_header(AVFormatContext *s)
avio_w8(pb, 0); /* bIndexSubType (0 == frame index) */ avio_w8(pb, 0); /* bIndexSubType (0 == frame index) */
avio_w8(pb, 0); /* bIndexType (0 == AVI_INDEX_OF_INDEXES) */ avio_w8(pb, 0); /* bIndexType (0 == AVI_INDEX_OF_INDEXES) */
avio_wl32(pb, 0); /* nEntriesInUse (will fill out later on) */ avio_wl32(pb, 0); /* nEntriesInUse (will fill out later on) */
put_tag(pb, avi_stream2fourcc(&tag[0], i, stream->codec_type)); ffio_wfourcc(pb, avi_stream2fourcc(&tag[0], i, stream->codec_type));
/* dwChunkId */ /* dwChunkId */
avio_wl64(pb, 0); /* dwReserved[3] avio_wl64(pb, 0); /* dwReserved[3]
avio_wl32(pb, 0); Must be 0. */ avio_wl32(pb, 0); Must be 0. */
...@@ -364,8 +365,8 @@ static int avi_write_header(AVFormatContext *s) ...@@ -364,8 +365,8 @@ static int avi_write_header(AVFormatContext *s)
if (!url_is_streamed(pb)) { if (!url_is_streamed(pb)) {
/* AVI could become an OpenDML one, if it grows beyond 2Gb range */ /* AVI could become an OpenDML one, if it grows beyond 2Gb range */
avi->odml_list = ff_start_tag(pb, "JUNK"); avi->odml_list = ff_start_tag(pb, "JUNK");
put_tag(pb, "odml"); ffio_wfourcc(pb, "odml");
put_tag(pb, "dmlh"); ffio_wfourcc(pb, "dmlh");
avio_wl32(pb, 248); avio_wl32(pb, 248);
for (i = 0; i < 248; i+= 4) for (i = 0; i < 248; i+= 4)
avio_wl32(pb, 0); avio_wl32(pb, 0);
...@@ -375,7 +376,7 @@ static int avi_write_header(AVFormatContext *s) ...@@ -375,7 +376,7 @@ static int avi_write_header(AVFormatContext *s)
ff_end_tag(pb, list1); ff_end_tag(pb, list1);
list2 = ff_start_tag(pb, "LIST"); list2 = ff_start_tag(pb, "LIST");
put_tag(pb, "INFO"); ffio_wfourcc(pb, "INFO");
ff_metadata_conv(&s->metadata, ff_avi_metadata_conv, NULL); ff_metadata_conv(&s->metadata, ff_avi_metadata_conv, NULL);
for (i = 0; *ff_avi_tags[i]; i++) { for (i = 0; *ff_avi_tags[i]; i++) {
if ((t = av_metadata_get(s->metadata, ff_avi_tags[i], NULL, AV_METADATA_MATCH_CASE))) if ((t = av_metadata_get(s->metadata, ff_avi_tags[i], NULL, AV_METADATA_MATCH_CASE)))
...@@ -390,7 +391,7 @@ static int avi_write_header(AVFormatContext *s) ...@@ -390,7 +391,7 @@ static int avi_write_header(AVFormatContext *s)
ff_end_tag(pb, list2); ff_end_tag(pb, list2);
avi->movi_list = ff_start_tag(pb, "LIST"); avi->movi_list = ff_start_tag(pb, "LIST");
put_tag(pb, "movi"); ffio_wfourcc(pb, "movi");
put_flush_packet(pb); put_flush_packet(pb);
...@@ -419,7 +420,7 @@ static int avi_write_ix(AVFormatContext *s) ...@@ -419,7 +420,7 @@ static int avi_write_ix(AVFormatContext *s)
/* Writing AVI OpenDML leaf index chunk */ /* Writing AVI OpenDML leaf index chunk */
ix = url_ftell(pb); ix = url_ftell(pb);
put_tag(pb, &ix_tag[0]); /* ix?? */ ffio_wfourcc(pb, &ix_tag[0]); /* ix?? */
avio_wl32(pb, avist->indexes.entry * 8 + 24); avio_wl32(pb, avist->indexes.entry * 8 + 24);
/* chunk size */ /* chunk size */
avio_wl16(pb, 2); /* wLongsPerEntry */ avio_wl16(pb, 2); /* wLongsPerEntry */
...@@ -427,7 +428,7 @@ static int avi_write_ix(AVFormatContext *s) ...@@ -427,7 +428,7 @@ static int avi_write_ix(AVFormatContext *s)
avio_w8(pb, 1); /* bIndexType (1 == AVI_INDEX_OF_CHUNKS) */ avio_w8(pb, 1); /* bIndexType (1 == AVI_INDEX_OF_CHUNKS) */
avio_wl32(pb, avist->indexes.entry); avio_wl32(pb, avist->indexes.entry);
/* nEntriesInUse */ /* nEntriesInUse */
put_tag(pb, &tag[0]); /* dwChunkId */ ffio_wfourcc(pb, &tag[0]); /* dwChunkId */
avio_wl64(pb, avi->movi_list);/* qwBaseOffset */ avio_wl64(pb, avi->movi_list);/* qwBaseOffset */
avio_wl32(pb, 0); /* dwReserved_3 (must be 0) */ avio_wl32(pb, 0); /* dwReserved_3 (must be 0) */
...@@ -442,7 +443,7 @@ static int avi_write_ix(AVFormatContext *s) ...@@ -442,7 +443,7 @@ static int avi_write_ix(AVFormatContext *s)
/* Updating one entry in the AVI OpenDML master index */ /* Updating one entry in the AVI OpenDML master index */
url_fseek(pb, avist->indexes.indx_start - 8, SEEK_SET); url_fseek(pb, avist->indexes.indx_start - 8, SEEK_SET);
put_tag(pb, "indx"); /* enabling this entry */ ffio_wfourcc(pb, "indx"); /* enabling this entry */
url_fskip(pb, 8); url_fskip(pb, 8);
avio_wl32(pb, avi->riff_id); /* nEntriesInUse */ avio_wl32(pb, avi->riff_id); /* nEntriesInUse */
url_fskip(pb, 16*avi->riff_id); url_fskip(pb, 16*avi->riff_id);
...@@ -492,7 +493,7 @@ static int avi_write_idx1(AVFormatContext *s) ...@@ -492,7 +493,7 @@ static int avi_write_idx1(AVFormatContext *s)
avist= s->streams[stream_id]->priv_data; avist= s->streams[stream_id]->priv_data;
avi_stream2fourcc(&tag[0], stream_id, avi_stream2fourcc(&tag[0], stream_id,
s->streams[stream_id]->codec->codec_type); s->streams[stream_id]->codec->codec_type);
put_tag(pb, &tag[0]); ffio_wfourcc(pb, &tag[0]);
avio_wl32(pb, ie->flags); avio_wl32(pb, ie->flags);
avio_wl32(pb, ie->pos); avio_wl32(pb, ie->pos);
avio_wl32(pb, ie->len); avio_wl32(pb, ie->len);
...@@ -601,7 +602,7 @@ static int avi_write_trailer(AVFormatContext *s) ...@@ -601,7 +602,7 @@ static int avi_write_trailer(AVFormatContext *s)
file_size = url_ftell(pb); file_size = url_ftell(pb);
url_fseek(pb, avi->odml_list - 8, SEEK_SET); url_fseek(pb, avi->odml_list - 8, SEEK_SET);
put_tag(pb, "LIST"); /* Making this AVI OpenDML one */ ffio_wfourcc(pb, "LIST"); /* Making this AVI OpenDML one */
url_fskip(pb, 16); url_fskip(pb, 16);
for (n=nb_frames=0;n<s->nb_streams;n++) { for (n=nb_frames=0;n<s->nb_streams;n++) {
......
...@@ -42,4 +42,6 @@ int ffio_read_partial(AVIOContext *s, unsigned char *buf, int size); ...@@ -42,4 +42,6 @@ int ffio_read_partial(AVIOContext *s, unsigned char *buf, int size);
void ffio_fill(AVIOContext *s, int b, int count); void ffio_fill(AVIOContext *s, int b, int count);
#define ffio_wfourcc(pb, str) avio_wl32(pb, MKTAG((str)[0], (str)[1], (str)[2], (str)[3]))
#endif // AVFORMAT_AVIO_INTERNAL_H #endif // AVFORMAT_AVIO_INTERNAL_H
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include "libavutil/intreadwrite.h" #include "libavutil/intreadwrite.h"
#include "libavutil/avstring.h" #include "libavutil/avstring.h"
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include <strings.h> #include <strings.h>
typedef struct { typedef struct {
...@@ -383,13 +384,13 @@ static int write_packet(AVFormatContext *s, AVPacket *pkt) ...@@ -383,13 +384,13 @@ static int write_packet(AVFormatContext *s, AVPacket *pkt)
if(pkt->size < 8 || AV_RL32(pkt->data+4) != MKTAG('j','p','2','c')) if(pkt->size < 8 || AV_RL32(pkt->data+4) != MKTAG('j','p','2','c'))
goto error; goto error;
avio_wb32(pb[0], 12); avio_wb32(pb[0], 12);
put_tag (pb[0], "jP "); ffio_wfourcc(pb[0], "jP ");
avio_wb32(pb[0], 0x0D0A870A); // signature avio_wb32(pb[0], 0x0D0A870A); // signature
avio_wb32(pb[0], 20); avio_wb32(pb[0], 20);
put_tag (pb[0], "ftyp"); ffio_wfourcc(pb[0], "ftyp");
put_tag (pb[0], "jp2 "); ffio_wfourcc(pb[0], "jp2 ");
avio_wb32(pb[0], 0); avio_wb32(pb[0], 0);
put_tag (pb[0], "jp2 "); ffio_wfourcc(pb[0], "jp2 ");
avio_write(pb[0], st->codec->extradata, st->codec->extradata_size); avio_write(pb[0], st->codec->extradata, st->codec->extradata_size);
}else if(pkt->size < 8 || }else if(pkt->size < 8 ||
(!st->codec->extradata_size && (!st->codec->extradata_size &&
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "pcm.h" #include "pcm.h"
#include "riff.h" #include "riff.h"
...@@ -70,7 +71,7 @@ static int mmf_write_header(AVFormatContext *s) ...@@ -70,7 +71,7 @@ static int mmf_write_header(AVFormatContext *s)
return -1; return -1;
} }
put_tag(pb, "MMMD"); ffio_wfourcc(pb, "MMMD");
avio_wb32(pb, 0); avio_wb32(pb, 0);
pos = ff_start_tag(pb, "CNTI"); pos = ff_start_tag(pb, "CNTI");
avio_w8(pb, 0); /* class */ avio_w8(pb, 0); /* class */
...@@ -91,7 +92,7 @@ static int mmf_write_header(AVFormatContext *s) ...@@ -91,7 +92,7 @@ static int mmf_write_header(AVFormatContext *s)
avio_w8(pb, 2); /* time base d */ avio_w8(pb, 2); /* time base d */
avio_w8(pb, 2); /* time base g */ avio_w8(pb, 2); /* time base g */
put_tag(pb, "Atsq"); ffio_wfourcc(pb, "Atsq");
avio_wb32(pb, 16); avio_wb32(pb, 16);
mmf->atsqpos = url_ftell(pb); mmf->atsqpos = url_ftell(pb);
/* Will be filled on close */ /* Will be filled on close */
......
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include "movenc.h" #include "movenc.h"
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "riff.h" #include "riff.h"
#include "avio.h" #include "avio.h"
#include "isom.h" #include "isom.h"
...@@ -55,9 +56,9 @@ static int mov_write_stco_tag(AVIOContext *pb, MOVTrack *track) ...@@ -55,9 +56,9 @@ static int mov_write_stco_tag(AVIOContext *pb, MOVTrack *track)
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
if (pos > UINT32_MAX) { if (pos > UINT32_MAX) {
mode64 = 1; mode64 = 1;
put_tag(pb, "co64"); ffio_wfourcc(pb, "co64");
} else } else
put_tag(pb, "stco"); ffio_wfourcc(pb, "stco");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb32(pb, track->entry); /* entry count */ avio_wb32(pb, track->entry); /* entry count */
for (i=0; i<track->entry; i++) { for (i=0; i<track->entry; i++) {
...@@ -77,7 +78,7 @@ static int mov_write_stsz_tag(AVIOContext *pb, MOVTrack *track) ...@@ -77,7 +78,7 @@ static int mov_write_stsz_tag(AVIOContext *pb, MOVTrack *track)
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "stsz"); ffio_wfourcc(pb, "stsz");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
for (i=0; i<track->entry; i++) { for (i=0; i<track->entry; i++) {
...@@ -114,7 +115,7 @@ static int mov_write_stsc_tag(AVIOContext *pb, MOVTrack *track) ...@@ -114,7 +115,7 @@ static int mov_write_stsc_tag(AVIOContext *pb, MOVTrack *track)
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "stsc"); ffio_wfourcc(pb, "stsc");
avio_wb32(pb, 0); // version & flags avio_wb32(pb, 0); // version & flags
entryPos = url_ftell(pb); entryPos = url_ftell(pb);
avio_wb32(pb, track->entry); // entry count avio_wb32(pb, track->entry); // entry count
...@@ -143,7 +144,7 @@ static int mov_write_stss_tag(AVIOContext *pb, MOVTrack *track, uint32_t flag) ...@@ -143,7 +144,7 @@ static int mov_write_stss_tag(AVIOContext *pb, MOVTrack *track, uint32_t flag)
int i, index = 0; int i, index = 0;
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); // size avio_wb32(pb, 0); // size
put_tag(pb, flag == MOV_SYNC_SAMPLE ? "stss" : "stps"); ffio_wfourcc(pb, flag == MOV_SYNC_SAMPLE ? "stss" : "stps");
avio_wb32(pb, 0); // version & flags avio_wb32(pb, 0); // version & flags
entryPos = url_ftell(pb); entryPos = url_ftell(pb);
avio_wb32(pb, track->entry); // entry count avio_wb32(pb, track->entry); // entry count
...@@ -163,9 +164,9 @@ static int mov_write_stss_tag(AVIOContext *pb, MOVTrack *track, uint32_t flag) ...@@ -163,9 +164,9 @@ static int mov_write_stss_tag(AVIOContext *pb, MOVTrack *track, uint32_t flag)
static int mov_write_amr_tag(AVIOContext *pb, MOVTrack *track) static int mov_write_amr_tag(AVIOContext *pb, MOVTrack *track)
{ {
avio_wb32(pb, 0x11); /* size */ avio_wb32(pb, 0x11); /* size */
if (track->mode == MODE_MOV) put_tag(pb, "samr"); if (track->mode == MODE_MOV) ffio_wfourcc(pb, "samr");
else put_tag(pb, "damr"); else ffio_wfourcc(pb, "damr");
put_tag(pb, "FFMP"); ffio_wfourcc(pb, "FFMP");
avio_w8(pb, 0); /* decoder version */ avio_w8(pb, 0); /* decoder version */
avio_wb16(pb, 0x81FF); /* Mode set (all modes for AMR_NB) */ avio_wb16(pb, 0x81FF); /* Mode set (all modes for AMR_NB) */
...@@ -185,7 +186,7 @@ static int mov_write_ac3_tag(AVIOContext *pb, MOVTrack *track) ...@@ -185,7 +186,7 @@ static int mov_write_ac3_tag(AVIOContext *pb, MOVTrack *track)
return -1; return -1;
avio_wb32(pb, 11); avio_wb32(pb, 11);
put_tag(pb, "dac3"); ffio_wfourcc(pb, "dac3");
init_get_bits(&gbc, track->vosData+4, track->vosLen-4); init_get_bits(&gbc, track->vosData+4, track->vosLen-4);
fscod = get_bits(&gbc, 2); fscod = get_bits(&gbc, 2);
...@@ -231,7 +232,7 @@ static int mov_write_extradata_tag(AVIOContext *pb, MOVTrack *track) ...@@ -231,7 +232,7 @@ static int mov_write_extradata_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_enda_tag(AVIOContext *pb) static int mov_write_enda_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 10); avio_wb32(pb, 10);
put_tag(pb, "enda"); ffio_wfourcc(pb, "enda");
avio_wb16(pb, 1); /* little endian */ avio_wb16(pb, 1); /* little endian */
return 10; return 10;
} }
...@@ -258,7 +259,7 @@ static int mov_write_esds_tag(AVIOContext *pb, MOVTrack *track) // Basic ...@@ -258,7 +259,7 @@ static int mov_write_esds_tag(AVIOContext *pb, MOVTrack *track) // Basic
int decoderSpecificInfoLen = track->vosLen ? descrLength(track->vosLen):0; int decoderSpecificInfoLen = track->vosLen ? descrLength(track->vosLen):0;
avio_wb32(pb, 0); // size avio_wb32(pb, 0); // size
put_tag(pb, "esds"); ffio_wfourcc(pb, "esds");
avio_wb32(pb, 0); // Version avio_wb32(pb, 0); // Version
// ES descriptor // ES descriptor
...@@ -329,16 +330,16 @@ static int mov_write_wave_tag(AVIOContext *pb, MOVTrack *track) ...@@ -329,16 +330,16 @@ static int mov_write_wave_tag(AVIOContext *pb, MOVTrack *track)
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "wave"); ffio_wfourcc(pb, "wave");
avio_wb32(pb, 12); /* size */ avio_wb32(pb, 12); /* size */
put_tag(pb, "frma"); ffio_wfourcc(pb, "frma");
avio_wl32(pb, track->tag); avio_wl32(pb, track->tag);
if (track->enc->codec_id == CODEC_ID_AAC) { if (track->enc->codec_id == CODEC_ID_AAC) {
/* useless atom needed by mplayer, ipod, not needed by quicktime */ /* useless atom needed by mplayer, ipod, not needed by quicktime */
avio_wb32(pb, 12); /* size */ avio_wb32(pb, 12); /* size */
put_tag(pb, "mp4a"); ffio_wfourcc(pb, "mp4a");
avio_wb32(pb, 0); avio_wb32(pb, 0);
mov_write_esds_tag(pb, track); mov_write_esds_tag(pb, track);
} else if (mov_pcm_le_gt16(track->enc->codec_id)) { } else if (mov_pcm_le_gt16(track->enc->codec_id)) {
...@@ -363,7 +364,7 @@ static int mov_write_wave_tag(AVIOContext *pb, MOVTrack *track) ...@@ -363,7 +364,7 @@ static int mov_write_wave_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_glbl_tag(AVIOContext *pb, MOVTrack *track) static int mov_write_glbl_tag(AVIOContext *pb, MOVTrack *track)
{ {
avio_wb32(pb, track->vosLen+8); avio_wb32(pb, track->vosLen+8);
put_tag(pb, "glbl"); ffio_wfourcc(pb, "glbl");
avio_write(pb, track->vosData, track->vosLen); avio_write(pb, track->vosData, track->vosLen);
return 8+track->vosLen; return 8+track->vosLen;
} }
...@@ -493,8 +494,8 @@ static int mov_write_audio_tag(AVIOContext *pb, MOVTrack *track) ...@@ -493,8 +494,8 @@ static int mov_write_audio_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_d263_tag(AVIOContext *pb) static int mov_write_d263_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 0xf); /* size */ avio_wb32(pb, 0xf); /* size */
put_tag(pb, "d263"); ffio_wfourcc(pb, "d263");
put_tag(pb, "FFMP"); ffio_wfourcc(pb, "FFMP");
avio_w8(pb, 0); /* decoder version */ avio_w8(pb, 0); /* decoder version */
/* FIXME use AVCodecContext level/profile, when encoder will set values */ /* FIXME use AVCodecContext level/profile, when encoder will set values */
avio_w8(pb, 0xa); /* level */ avio_w8(pb, 0xa); /* level */
...@@ -506,8 +507,8 @@ static int mov_write_d263_tag(AVIOContext *pb) ...@@ -506,8 +507,8 @@ static int mov_write_d263_tag(AVIOContext *pb)
static int mov_write_svq3_tag(AVIOContext *pb) static int mov_write_svq3_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 0x15); avio_wb32(pb, 0x15);
put_tag(pb, "SMI "); ffio_wfourcc(pb, "SMI ");
put_tag(pb, "SEQH"); ffio_wfourcc(pb, "SEQH");
avio_wb32(pb, 0x5); avio_wb32(pb, 0x5);
avio_wb32(pb, 0xe2c0211d); avio_wb32(pb, 0xe2c0211d);
avio_wb32(pb, 0xc0000000); avio_wb32(pb, 0xc0000000);
...@@ -520,7 +521,7 @@ static int mov_write_avcc_tag(AVIOContext *pb, MOVTrack *track) ...@@ -520,7 +521,7 @@ static int mov_write_avcc_tag(AVIOContext *pb, MOVTrack *track)
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); avio_wb32(pb, 0);
put_tag(pb, "avcC"); ffio_wfourcc(pb, "avcC");
ff_isom_write_avcc(pb, track->vosData, track->vosLen); ff_isom_write_avcc(pb, track->vosData, track->vosLen);
return updateSize(pb, pos); return updateSize(pb, pos);
} }
...@@ -530,23 +531,23 @@ static int mov_write_avid_tag(AVIOContext *pb, MOVTrack *track) ...@@ -530,23 +531,23 @@ static int mov_write_avid_tag(AVIOContext *pb, MOVTrack *track)
{ {
int i; int i;
avio_wb32(pb, 24); /* size */ avio_wb32(pb, 24); /* size */
put_tag(pb, "ACLR"); ffio_wfourcc(pb, "ACLR");
put_tag(pb, "ACLR"); ffio_wfourcc(pb, "ACLR");
put_tag(pb, "0001"); ffio_wfourcc(pb, "0001");
avio_wb32(pb, 1); /* yuv 1 / rgb 2 ? */ avio_wb32(pb, 1); /* yuv 1 / rgb 2 ? */
avio_wb32(pb, 0); /* unknown */ avio_wb32(pb, 0); /* unknown */
avio_wb32(pb, 24); /* size */ avio_wb32(pb, 24); /* size */
put_tag(pb, "APRG"); ffio_wfourcc(pb, "APRG");
put_tag(pb, "APRG"); ffio_wfourcc(pb, "APRG");
put_tag(pb, "0001"); ffio_wfourcc(pb, "0001");
avio_wb32(pb, 1); /* unknown */ avio_wb32(pb, 1); /* unknown */
avio_wb32(pb, 0); /* unknown */ avio_wb32(pb, 0); /* unknown */
avio_wb32(pb, 120); /* size */ avio_wb32(pb, 120); /* size */
put_tag(pb, "ARES"); ffio_wfourcc(pb, "ARES");
put_tag(pb, "ARES"); ffio_wfourcc(pb, "ARES");
put_tag(pb, "0001"); ffio_wfourcc(pb, "0001");
avio_wb32(pb, AV_RB32(track->vosData + 0x28)); /* dnxhd cid, some id ? */ avio_wb32(pb, AV_RB32(track->vosData + 0x28)); /* dnxhd cid, some id ? */
avio_wb32(pb, track->enc->width); avio_wb32(pb, track->enc->width);
/* values below are based on samples created with quicktime and avid codecs */ /* values below are based on samples created with quicktime and avid codecs */
...@@ -741,7 +742,7 @@ static int mov_find_codec_tag(AVFormatContext *s, MOVTrack *track) ...@@ -741,7 +742,7 @@ static int mov_find_codec_tag(AVFormatContext *s, MOVTrack *track)
static int mov_write_uuid_tag_ipod(AVIOContext *pb) static int mov_write_uuid_tag_ipod(AVIOContext *pb)
{ {
avio_wb32(pb, 28); avio_wb32(pb, 28);
put_tag(pb, "uuid"); ffio_wfourcc(pb, "uuid");
avio_wb32(pb, 0x6b6840f2); avio_wb32(pb, 0x6b6840f2);
avio_wb32(pb, 0x5f244fc5); avio_wb32(pb, 0x5f244fc5);
avio_wb32(pb, 0xba39a51b); avio_wb32(pb, 0xba39a51b);
...@@ -772,7 +773,7 @@ static int mov_write_pasp_tag(AVIOContext *pb, MOVTrack *track) ...@@ -772,7 +773,7 @@ static int mov_write_pasp_tag(AVIOContext *pb, MOVTrack *track)
track->enc->sample_aspect_ratio.den, INT_MAX); track->enc->sample_aspect_ratio.den, INT_MAX);
avio_wb32(pb, 16); avio_wb32(pb, 16);
put_tag(pb, "pasp"); ffio_wfourcc(pb, "pasp");
avio_wb32(pb, sar.num); avio_wb32(pb, sar.num);
avio_wb32(pb, sar.den); avio_wb32(pb, sar.den);
return 16; return 16;
...@@ -792,7 +793,7 @@ static int mov_write_video_tag(AVIOContext *pb, MOVTrack *track) ...@@ -792,7 +793,7 @@ static int mov_write_video_tag(AVIOContext *pb, MOVTrack *track)
avio_wb16(pb, 0); /* Codec stream version */ avio_wb16(pb, 0); /* Codec stream version */
avio_wb16(pb, 0); /* Codec stream revision (=0) */ avio_wb16(pb, 0); /* Codec stream revision (=0) */
if (track->mode == MODE_MOV) { if (track->mode == MODE_MOV) {
put_tag(pb, "FFMP"); /* Vendor */ ffio_wfourcc(pb, "FFMP"); /* Vendor */
if(track->enc->codec_id == CODEC_ID_RAWVIDEO) { if(track->enc->codec_id == CODEC_ID_RAWVIDEO) {
avio_wb32(pb, 0); /* Temporal Quality */ avio_wb32(pb, 0); /* Temporal Quality */
avio_wb32(pb, 0x400); /* Spatial Quality = lossless*/ avio_wb32(pb, 0x400); /* Spatial Quality = lossless*/
...@@ -852,7 +853,7 @@ static int mov_write_rtp_tag(AVIOContext *pb, MOVTrack *track) ...@@ -852,7 +853,7 @@ static int mov_write_rtp_tag(AVIOContext *pb, MOVTrack *track)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "rtp "); ffio_wfourcc(pb, "rtp ");
avio_wb32(pb, 0); /* Reserved */ avio_wb32(pb, 0); /* Reserved */
avio_wb16(pb, 0); /* Reserved */ avio_wb16(pb, 0); /* Reserved */
avio_wb16(pb, 1); /* Data-reference index */ avio_wb16(pb, 1); /* Data-reference index */
...@@ -862,7 +863,7 @@ static int mov_write_rtp_tag(AVIOContext *pb, MOVTrack *track) ...@@ -862,7 +863,7 @@ static int mov_write_rtp_tag(AVIOContext *pb, MOVTrack *track)
avio_wb32(pb, track->max_packet_size); /* Max packet size */ avio_wb32(pb, track->max_packet_size); /* Max packet size */
avio_wb32(pb, 12); /* size */ avio_wb32(pb, 12); /* size */
put_tag(pb, "tims"); ffio_wfourcc(pb, "tims");
avio_wb32(pb, track->timescale); avio_wb32(pb, track->timescale);
return updateSize(pb, pos); return updateSize(pb, pos);
...@@ -872,7 +873,7 @@ static int mov_write_stsd_tag(AVIOContext *pb, MOVTrack *track) ...@@ -872,7 +873,7 @@ static int mov_write_stsd_tag(AVIOContext *pb, MOVTrack *track)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "stsd"); ffio_wfourcc(pb, "stsd");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb32(pb, 1); /* entry count */ avio_wb32(pb, 1); /* entry count */
if (track->enc->codec_type == AVMEDIA_TYPE_VIDEO) if (track->enc->codec_type == AVMEDIA_TYPE_VIDEO)
...@@ -908,7 +909,7 @@ static int mov_write_ctts_tag(AVIOContext *pb, MOVTrack *track) ...@@ -908,7 +909,7 @@ static int mov_write_ctts_tag(AVIOContext *pb, MOVTrack *track)
entries++; /* last one */ entries++; /* last one */
atom_size = 16 + (entries * 8); atom_size = 16 + (entries * 8);
avio_wb32(pb, atom_size); /* size */ avio_wb32(pb, atom_size); /* size */
put_tag(pb, "ctts"); ffio_wfourcc(pb, "ctts");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb32(pb, entries); /* entry count */ avio_wb32(pb, entries); /* entry count */
for (i=0; i<entries; i++) { for (i=0; i<entries; i++) {
...@@ -950,7 +951,7 @@ static int mov_write_stts_tag(AVIOContext *pb, MOVTrack *track) ...@@ -950,7 +951,7 @@ static int mov_write_stts_tag(AVIOContext *pb, MOVTrack *track)
} }
atom_size = 16 + (entries * 8); atom_size = 16 + (entries * 8);
avio_wb32(pb, atom_size); /* size */ avio_wb32(pb, atom_size); /* size */
put_tag(pb, "stts"); ffio_wfourcc(pb, "stts");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb32(pb, entries); /* entry count */ avio_wb32(pb, entries); /* entry count */
for (i=0; i<entries; i++) { for (i=0; i<entries; i++) {
...@@ -964,12 +965,12 @@ static int mov_write_stts_tag(AVIOContext *pb, MOVTrack *track) ...@@ -964,12 +965,12 @@ static int mov_write_stts_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_dref_tag(AVIOContext *pb) static int mov_write_dref_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 28); /* size */ avio_wb32(pb, 28); /* size */
put_tag(pb, "dref"); ffio_wfourcc(pb, "dref");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb32(pb, 1); /* entry count */ avio_wb32(pb, 1); /* entry count */
avio_wb32(pb, 0xc); /* size */ avio_wb32(pb, 0xc); /* size */
put_tag(pb, "url "); ffio_wfourcc(pb, "url ");
avio_wb32(pb, 1); /* version & flags */ avio_wb32(pb, 1); /* version & flags */
return 28; return 28;
...@@ -979,7 +980,7 @@ static int mov_write_stbl_tag(AVIOContext *pb, MOVTrack *track) ...@@ -979,7 +980,7 @@ static int mov_write_stbl_tag(AVIOContext *pb, MOVTrack *track)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "stbl"); ffio_wfourcc(pb, "stbl");
mov_write_stsd_tag(pb, track); mov_write_stsd_tag(pb, track);
mov_write_stts_tag(pb, track); mov_write_stts_tag(pb, track);
if ((track->enc->codec_type == AVMEDIA_TYPE_VIDEO || if ((track->enc->codec_type == AVMEDIA_TYPE_VIDEO ||
...@@ -1001,7 +1002,7 @@ static int mov_write_dinf_tag(AVIOContext *pb) ...@@ -1001,7 +1002,7 @@ static int mov_write_dinf_tag(AVIOContext *pb)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "dinf"); ffio_wfourcc(pb, "dinf");
mov_write_dref_tag(pb); mov_write_dref_tag(pb);
return updateSize(pb, pos); return updateSize(pb, pos);
} }
...@@ -1009,7 +1010,7 @@ static int mov_write_dinf_tag(AVIOContext *pb) ...@@ -1009,7 +1010,7 @@ static int mov_write_dinf_tag(AVIOContext *pb)
static int mov_write_nmhd_tag(AVIOContext *pb) static int mov_write_nmhd_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 12); avio_wb32(pb, 12);
put_tag(pb, "nmhd"); ffio_wfourcc(pb, "nmhd");
avio_wb32(pb, 0); avio_wb32(pb, 0);
return 12; return 12;
} }
...@@ -1017,9 +1018,9 @@ static int mov_write_nmhd_tag(AVIOContext *pb) ...@@ -1017,9 +1018,9 @@ static int mov_write_nmhd_tag(AVIOContext *pb)
static int mov_write_gmhd_tag(AVIOContext *pb) static int mov_write_gmhd_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 0x20); /* size */ avio_wb32(pb, 0x20); /* size */
put_tag(pb, "gmhd"); ffio_wfourcc(pb, "gmhd");
avio_wb32(pb, 0x18); /* gmin size */ avio_wb32(pb, 0x18); /* gmin size */
put_tag(pb, "gmin"); /* generic media info */ ffio_wfourcc(pb, "gmin");/* generic media info */
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb16(pb, 0x40); /* graphics mode = */ avio_wb16(pb, 0x40); /* graphics mode = */
avio_wb16(pb, 0x8000); /* opColor (r?) */ avio_wb16(pb, 0x8000); /* opColor (r?) */
...@@ -1033,7 +1034,7 @@ static int mov_write_gmhd_tag(AVIOContext *pb) ...@@ -1033,7 +1034,7 @@ static int mov_write_gmhd_tag(AVIOContext *pb)
static int mov_write_smhd_tag(AVIOContext *pb) static int mov_write_smhd_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 16); /* size */ avio_wb32(pb, 16); /* size */
put_tag(pb, "smhd"); ffio_wfourcc(pb, "smhd");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb16(pb, 0); /* reserved (balance, normally = 0) */ avio_wb16(pb, 0); /* reserved (balance, normally = 0) */
avio_wb16(pb, 0); /* reserved */ avio_wb16(pb, 0); /* reserved */
...@@ -1043,7 +1044,7 @@ static int mov_write_smhd_tag(AVIOContext *pb) ...@@ -1043,7 +1044,7 @@ static int mov_write_smhd_tag(AVIOContext *pb)
static int mov_write_vmhd_tag(AVIOContext *pb) static int mov_write_vmhd_tag(AVIOContext *pb)
{ {
avio_wb32(pb, 0x14); /* size (always 0x14) */ avio_wb32(pb, 0x14); /* size (always 0x14) */
put_tag(pb, "vmhd"); ffio_wfourcc(pb, "vmhd");
avio_wb32(pb, 0x01); /* version & flags */ avio_wb32(pb, 0x01); /* version & flags */
avio_wb64(pb, 0); /* reserved (graphics mode = copy) */ avio_wb64(pb, 0); /* reserved (graphics mode = copy) */
return 0x14; return 0x14;
...@@ -1077,10 +1078,10 @@ static int mov_write_hdlr_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1077,10 +1078,10 @@ static int mov_write_hdlr_tag(AVIOContext *pb, MOVTrack *track)
} }
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "hdlr"); ffio_wfourcc(pb, "hdlr");
avio_wb32(pb, 0); /* Version & flags */ avio_wb32(pb, 0); /* Version & flags */
avio_write(pb, hdlr, 4); /* handler */ avio_write(pb, hdlr, 4); /* handler */
put_tag(pb, hdlr_type); /* handler type */ ffio_wfourcc(pb, hdlr_type); /* handler type */
avio_wb32(pb ,0); /* reserved */ avio_wb32(pb ,0); /* reserved */
avio_wb32(pb ,0); /* reserved */ avio_wb32(pb ,0); /* reserved */
avio_wb32(pb ,0); /* reserved */ avio_wb32(pb ,0); /* reserved */
...@@ -1097,7 +1098,7 @@ static int mov_write_hmhd_tag(AVIOContext *pb) ...@@ -1097,7 +1098,7 @@ static int mov_write_hmhd_tag(AVIOContext *pb)
/* This atom must be present, but leaving the values at zero /* This atom must be present, but leaving the values at zero
* seems harmless. */ * seems harmless. */
avio_wb32(pb, 28); /* size */ avio_wb32(pb, 28); /* size */
put_tag(pb, "hmhd"); ffio_wfourcc(pb, "hmhd");
avio_wb32(pb, 0); /* version, flags */ avio_wb32(pb, 0); /* version, flags */
avio_wb16(pb, 0); /* maxPDUsize */ avio_wb16(pb, 0); /* maxPDUsize */
avio_wb16(pb, 0); /* avgPDUsize */ avio_wb16(pb, 0); /* avgPDUsize */
...@@ -1111,7 +1112,7 @@ static int mov_write_minf_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1111,7 +1112,7 @@ static int mov_write_minf_tag(AVIOContext *pb, MOVTrack *track)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "minf"); ffio_wfourcc(pb, "minf");
if(track->enc->codec_type == AVMEDIA_TYPE_VIDEO) if(track->enc->codec_type == AVMEDIA_TYPE_VIDEO)
mov_write_vmhd_tag(pb); mov_write_vmhd_tag(pb);
else if (track->enc->codec_type == AVMEDIA_TYPE_AUDIO) else if (track->enc->codec_type == AVMEDIA_TYPE_AUDIO)
...@@ -1134,7 +1135,7 @@ static int mov_write_mdhd_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1134,7 +1135,7 @@ static int mov_write_mdhd_tag(AVIOContext *pb, MOVTrack *track)
int version = track->trackDuration < INT32_MAX ? 0 : 1; int version = track->trackDuration < INT32_MAX ? 0 : 1;
(version == 1) ? avio_wb32(pb, 44) : avio_wb32(pb, 32); /* size */ (version == 1) ? avio_wb32(pb, 44) : avio_wb32(pb, 32); /* size */
put_tag(pb, "mdhd"); ffio_wfourcc(pb, "mdhd");
avio_w8(pb, version); avio_w8(pb, version);
avio_wb24(pb, 0); /* flags */ avio_wb24(pb, 0); /* flags */
if (version == 1) { if (version == 1) {
...@@ -1163,7 +1164,7 @@ static int mov_write_mdia_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1163,7 +1164,7 @@ static int mov_write_mdia_tag(AVIOContext *pb, MOVTrack *track)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "mdia"); ffio_wfourcc(pb, "mdia");
mov_write_mdhd_tag(pb, track); mov_write_mdhd_tag(pb, track);
mov_write_hdlr_tag(pb, track); mov_write_hdlr_tag(pb, track);
mov_write_minf_tag(pb, track); mov_write_minf_tag(pb, track);
...@@ -1177,7 +1178,7 @@ static int mov_write_tkhd_tag(AVIOContext *pb, MOVTrack *track, AVStream *st) ...@@ -1177,7 +1178,7 @@ static int mov_write_tkhd_tag(AVIOContext *pb, MOVTrack *track, AVStream *st)
int version = duration < INT32_MAX ? 0 : 1; int version = duration < INT32_MAX ? 0 : 1;
(version == 1) ? avio_wb32(pb, 104) : avio_wb32(pb, 92); /* size */ (version == 1) ? avio_wb32(pb, 104) : avio_wb32(pb, 92); /* size */
put_tag(pb, "tkhd"); ffio_wfourcc(pb, "tkhd");
avio_w8(pb, version); avio_w8(pb, version);
avio_wb24(pb, 0xf); /* flags (track enabled) */ avio_wb24(pb, 0xf); /* flags (track enabled) */
if (version == 1) { if (version == 1) {
...@@ -1232,9 +1233,9 @@ static int mov_write_tkhd_tag(AVIOContext *pb, MOVTrack *track, AVStream *st) ...@@ -1232,9 +1233,9 @@ static int mov_write_tkhd_tag(AVIOContext *pb, MOVTrack *track, AVStream *st)
static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track) static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track)
{ {
avio_wb32(pb, 0x24); /* size */ avio_wb32(pb, 0x24); /* size */
put_tag(pb, "edts"); ffio_wfourcc(pb, "edts");
avio_wb32(pb, 0x1c); /* size */ avio_wb32(pb, 0x1c); /* size */
put_tag(pb, "elst"); ffio_wfourcc(pb, "elst");
avio_wb32(pb, 0x0); avio_wb32(pb, 0x0);
avio_wb32(pb, 0x1); avio_wb32(pb, 0x1);
...@@ -1250,7 +1251,7 @@ static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1250,7 +1251,7 @@ static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_tref_tag(AVIOContext *pb, MOVTrack *track) static int mov_write_tref_tag(AVIOContext *pb, MOVTrack *track)
{ {
avio_wb32(pb, 20); // size avio_wb32(pb, 20); // size
put_tag(pb, "tref"); ffio_wfourcc(pb, "tref");
avio_wb32(pb, 12); // size (subatom) avio_wb32(pb, 12); // size (subatom)
avio_wl32(pb, track->tref_tag); avio_wl32(pb, track->tref_tag);
avio_wb32(pb, track->tref_id); avio_wb32(pb, track->tref_id);
...@@ -1261,13 +1262,13 @@ static int mov_write_tref_tag(AVIOContext *pb, MOVTrack *track) ...@@ -1261,13 +1262,13 @@ static int mov_write_tref_tag(AVIOContext *pb, MOVTrack *track)
static int mov_write_uuid_tag_psp(AVIOContext *pb, MOVTrack *mov) static int mov_write_uuid_tag_psp(AVIOContext *pb, MOVTrack *mov)
{ {
avio_wb32(pb, 0x34); /* size ... reports as 28 in mp4box! */ avio_wb32(pb, 0x34); /* size ... reports as 28 in mp4box! */
put_tag(pb, "uuid"); ffio_wfourcc(pb, "uuid");
put_tag(pb, "USMT"); ffio_wfourcc(pb, "USMT");
avio_wb32(pb, 0x21d24fce); avio_wb32(pb, 0x21d24fce);
avio_wb32(pb, 0xbb88695c); avio_wb32(pb, 0xbb88695c);
avio_wb32(pb, 0xfac9c740); avio_wb32(pb, 0xfac9c740);
avio_wb32(pb, 0x1c); // another size here! avio_wb32(pb, 0x1c); // another size here!
put_tag(pb, "MTDT"); ffio_wfourcc(pb, "MTDT");
avio_wb32(pb, 0x00010012); avio_wb32(pb, 0x00010012);
avio_wb32(pb, 0x0a); avio_wb32(pb, 0x0a);
avio_wb32(pb, 0x55c40000); avio_wb32(pb, 0x55c40000);
...@@ -1286,11 +1287,11 @@ static int mov_write_udta_sdp(AVIOContext *pb, AVCodecContext *ctx, int index) ...@@ -1286,11 +1287,11 @@ static int mov_write_udta_sdp(AVIOContext *pb, AVCodecContext *ctx, int index)
len = strlen(buf); len = strlen(buf);
avio_wb32(pb, len + 24); avio_wb32(pb, len + 24);
put_tag (pb, "udta"); ffio_wfourcc(pb, "udta");
avio_wb32(pb, len + 16); avio_wb32(pb, len + 16);
put_tag (pb, "hnti"); ffio_wfourcc(pb, "hnti");
avio_wb32(pb, len + 8); avio_wb32(pb, len + 8);
put_tag (pb, "sdp "); ffio_wfourcc(pb, "sdp ");
avio_write(pb, buf, len); avio_write(pb, buf, len);
return len + 24; return len + 24;
} }
...@@ -1299,7 +1300,7 @@ static int mov_write_trak_tag(AVIOContext *pb, MOVTrack *track, AVStream *st) ...@@ -1299,7 +1300,7 @@ static int mov_write_trak_tag(AVIOContext *pb, MOVTrack *track, AVStream *st)
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "trak"); ffio_wfourcc(pb, "trak");
mov_write_tkhd_tag(pb, track, st); mov_write_tkhd_tag(pb, track, st);
if (track->mode == MODE_PSP || track->flags & MOV_TRACK_CTTS) if (track->mode == MODE_PSP || track->flags & MOV_TRACK_CTTS)
mov_write_edts_tag(pb, track); // PSP Movies require edts box mov_write_edts_tag(pb, track); // PSP Movies require edts box
...@@ -1318,7 +1319,7 @@ static int mov_write_trak_tag(AVIOContext *pb, MOVTrack *track, AVStream *st) ...@@ -1318,7 +1319,7 @@ static int mov_write_trak_tag(AVIOContext *pb, MOVTrack *track, AVStream *st)
static int mov_write_iods_tag(AVIOContext *pb, MOVMuxContext *mov) static int mov_write_iods_tag(AVIOContext *pb, MOVMuxContext *mov)
{ {
avio_wb32(pb, 0x15); /* size */ avio_wb32(pb, 0x15); /* size */
put_tag(pb, "iods"); ffio_wfourcc(pb, "iods");
avio_wb32(pb, 0); /* version & flags */ avio_wb32(pb, 0); /* version & flags */
avio_wb16(pb, 0x1007); avio_wb16(pb, 0x1007);
avio_w8(pb, 0); avio_w8(pb, 0);
...@@ -1350,7 +1351,7 @@ static int mov_write_mvhd_tag(AVIOContext *pb, MOVMuxContext *mov) ...@@ -1350,7 +1351,7 @@ static int mov_write_mvhd_tag(AVIOContext *pb, MOVMuxContext *mov)
version = maxTrackLen < UINT32_MAX ? 0 : 1; version = maxTrackLen < UINT32_MAX ? 0 : 1;
(version == 1) ? avio_wb32(pb, 120) : avio_wb32(pb, 108); /* size */ (version == 1) ? avio_wb32(pb, 120) : avio_wb32(pb, 108); /* size */
put_tag(pb, "mvhd"); ffio_wfourcc(pb, "mvhd");
avio_w8(pb, version); avio_w8(pb, version);
avio_wb24(pb, 0); /* flags */ avio_wb24(pb, 0); /* flags */
if (version == 1) { if (version == 1) {
...@@ -1394,11 +1395,11 @@ static int mov_write_itunes_hdlr_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1394,11 +1395,11 @@ static int mov_write_itunes_hdlr_tag(AVIOContext *pb, MOVMuxContext *mov,
AVFormatContext *s) AVFormatContext *s)
{ {
avio_wb32(pb, 33); /* size */ avio_wb32(pb, 33); /* size */
put_tag(pb, "hdlr"); ffio_wfourcc(pb, "hdlr");
avio_wb32(pb, 0); avio_wb32(pb, 0);
avio_wb32(pb, 0); avio_wb32(pb, 0);
put_tag(pb, "mdir"); ffio_wfourcc(pb, "mdir");
put_tag(pb, "appl"); ffio_wfourcc(pb, "appl");
avio_wb32(pb, 0); avio_wb32(pb, 0);
avio_wb32(pb, 0); avio_wb32(pb, 0);
avio_w8(pb, 0); avio_w8(pb, 0);
...@@ -1411,7 +1412,7 @@ static int mov_write_string_data_tag(AVIOContext *pb, const char *data, int lang ...@@ -1411,7 +1412,7 @@ static int mov_write_string_data_tag(AVIOContext *pb, const char *data, int lang
if(long_style){ if(long_style){
int size = 16 + strlen(data); int size = 16 + strlen(data);
avio_wb32(pb, size); /* size */ avio_wb32(pb, size); /* size */
put_tag(pb, "data"); ffio_wfourcc(pb, "data");
avio_wb32(pb, 1); avio_wb32(pb, 1);
avio_wb32(pb, 0); avio_wb32(pb, 0);
avio_write(pb, data, strlen(data)); avio_write(pb, data, strlen(data));
...@@ -1431,7 +1432,7 @@ static int mov_write_string_tag(AVIOContext *pb, const char *name, const char *v ...@@ -1431,7 +1432,7 @@ static int mov_write_string_tag(AVIOContext *pb, const char *name, const char *v
if (value && value[0]) { if (value && value[0]) {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, name); ffio_wfourcc(pb, name);
mov_write_string_data_tag(pb, value, lang, long_style); mov_write_string_data_tag(pb, value, lang, long_style);
size= updateSize(pb, pos); size= updateSize(pb, pos);
} }
...@@ -1470,9 +1471,9 @@ static int mov_write_trkn_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1470,9 +1471,9 @@ static int mov_write_trkn_tag(AVIOContext *pb, MOVMuxContext *mov,
int size = 0, track = t ? atoi(t->value) : 0; int size = 0, track = t ? atoi(t->value) : 0;
if (track) { if (track) {
avio_wb32(pb, 32); /* size */ avio_wb32(pb, 32); /* size */
put_tag(pb, "trkn"); ffio_wfourcc(pb, "trkn");
avio_wb32(pb, 24); /* size */ avio_wb32(pb, 24); /* size */
put_tag(pb, "data"); ffio_wfourcc(pb, "data");
avio_wb32(pb, 0); // 8 bytes empty avio_wb32(pb, 0); // 8 bytes empty
avio_wb32(pb, 0); avio_wb32(pb, 0);
avio_wb16(pb, 0); // empty avio_wb16(pb, 0); // empty
...@@ -1490,7 +1491,7 @@ static int mov_write_ilst_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1490,7 +1491,7 @@ static int mov_write_ilst_tag(AVIOContext *pb, MOVMuxContext *mov,
{ {
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "ilst"); ffio_wfourcc(pb, "ilst");
mov_write_string_metadata(s, pb, "\251nam", "title" , 1); mov_write_string_metadata(s, pb, "\251nam", "title" , 1);
mov_write_string_metadata(s, pb, "\251ART", "artist" , 1); mov_write_string_metadata(s, pb, "\251ART", "artist" , 1);
mov_write_string_metadata(s, pb, "aART", "album_artist", 1); mov_write_string_metadata(s, pb, "aART", "album_artist", 1);
...@@ -1519,7 +1520,7 @@ static int mov_write_meta_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1519,7 +1520,7 @@ static int mov_write_meta_tag(AVIOContext *pb, MOVMuxContext *mov,
int size = 0; int size = 0;
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "meta"); ffio_wfourcc(pb, "meta");
avio_wb32(pb, 0); avio_wb32(pb, 0);
mov_write_itunes_hdlr_tag(pb, mov, s); mov_write_itunes_hdlr_tag(pb, mov, s);
mov_write_ilst_tag(pb, mov, s); mov_write_ilst_tag(pb, mov, s);
...@@ -1562,7 +1563,7 @@ static int mov_write_3gp_udta_tag(AVIOContext *pb, AVFormatContext *s, ...@@ -1562,7 +1563,7 @@ static int mov_write_3gp_udta_tag(AVIOContext *pb, AVFormatContext *s,
if (!t || !utf8len(t->value)) if (!t || !utf8len(t->value))
return 0; return 0;
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag (pb, tag); /* type */ ffio_wfourcc(pb, tag); /* type */
avio_wb32(pb, 0); /* version + flags */ avio_wb32(pb, 0); /* version + flags */
if (!strcmp(tag, "yrrc")) if (!strcmp(tag, "yrrc"))
avio_wb16(pb, atoi(t->value)); avio_wb16(pb, atoi(t->value));
...@@ -1582,7 +1583,7 @@ static int mov_write_chpl_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1582,7 +1583,7 @@ static int mov_write_chpl_tag(AVIOContext *pb, AVFormatContext *s)
int i, nb_chapters = FFMIN(s->nb_chapters, 255); int i, nb_chapters = FFMIN(s->nb_chapters, 255);
avio_wb32(pb, 0); // size avio_wb32(pb, 0); // size
put_tag (pb, "chpl"); ffio_wfourcc(pb, "chpl");
avio_wb32(pb, 0x01000000); // version + flags avio_wb32(pb, 0x01000000); // version + flags
avio_wb32(pb, 0); // unknown avio_wb32(pb, 0); // unknown
avio_w8(pb, nb_chapters); avio_w8(pb, nb_chapters);
...@@ -1647,7 +1648,7 @@ static int mov_write_udta_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1647,7 +1648,7 @@ static int mov_write_udta_tag(AVIOContext *pb, MOVMuxContext *mov,
if ((size = url_close_dyn_buf(pb_buf, &buf)) > 0) { if ((size = url_close_dyn_buf(pb_buf, &buf)) > 0) {
avio_wb32(pb, size+8); avio_wb32(pb, size+8);
put_tag(pb, "udta"); ffio_wfourcc(pb, "udta");
avio_write(pb, buf, size); avio_write(pb, buf, size);
} }
av_free(buf); av_free(buf);
...@@ -1676,15 +1677,15 @@ static int mov_write_uuidusmt_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1676,15 +1677,15 @@ static int mov_write_uuidusmt_tag(AVIOContext *pb, AVFormatContext *s)
if (title) { if (title) {
pos = url_ftell(pb); pos = url_ftell(pb);
avio_wb32(pb, 0); /* size placeholder*/ avio_wb32(pb, 0); /* size placeholder*/
put_tag(pb, "uuid"); ffio_wfourcc(pb, "uuid");
put_tag(pb, "USMT"); ffio_wfourcc(pb, "USMT");
avio_wb32(pb, 0x21d24fce); /* 96 bit UUID */ avio_wb32(pb, 0x21d24fce); /* 96 bit UUID */
avio_wb32(pb, 0xbb88695c); avio_wb32(pb, 0xbb88695c);
avio_wb32(pb, 0xfac9c740); avio_wb32(pb, 0xfac9c740);
pos2 = url_ftell(pb); pos2 = url_ftell(pb);
avio_wb32(pb, 0); /* size placeholder*/ avio_wb32(pb, 0); /* size placeholder*/
put_tag(pb, "MTDT"); ffio_wfourcc(pb, "MTDT");
avio_wb16(pb, 4); avio_wb16(pb, 4);
// ? // ?
...@@ -1712,7 +1713,7 @@ static int mov_write_moov_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1712,7 +1713,7 @@ static int mov_write_moov_tag(AVIOContext *pb, MOVMuxContext *mov,
int i; int i;
int64_t pos = url_ftell(pb); int64_t pos = url_ftell(pb);
avio_wb32(pb, 0); /* size placeholder*/ avio_wb32(pb, 0); /* size placeholder*/
put_tag(pb, "moov"); ffio_wfourcc(pb, "moov");
for (i=0; i<mov->nb_streams; i++) { for (i=0; i<mov->nb_streams; i++) {
if(mov->tracks[i].entry <= 0) continue; if(mov->tracks[i].entry <= 0) continue;
...@@ -1753,11 +1754,11 @@ static int mov_write_moov_tag(AVIOContext *pb, MOVMuxContext *mov, ...@@ -1753,11 +1754,11 @@ static int mov_write_moov_tag(AVIOContext *pb, MOVMuxContext *mov,
static int mov_write_mdat_tag(AVIOContext *pb, MOVMuxContext *mov) static int mov_write_mdat_tag(AVIOContext *pb, MOVMuxContext *mov)
{ {
avio_wb32(pb, 8); // placeholder for extended size field (64 bit) avio_wb32(pb, 8); // placeholder for extended size field (64 bit)
put_tag(pb, mov->mode == MODE_MOV ? "wide" : "free"); ffio_wfourcc(pb, mov->mode == MODE_MOV ? "wide" : "free");
mov->mdat_pos = url_ftell(pb); mov->mdat_pos = url_ftell(pb);
avio_wb32(pb, 0); /* size placeholder*/ avio_wb32(pb, 0); /* size placeholder*/
put_tag(pb, "mdat"); ffio_wfourcc(pb, "mdat");
return 0; return 0;
} }
...@@ -1779,42 +1780,42 @@ static int mov_write_ftyp_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1779,42 +1780,42 @@ static int mov_write_ftyp_tag(AVIOContext *pb, AVFormatContext *s)
} }
avio_wb32(pb, 0); /* size */ avio_wb32(pb, 0); /* size */
put_tag(pb, "ftyp"); ffio_wfourcc(pb, "ftyp");
if (mov->mode == MODE_3GP) { if (mov->mode == MODE_3GP) {
put_tag(pb, has_h264 ? "3gp6" : "3gp4"); ffio_wfourcc(pb, has_h264 ? "3gp6" : "3gp4");
minor = has_h264 ? 0x100 : 0x200; minor = has_h264 ? 0x100 : 0x200;
} else if (mov->mode & MODE_3G2) { } else if (mov->mode & MODE_3G2) {
put_tag(pb, has_h264 ? "3g2b" : "3g2a"); ffio_wfourcc(pb, has_h264 ? "3g2b" : "3g2a");
minor = has_h264 ? 0x20000 : 0x10000; minor = has_h264 ? 0x20000 : 0x10000;
}else if (mov->mode == MODE_PSP) }else if (mov->mode == MODE_PSP)
put_tag(pb, "MSNV"); ffio_wfourcc(pb, "MSNV");
else if (mov->mode == MODE_MP4) else if (mov->mode == MODE_MP4)
put_tag(pb, "isom"); ffio_wfourcc(pb, "isom");
else if (mov->mode == MODE_IPOD) else if (mov->mode == MODE_IPOD)
put_tag(pb, has_video ? "M4V ":"M4A "); ffio_wfourcc(pb, has_video ? "M4V ":"M4A ");
else else
put_tag(pb, "qt "); ffio_wfourcc(pb, "qt ");
avio_wb32(pb, minor); avio_wb32(pb, minor);
if(mov->mode == MODE_MOV) if(mov->mode == MODE_MOV)
put_tag(pb, "qt "); ffio_wfourcc(pb, "qt ");
else{ else{
put_tag(pb, "isom"); ffio_wfourcc(pb, "isom");
put_tag(pb, "iso2"); ffio_wfourcc(pb, "iso2");
if(has_h264) if(has_h264)
put_tag(pb, "avc1"); ffio_wfourcc(pb, "avc1");
} }
if (mov->mode == MODE_3GP) if (mov->mode == MODE_3GP)
put_tag(pb, has_h264 ? "3gp6":"3gp4"); ffio_wfourcc(pb, has_h264 ? "3gp6":"3gp4");
else if (mov->mode & MODE_3G2) else if (mov->mode & MODE_3G2)
put_tag(pb, has_h264 ? "3g2b":"3g2a"); ffio_wfourcc(pb, has_h264 ? "3g2b":"3g2a");
else if (mov->mode == MODE_PSP) else if (mov->mode == MODE_PSP)
put_tag(pb, "MSNV"); ffio_wfourcc(pb, "MSNV");
else if (mov->mode == MODE_MP4) else if (mov->mode == MODE_MP4)
put_tag(pb, "mp41"); ffio_wfourcc(pb, "mp41");
return updateSize(pb, pos); return updateSize(pb, pos);
} }
...@@ -1828,8 +1829,8 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1828,8 +1829,8 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s)
int video_kbitrate= FFMIN(VideoCodec->bit_rate / 1000, 800 - audio_kbitrate); int video_kbitrate= FFMIN(VideoCodec->bit_rate / 1000, 800 - audio_kbitrate);
avio_wb32(pb, 0x94); /* size */ avio_wb32(pb, 0x94); /* size */
put_tag(pb, "uuid"); ffio_wfourcc(pb, "uuid");
put_tag(pb, "PROF"); ffio_wfourcc(pb, "PROF");
avio_wb32(pb, 0x21d24fce); /* 96 bit UUID */ avio_wb32(pb, 0x21d24fce); /* 96 bit UUID */
avio_wb32(pb, 0xbb88695c); avio_wb32(pb, 0xbb88695c);
...@@ -1839,16 +1840,16 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1839,16 +1840,16 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s)
avio_wb32(pb, 0x3); /* 3 sections ? */ avio_wb32(pb, 0x3); /* 3 sections ? */
avio_wb32(pb, 0x14); /* size */ avio_wb32(pb, 0x14); /* size */
put_tag(pb, "FPRF"); ffio_wfourcc(pb, "FPRF");
avio_wb32(pb, 0x0); /* ? */ avio_wb32(pb, 0x0); /* ? */
avio_wb32(pb, 0x0); /* ? */ avio_wb32(pb, 0x0); /* ? */
avio_wb32(pb, 0x0); /* ? */ avio_wb32(pb, 0x0); /* ? */
avio_wb32(pb, 0x2c); /* size */ avio_wb32(pb, 0x2c); /* size */
put_tag(pb, "APRF"); /* audio */ ffio_wfourcc(pb, "APRF");/* audio */
avio_wb32(pb, 0x0); avio_wb32(pb, 0x0);
avio_wb32(pb, 0x2); /* TrackID */ avio_wb32(pb, 0x2); /* TrackID */
put_tag(pb, "mp4a"); ffio_wfourcc(pb, "mp4a");
avio_wb32(pb, 0x20f); avio_wb32(pb, 0x20f);
avio_wb32(pb, 0x0); avio_wb32(pb, 0x0);
avio_wb32(pb, audio_kbitrate); avio_wb32(pb, audio_kbitrate);
...@@ -1857,15 +1858,15 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s) ...@@ -1857,15 +1858,15 @@ static void mov_write_uuidprof_tag(AVIOContext *pb, AVFormatContext *s)
avio_wb32(pb, AudioCodec->channels); avio_wb32(pb, AudioCodec->channels);
avio_wb32(pb, 0x34); /* size */ avio_wb32(pb, 0x34); /* size */
put_tag(pb, "VPRF"); /* video */ ffio_wfourcc(pb, "VPRF"); /* video */
avio_wb32(pb, 0x0); avio_wb32(pb, 0x0);
avio_wb32(pb, 0x1); /* TrackID */ avio_wb32(pb, 0x1); /* TrackID */
if (VideoCodec->codec_id == CODEC_ID_H264) { if (VideoCodec->codec_id == CODEC_ID_H264) {
put_tag(pb, "avc1"); ffio_wfourcc(pb, "avc1");
avio_wb16(pb, 0x014D); avio_wb16(pb, 0x014D);
avio_wb16(pb, 0x0015); avio_wb16(pb, 0x0015);
} else { } else {
put_tag(pb, "mp4v"); ffio_wfourcc(pb, "mp4v");
avio_wb16(pb, 0x0000); avio_wb16(pb, 0x0000);
avio_wb16(pb, 0x0103); avio_wb16(pb, 0x0103);
} }
...@@ -2206,7 +2207,7 @@ static int mov_write_trailer(AVFormatContext *s) ...@@ -2206,7 +2207,7 @@ static int mov_write_trailer(AVFormatContext *s)
/* overwrite 'wide' placeholder atom */ /* overwrite 'wide' placeholder atom */
url_fseek(pb, mov->mdat_pos - 8, SEEK_SET); url_fseek(pb, mov->mdat_pos - 8, SEEK_SET);
avio_wb32(pb, 1); /* special value: real atom size will be 64 bit value after tag field */ avio_wb32(pb, 1); /* special value: real atom size will be 64 bit value after tag field */
put_tag(pb, "mdat"); ffio_wfourcc(pb, "mdat");
avio_wb64(pb, mov->mdat_size+16); avio_wb64(pb, mov->mdat_size+16);
} }
url_fseek(pb, moov_pos, SEEK_SET); url_fseek(pb, moov_pos, SEEK_SET);
......
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "libavcodec/bytestream.h" #include "libavcodec/bytestream.h"
#include "libavcodec/flac.h" #include "libavcodec/flac.h"
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "internal.h" #include "internal.h"
#include "vorbiscomment.h" #include "vorbiscomment.h"
...@@ -85,7 +86,7 @@ static int ogg_write_page(AVFormatContext *s, OGGPage *page, int extra_flags) ...@@ -85,7 +86,7 @@ static int ogg_write_page(AVFormatContext *s, OGGPage *page, int extra_flags)
if (ret < 0) if (ret < 0)
return ret; return ret;
init_checksum(pb, ff_crc04C11DB7_update, 0); init_checksum(pb, ff_crc04C11DB7_update, 0);
put_tag(pb, "OggS"); ffio_wfourcc(pb, "OggS");
avio_w8(pb, 0); avio_w8(pb, 0);
avio_w8(pb, page->flags | extra_flags); avio_w8(pb, page->flags | extra_flags);
avio_wl64(pb, page->granule); avio_wl64(pb, page->granule);
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include "libavcodec/avcodec.h" #include "libavcodec/avcodec.h"
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "riff.h" #include "riff.h"
#include "libavcodec/bytestream.h" #include "libavcodec/bytestream.h"
...@@ -321,7 +322,7 @@ const AVCodecTag ff_codec_wav_tags[] = { ...@@ -321,7 +322,7 @@ const AVCodecTag ff_codec_wav_tags[] = {
#if CONFIG_MUXERS #if CONFIG_MUXERS
int64_t ff_start_tag(AVIOContext *pb, const char *tag) int64_t ff_start_tag(AVIOContext *pb, const char *tag)
{ {
put_tag(pb, tag); ffio_wfourcc(pb, tag);
avio_wl32(pb, 0); avio_wl32(pb, 0);
return url_ftell(pb); return url_ftell(pb);
} }
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "rm.h" #include "rm.h"
typedef struct { typedef struct {
...@@ -74,13 +75,13 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -74,13 +75,13 @@ static int rv10_write_header(AVFormatContext *ctx,
start_ptr = s->buf_ptr; start_ptr = s->buf_ptr;
put_tag(s, ".RMF"); ffio_wfourcc(s, ".RMF");
avio_wb32(s,18); /* header size */ avio_wb32(s,18); /* header size */
avio_wb16(s,0); avio_wb16(s,0);
avio_wb32(s,0); avio_wb32(s,0);
avio_wb32(s,4 + ctx->nb_streams); /* num headers */ avio_wb32(s,4 + ctx->nb_streams); /* num headers */
put_tag(s,"PROP"); ffio_wfourcc(s,"PROP");
avio_wb32(s, 50); avio_wb32(s, 50);
avio_wb16(s, 0); avio_wb16(s, 0);
packet_max_size = 0; packet_max_size = 0;
...@@ -123,7 +124,7 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -123,7 +124,7 @@ static int rv10_write_header(AVFormatContext *ctx,
/* comments */ /* comments */
put_tag(s,"CONT"); ffio_wfourcc(s,"CONT");
size = 4 * 2 + 10; size = 4 * 2 + 10;
for(i=0; i<FF_ARRAY_ELEMS(ff_rm_metadata); i++) { for(i=0; i<FF_ARRAY_ELEMS(ff_rm_metadata); i++) {
tag = av_metadata_get(ctx->metadata, ff_rm_metadata[i], NULL, 0); tag = av_metadata_get(ctx->metadata, ff_rm_metadata[i], NULL, 0);
...@@ -151,7 +152,7 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -151,7 +152,7 @@ static int rv10_write_header(AVFormatContext *ctx,
codec_data_size = 34; codec_data_size = 34;
} }
put_tag(s,"MDPR"); ffio_wfourcc(s,"MDPR");
size = 10 + 9 * 4 + strlen(desc) + strlen(mimetype) + codec_data_size; size = 10 + 9 * 4 + strlen(desc) + strlen(mimetype) + codec_data_size;
avio_wb32(s, size); avio_wb32(s, size);
avio_wb16(s, 0); avio_wb16(s, 0);
...@@ -186,7 +187,7 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -186,7 +187,7 @@ static int rv10_write_header(AVFormatContext *ctx,
put_tag(s, ".ra"); put_tag(s, ".ra");
avio_w8(s, 0xfd); avio_w8(s, 0xfd);
avio_wb32(s, 0x00040000); /* version */ avio_wb32(s, 0x00040000); /* version */
put_tag(s, ".ra4"); ffio_wfourcc(s, ".ra4");
avio_wb32(s, 0x01b53530); /* stream length */ avio_wb32(s, 0x01b53530); /* stream length */
avio_wb16(s, 4); /* unknown */ avio_wb16(s, 4); /* unknown */
avio_wb32(s, 0x39); /* header size */ avio_wb32(s, 0x39); /* header size */
...@@ -239,10 +240,11 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -239,10 +240,11 @@ static int rv10_write_header(AVFormatContext *ctx,
} else { } else {
/* video codec info */ /* video codec info */
avio_wb32(s,34); /* size */ avio_wb32(s,34); /* size */
ffio_wfourcc(s, "VIDO");
if(stream->enc->codec_id == CODEC_ID_RV10) if(stream->enc->codec_id == CODEC_ID_RV10)
put_tag(s,"VIDORV10"); ffio_wfourcc(s,"RV10");
else else
put_tag(s,"VIDORV20"); ffio_wfourcc(s,"RV20");
avio_wb16(s, stream->enc->width); avio_wb16(s, stream->enc->width);
avio_wb16(s, stream->enc->height); avio_wb16(s, stream->enc->height);
avio_wb16(s, (int) stream->frame_rate); /* frames per seconds ? */ avio_wb16(s, (int) stream->frame_rate); /* frames per seconds ? */
...@@ -270,7 +272,7 @@ static int rv10_write_header(AVFormatContext *ctx, ...@@ -270,7 +272,7 @@ static int rv10_write_header(AVFormatContext *ctx,
data_offset_ptr[3] = data_pos; data_offset_ptr[3] = data_pos;
/* data stream */ /* data stream */
put_tag(s,"DATA"); ffio_wfourcc(s, "DATA");
avio_wb32(s,data_size + 10 + 8); avio_wb32(s,data_size + 10 + 8);
avio_wb16(s,0); avio_wb16(s,0);
......
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
#include "libavutil/intreadwrite.h" #include "libavutil/intreadwrite.h"
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "sox.h" #include "sox.h"
typedef struct { typedef struct {
...@@ -53,14 +54,14 @@ static int sox_write_header(AVFormatContext *s) ...@@ -53,14 +54,14 @@ static int sox_write_header(AVFormatContext *s)
sox->header_size = SOX_FIXED_HDR + comment_size; sox->header_size = SOX_FIXED_HDR + comment_size;
if (enc->codec_id == CODEC_ID_PCM_S32LE) { if (enc->codec_id == CODEC_ID_PCM_S32LE) {
put_tag(pb, ".SoX"); ffio_wfourcc(pb, ".SoX");
avio_wl32(pb, sox->header_size); avio_wl32(pb, sox->header_size);
avio_wl64(pb, 0); /* number of samples */ avio_wl64(pb, 0); /* number of samples */
avio_wl64(pb, av_dbl2int(enc->sample_rate)); avio_wl64(pb, av_dbl2int(enc->sample_rate));
avio_wl32(pb, enc->channels); avio_wl32(pb, enc->channels);
avio_wl32(pb, comment_size); avio_wl32(pb, comment_size);
} else if (enc->codec_id == CODEC_ID_PCM_S32BE) { } else if (enc->codec_id == CODEC_ID_PCM_S32BE) {
put_tag(pb, "XoS."); ffio_wfourcc(pb, "XoS.");
avio_wb32(pb, sox->header_size); avio_wb32(pb, sox->header_size);
avio_wb64(pb, 0); /* number of samples */ avio_wb64(pb, 0); /* number of samples */
avio_wb64(pb, av_dbl2int(enc->sample_rate)); avio_wb64(pb, av_dbl2int(enc->sample_rate));
......
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "avformat.h" #include "avformat.h"
#include "avio_internal.h"
#include "pcm.h" #include "pcm.h"
#include "riff.h" #include "riff.h"
...@@ -42,9 +43,9 @@ static int wav_write_header(AVFormatContext *s) ...@@ -42,9 +43,9 @@ static int wav_write_header(AVFormatContext *s)
AVIOContext *pb = s->pb; AVIOContext *pb = s->pb;
int64_t fmt, fact; int64_t fmt, fact;
put_tag(pb, "RIFF"); ffio_wfourcc(pb, "RIFF");
avio_wl32(pb, 0); /* file length */ avio_wl32(pb, 0); /* file length */
put_tag(pb, "WAVE"); ffio_wfourcc(pb, "WAVE");
/* format header */ /* format header */
fmt = ff_start_tag(pb, "fmt "); fmt = ff_start_tag(pb, "fmt ");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment