move up mxf_write_klv_fill and align index, rip and primer pack

Originally committed as revision 17118 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Baptiste Coudurier 2009-02-10 05:35:28 +00:00
parent bd5c94b546
commit b25ee3fb38

View File

@ -973,6 +973,22 @@ static void mxf_write_index_table_segment(AVFormatContext *s)
} }
} }
static void mxf_write_klv_fill(AVFormatContext *s)
{
unsigned pad = klv_fill_size(url_ftell(s->pb));
if (pad) {
put_buffer(s->pb, klv_fill_key, 16);
pad -= 16;
pad -= klv_ber_length(pad);
klv_encode_ber_length(s->pb, pad);
for (; pad > 7; pad -= 8)
put_be64(s->pb, 0);
for (; pad; pad--)
put_byte(s->pb, 0);
assert(!(url_ftell(s->pb) & (KAG_SIZE-1)));
}
}
static void mxf_write_partition(AVFormatContext *s, int bodysid, static void mxf_write_partition(AVFormatContext *s, int bodysid,
int indexsid, unsigned index_byte_count, int indexsid, unsigned index_byte_count,
const uint8_t *key, int write_metadata) const uint8_t *key, int write_metadata)
@ -1023,6 +1039,8 @@ static void mxf_write_partition(AVFormatContext *s, int bodysid,
int64_t pos, start = url_ftell(s->pb); int64_t pos, start = url_ftell(s->pb);
unsigned header_byte_count; unsigned header_byte_count;
mxf_write_klv_fill(s);
mxf_write_primer_pack(s); mxf_write_primer_pack(s);
mxf_write_header_metadata_sets(s); mxf_write_header_metadata_sets(s);
pos = url_ftell(s->pb); pos = url_ftell(s->pb);
@ -1207,22 +1225,6 @@ static int mxf_write_header(AVFormatContext *s)
return 0; return 0;
} }
static void mxf_write_klv_fill(AVFormatContext *s)
{
unsigned pad = klv_fill_size(url_ftell(s->pb));
if (pad) {
put_buffer(s->pb, klv_fill_key, 16);
pad -= 16;
pad -= klv_ber_length(pad);
klv_encode_ber_length(s->pb, pad);
for (; pad > 7; pad -= 8)
put_be64(s->pb, 0);
for (; pad; pad--)
put_byte(s->pb, 0);
assert(!(url_ftell(s->pb) & (KAG_SIZE-1)));
}
}
static const uint8_t system_metadata_pack_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x05,0x01,0x01,0x0D,0x01,0x03,0x01,0x04,0x01,0x01,0x00 }; static const uint8_t system_metadata_pack_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x05,0x01,0x01,0x0D,0x01,0x03,0x01,0x04,0x01,0x01,0x00 };
static const uint8_t system_metadata_package_set_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x43,0x01,0x01,0x0D,0x01,0x03,0x01,0x04,0x01,0x02,0x01 }; static const uint8_t system_metadata_package_set_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x43,0x01,0x01,0x0D,0x01,0x03,0x01,0x04,0x01,0x02,0x01 };
@ -1368,14 +1370,19 @@ static int mxf_write_footer(AVFormatContext *s)
// add encoded ber length // add encoded ber length
index_byte_count += 16 + klv_ber_length(index_byte_count); index_byte_count += 16 + klv_ber_length(index_byte_count);
index_byte_count += klv_fill_size(index_byte_count);
mxf_write_klv_fill(s); mxf_write_klv_fill(s);
mxf->footer_partition_offset = url_ftell(pb); mxf->footer_partition_offset = url_ftell(pb);
mxf_write_partition(s, 0, 2, index_byte_count, footer_partition_key, 0); mxf_write_partition(s, 0, 2, index_byte_count, footer_partition_key, 0);
mxf_write_klv_fill(s);
mxf_write_index_table_segment(s); mxf_write_index_table_segment(s);
mxf_write_klv_fill(s);
mxf_write_random_index_pack(s); mxf_write_random_index_pack(s);
if (!url_is_streamed(s->pb)) { if (!url_is_streamed(s->pb)) {