diff options
author | Baptiste Coudurier <baptiste.coudurier@gmail.com> | 2009-02-16 10:44:38 +0000 |
---|---|---|
committer | Baptiste Coudurier <baptiste.coudurier@gmail.com> | 2009-02-16 10:44:38 +0000 |
commit | d1fa518e9ce71b6849a9c2ee9aadbfb1a02fc503 (patch) | |
tree | b81fe173af977635b67a42735bfb4b1e6e1beea2 | |
parent | ed80a059badbe0231b87e0125e8267f5ed361927 (diff) | |
download | ffmpeg-d1fa518e9ce71b6849a9c2ee9aadbfb1a02fc503.tar.gz |
merge mxf_write_d10_packet into mxf_write_packet
Originally committed as revision 17367 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/mxfenc.c | 95 |
1 files changed, 30 insertions, 65 deletions
diff --git a/libavformat/mxfenc.c b/libavformat/mxfenc.c index e08e952fe6..849efaa49b 100644 --- a/libavformat/mxfenc.c +++ b/libavformat/mxfenc.c @@ -1631,47 +1631,6 @@ static void mxf_write_d10_audio_packet(AVFormatContext *s, AVStream *st, AVPacke } } -static int mxf_write_d10_packet(AVFormatContext *s, AVPacket *pkt) -{ - MXFContext *mxf = s->priv_data; - ByteIOContext *pb = s->pb; - AVStream *st = s->streams[pkt->stream_index]; - MXFStreamContext *sc = st->priv_data; - int flags = 0; - - if (st->codec->codec_id == CODEC_ID_MPEG2VIDEO) { - if (!mxf_parse_mpeg2_frame(s, st, pkt, &flags)) { - av_log(s, AV_LOG_ERROR, "could not get mpeg2 profile and level\n"); - return -1; - } - } - - if (!mxf->header_written) { - mxf_write_partition(s, 1, 2, header_open_partition_key, 1); - mxf->header_written = 1; - mxf_write_klv_fill(s); - mxf_write_index_table_segment(s); - } - - if (st->index == 0) { - mxf_write_klv_fill(s); - mxf_write_system_item(s); - - mxf->edit_units_count++; - } - - mxf_write_klv_fill(s); - put_buffer(pb, sc->track_essence_element_key, 16); // write key - if (st->codec->codec_type == CODEC_TYPE_VIDEO) - mxf_write_d10_video_packet(s, st, pkt); - else - mxf_write_d10_audio_packet(s, st, pkt); - - put_flush_packet(pb); - - return 0; -} - static int mxf_write_packet(AVFormatContext *s, AVPacket *pkt) { MXFContext *mxf = s->priv_data; @@ -1680,7 +1639,7 @@ static int mxf_write_packet(AVFormatContext *s, AVPacket *pkt) MXFStreamContext *sc = st->priv_data; int flags = 0; - if (!(mxf->edit_units_count % EDIT_UNITS_PER_BODY)) { + if (!mxf->edit_unit_byte_count && !(mxf->edit_units_count % EDIT_UNITS_PER_BODY)) { mxf->index_entries = av_realloc(mxf->index_entries, (mxf->edit_units_count + EDIT_UNITS_PER_BODY)*sizeof(*mxf->index_entries)); if (!mxf->index_entries) { @@ -1697,12 +1656,19 @@ static int mxf_write_packet(AVFormatContext *s, AVPacket *pkt) } if (!mxf->header_written) { - mxf_write_partition(s, 0, 0, header_open_partition_key, 1); + if (mxf->edit_unit_byte_count) { + mxf_write_partition(s, 1, 2, header_open_partition_key, 1); + mxf_write_klv_fill(s); + mxf_write_index_table_segment(s); + } else { + mxf_write_partition(s, 0, 0, header_open_partition_key, 1); + } mxf->header_written = 1; } if (st->index == 0) { - if ((!mxf->edit_units_count || mxf->edit_units_count > EDIT_UNITS_PER_BODY) && + if (!mxf->edit_unit_byte_count && + (!mxf->edit_units_count || mxf->edit_units_count > EDIT_UNITS_PER_BODY) && !(flags & 0x33)) { // I frame, Gop start mxf_write_klv_fill(s); mxf_write_partition(s, 1, 2, body_partition_key, 0); @@ -1712,27 +1678,34 @@ static int mxf_write_packet(AVFormatContext *s, AVPacket *pkt) } mxf_write_klv_fill(s); - mxf->index_entries[mxf->edit_units_count].offset = mxf->body_offset; - mxf->index_entries[mxf->edit_units_count].flags = flags; mxf_write_system_item(s); - mxf->body_offset += KAG_SIZE; // size of system element - + if (!mxf->edit_unit_byte_count) { + mxf->index_entries[mxf->edit_units_count].offset = mxf->body_offset; + mxf->index_entries[mxf->edit_units_count].flags = flags; + mxf->body_offset += KAG_SIZE; // size of system element + } mxf->edit_units_count++; - } else if (st->index == 1) { + } else if (!mxf->edit_unit_byte_count && st->index == 1) { mxf->index_entries[mxf->edit_units_count-1].slice_offset = mxf->body_offset - mxf->index_entries[mxf->edit_units_count-1].offset; } mxf_write_klv_fill(s); put_buffer(pb, sc->track_essence_element_key, 16); // write key - klv_encode_ber4_length(pb, pkt->size); // write length - put_buffer(pb, pkt->data, pkt->size); // write value + if (s->oformat == &mxf_d10_muxer) { + if (st->codec->codec_type == CODEC_TYPE_VIDEO) + mxf_write_d10_video_packet(s, st, pkt); + else + mxf_write_d10_audio_packet(s, st, pkt); + } else { + klv_encode_ber4_length(pb, pkt->size); // write length + put_buffer(pb, pkt->data, pkt->size); + mxf->body_offset += 16+4+pkt->size + klv_fill_size(16+4+pkt->size); + } put_flush_packet(pb); - mxf->body_offset += 16+4+pkt->size + klv_fill_size(16+4+pkt->size); - return 0; } @@ -1782,21 +1755,13 @@ static int mxf_write_footer(AVFormatContext *s) mxf_write_random_index_pack(s); if (!url_is_streamed(s->pb)) { - int index; url_fseek(pb, 0, SEEK_SET); - if (s->oformat == &mxf_d10_muxer) { + if (mxf->edit_unit_byte_count) { mxf_write_partition(s, 1, 2, header_closed_partition_key, 1); - index = 1; - } else if (mxf->edit_unit_byte_count) { - mxf_write_partition(s, 0, 2, header_closed_partition_key, 1); - index = 1; - } else { - mxf_write_partition(s, 0, 0, header_closed_partition_key, 1); - index = 0; - } - if (index) { mxf_write_klv_fill(s); mxf_write_index_table_segment(s); + } else { + mxf_write_partition(s, 0, 0, header_closed_partition_key, 1); } } @@ -1908,7 +1873,7 @@ AVOutputFormat mxf_d10_muxer = { CODEC_ID_PCM_S16LE, CODEC_ID_MPEG2VIDEO, mxf_write_header, - mxf_write_d10_packet, + mxf_write_packet, mxf_write_footer, AVFMT_NOTIMESTAMPS, NULL, |