71 #define MXF_MAX_CHUNK_SIZE (32 << 20)
72 #define RUN_IN_MAX (65535+1) // S377m-2004 section 5.5 and S377-1-2009 section 6.5, the +1 is to be slightly more tolerant
183 uint8_t track_number[4];
206 #define MXF_FIELD_DOMINANCE_DEFAULT 0
207 #define MXF_FIELD_DOMINANCE_FF 1
208 #define MXF_FIELD_DOMINANCE_FL 2
339 static const uint8_t
mxf_header_partition_pack_key[] = { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x02 };
340 static const uint8_t
mxf_essence_element_key[] = { 0x06,0x0e,0x2b,0x34,0x01,0x02,0x01,0x01,0x0d,0x01,0x03,0x01 };
341 static const uint8_t
mxf_avid_essence_element_key[] = { 0x06,0x0e,0x2b,0x34,0x01,0x02,0x01,0x01,0x0e,0x04,0x03,0x01 };
342 static const uint8_t
mxf_canopus_essence_element_key[] = { 0x06,0x0e,0x2b,0x34,0x01,0x02,0x01,0x0a,0x0e,0x0f,0x03,0x01 };
343 static const uint8_t
mxf_system_item_key_cp[] = { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x03,0x01,0x04 };
344 static const uint8_t
mxf_system_item_key_gc[] = { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x03,0x01,0x14 };
346 static const uint8_t
mxf_apple_coll_prefix[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x0e,0x20,0x04,0x01,0x05,0x03,0x01 };
349 static const uint8_t
mxf_crypto_source_container_ul[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x09,0x06,0x01,0x01,0x02,0x02,0x00,0x00,0x00 };
350 static const uint8_t
mxf_encrypted_triplet_key[] = { 0x06,0x0e,0x2b,0x34,0x02,0x04,0x01,0x07,0x0d,0x01,0x03,0x01,0x02,0x7e,0x01,0x00 };
351 static const uint8_t
mxf_encrypted_essence_container[] = { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x07,0x0d,0x01,0x03,0x01,0x02,0x0b,0x01,0x00 };
352 static const uint8_t
mxf_sony_mpeg4_extradata[] = { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0e,0x06,0x06,0x02,0x02,0x01,0x00,0x00 };
353 static const uint8_t
mxf_ffv1_extradata[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x01,0x06,0x0c,0x01,0x00,0x00,0x00 };
354 static const uint8_t
mxf_avid_project_name[] = { 0xa5,0xfb,0x7b,0x25,0xf6,0x15,0x94,0xb9,0x62,0xfc,0x37,0x17,0x49,0x2d,0x42,0xbf };
355 static const uint8_t
mxf_jp2k_rsiz[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0a,0x04,0x01,0x06,0x03,0x01,0x00,0x00,0x00 };
356 static const uint8_t
mxf_indirect_value_utf16le[] = { 0x4c,0x00,0x02,0x10,0x01,0x00,0x00,0x00,0x00,0x06,0x0e,0x2b,0x34,0x01,0x04,0x01,0x01 };
357 static const uint8_t
mxf_indirect_value_utf16be[] = { 0x42,0x01,0x10,0x02,0x00,0x00,0x00,0x00,0x00,0x06,0x0e,0x2b,0x34,0x01,0x04,0x01,0x01 };
358 static const uint8_t
mxf_apple_coll_max_cll[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x0e,0x20,0x04,0x01,0x05,0x03,0x01,0x01 };
359 static const uint8_t
mxf_apple_coll_max_fall[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x0e,0x20,0x04,0x01,0x05,0x03,0x01,0x02 };
361 static const uint8_t
mxf_mca_label_dictionary_id[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x01,0x00,0x00,0x00 };
362 static const uint8_t
mxf_mca_tag_symbol[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x02,0x00,0x00,0x00 };
363 static const uint8_t
mxf_mca_tag_name[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x03,0x00,0x00,0x00 };
364 static const uint8_t
mxf_group_of_soundfield_groups_link_id[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x04,0x00,0x00,0x00 };
365 static const uint8_t
mxf_mca_link_id[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x05,0x00,0x00,0x00 };
366 static const uint8_t
mxf_mca_channel_id[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x04,0x0a,0x00,0x00,0x00,0x00 };
367 static const uint8_t
mxf_soundfield_group_link_id[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x01,0x03,0x07,0x01,0x06,0x00,0x00,0x00 };
368 static const uint8_t
mxf_mca_rfc5646_spoken_language[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0d,0x03,0x01,0x01,0x02,0x03,0x15,0x00,0x00 };
370 static const uint8_t
mxf_sub_descriptor[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x09,0x06,0x01,0x01,0x04,0x06,0x10,0x00,0x00 };
380 #define IS_KLV_KEY(x, y) (!memcmp(x, y, sizeof(y)))
438 int bytes_num =
size & 0x7f;
443 *llen = bytes_num + 1;
450 if (
size > INT64_MAX)
462 else if (
b !=
key[
i])
503 if (klv->
offset > INT64_MAX - 16 - llen)
507 if (
pos > INT64_MAX - length)
515 for (
int i = 0;
i <
s->nb_streams;
i++) {
522 return s->nb_streams == 1 &&
s->streams[0]->priv_data ? 0 : -1;
551 int cdp_identifier, cdp_length, cdp_footer_id, ccdata_id, cc_count;
552 int line_num, sample_coding, sample_count;
553 int did, sdid, data_length;
559 for (
int i = 0;
i < count;
i++) {
568 length -= 6 + 8 + sample_count;
569 if (line_num != 9 && line_num != 11)
571 if (sample_coding == 7 || sample_coding == 8 || sample_coding == 9) {
583 if (did != 0x61 || sdid != 1) {
588 if (cdp_identifier != 0x9669) {
597 if (ccdata_id != 0x72) {
605 if (cdp_length - 9 - 4 < cc_count * 3) {
609 avio_skip(
s->pb, data_length - 9 - 4 - cc_count * 3);
611 if (cdp_footer_id != 0x74) {
626 const uint8_t *buf_ptr, *end_ptr;
643 uint32_t
sample = bytestream_get_le32(&buf_ptr);
645 bytestream_put_le24(&data_ptr, (
sample >> 4) & 0xffffff);
647 bytestream_put_le16(&data_ptr, (
sample >> 12) & 0xffff);
658 static const uint8_t checkv[16] = {0x43, 0x48, 0x55, 0x4b, 0x43, 0x48, 0x55, 0x4b, 0x43, 0x48, 0x55, 0x4b, 0x43, 0x48, 0x55, 0x4b};
664 uint64_t plaintext_size;
671 if (!mxf->
aesc &&
s->key &&
s->keylen == 16) {
698 if (orig_size < plaintext_size)
702 if (
size < 32 ||
size - 32 < orig_size || (
int)orig_size != orig_size)
710 if (memcmp(tmpbuf, checkv, 16))
716 else if (
size < plaintext_size)
718 size -= plaintext_size;
734 if (item_len != 18) {
738 if (item_num > 65536 || item_num < 0) {
760 uint64_t footer_partition;
761 uint32_t nb_essence_containers;
762 uint64_t this_partition;
787 memset(partition, 0,
sizeof(*partition));
813 if (this_partition != klv_offset - mxf->
run_in) {
815 "this_partition %"PRId64
" mismatches %"PRId64
"\n",
816 this_partition, klv_offset - mxf->
run_in);
839 av_dict_set(&
s->metadata,
"operational_pattern_ul", str, 0);
842 if (this_partition &&
845 "PreviousPartition equal to ThisPartition %"PRIx64
"\n",
858 "Overriding PreviousPartition with %"PRIx64
"\n",
863 if (footer_partition) {
866 "inconsistent FooterPartition value: %"PRIu64
" != %"PRIu64
"\n",
874 "PartitionPack: ThisPartition = 0x%"PRIX64
875 ", PreviousPartition = 0x%"PRIX64
", "
876 "FooterPartition = 0x%"PRIX64
", IndexSID = %i, BodySID = %i\n",
886 "PreviousPartition points to this partition or forward\n");
890 if (
op[12] == 1 &&
op[13] == 1) mxf->
op =
OP1a;
891 else if (
op[12] == 1 &&
op[13] == 2) mxf->
op =
OP1b;
892 else if (
op[12] == 1 &&
op[13] == 3) mxf->
op =
OP1c;
893 else if (
op[12] == 2 &&
op[13] == 1) mxf->
op =
OP2a;
894 else if (
op[12] == 2 &&
op[13] == 2) mxf->
op =
OP2b;
895 else if (
op[12] == 2 &&
op[13] == 3) mxf->
op =
OP2c;
896 else if (
op[12] == 3 &&
op[13] == 1) mxf->
op =
OP3a;
897 else if (
op[12] == 3 &&
op[13] == 2) mxf->
op =
OP3b;
898 else if (
op[12] == 3 &&
op[13] == 3) mxf->
op =
OP3c;
900 else if (
op[12] == 0x10) {
905 if (nb_essence_containers != 1) {
911 "\"OPAtom\" with %"PRIu32
" ECs - assuming %s\n",
912 nb_essence_containers,
913 mxfop ==
OP1a ?
"OP1a" :
"OPAtom");
945 else if (
p->complete)
951 return (score << 60) | ((uint64_t)
p->pack_ofs >> 4);
963 for (
int i = 0;
i <
mg->metadata_sets_count;
i++) {
964 if (!memcmp((*metadata_set)->uid,
mg->metadata_sets[
i]->uid, 16)) {
965 uint64_t old_s =
mg->metadata_sets[
i]->partition_score;
966 uint64_t new_s = (*metadata_set)->partition_score;
999 if (
c > INT_MAX /
sizeof(
UID))
1011 if (
ret != *count *
sizeof(
UID)) {
1012 *count =
ret < 0 ? 0 :
ret /
sizeof(
UID);
1024 if (size < 0 || size > INT_MAX - 1)
1027 buf_size =
size + 1;
1048 if (size < 0 || size > INT_MAX/2)
1070 #define READ_STR16(type, big_endian) \
1071 static int mxf_read_utf16 ## type ##_string(AVIOContext *pb, int size, char** str) \
1073 return mxf_read_utf16_string(pb, size, str, big_endian); \
1154 mxf_read_utf16be_string(pb,
size, &track->
name);
1207 &package->tracks_count);
1211 avio_read(pb, package->package_uid, 16);
1214 avio_read(pb, package->descriptor_ref, 16);
1217 return mxf_read_utf16be_string(pb,
size, &package->name);
1220 &package->comment_count);
1247 uint32_t nb_index_entries;
1249 if (
segment->temporal_offset_entries)
1253 if (nb_index_entries > INT_MAX)
1255 segment->nb_index_entries = nb_index_entries;
1258 if(
segment->nb_index_entries && length < 11)
1269 for (
i = 0;
i <
segment->nb_index_entries;
i++) {
1303 if (
segment->index_edit_rate.num <= 0 ||
1304 segment->index_edit_rate.den <= 0)
1307 segment->index_edit_rate.den);
1336 }
while (
code != 0);
1344 int entry_count, entry_size;
1377 if (entry_size == 4) {
1378 if (entry_count > 0)
1382 if (entry_count > 1)
1465 for (
int i = 0;
i < 3;
i++) {
1495 if (!descriptor->
coll) {
1497 if (!descriptor->
coll)
1574 return mxf_read_utf16le_string(pb,
size - 17, &tagged_value->
value);
1576 return mxf_read_utf16be_string(pb,
size - 17, &tagged_value->
value);
1586 return mxf_read_utf16be_string(pb,
size, &tagged_value->
name);
1600 for (
i = 0;
i <
len;
i++) {
1601 if (
i != 7 &&
key[
i] != uid_prefix[
i])
1609 while (uls->
uid[0]) {
1623 for (
int i =
mg->metadata_sets_count - 1;
i >= 0;
i--)
1624 if (!memcmp(*strong_ref,
mg->metadata_sets[
i]->uid, 16))
1625 return mg->metadata_sets[
i];
1632 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x07,0x0d,0x01,0x03,0x01,0x02,0x0c,0x01,0x00 }, 14,
AV_CODEC_ID_JPEG2000,
NULL, 14,
J2KWrap },
1633 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x10,0x60,0x01 }, 14,
AV_CODEC_ID_H264,
NULL, 15 },
1634 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x11,0x01,0x00 }, 14,
AV_CODEC_ID_DNXHD,
NULL, 14 },
1635 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x0d,0x01,0x03,0x01,0x02,0x1e,0x01,0x00 }, 14,
AV_CODEC_ID_DNXUC,
NULL, 14 },
1636 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x12,0x01,0x00 }, 14,
AV_CODEC_ID_VC1,
NULL, 14 },
1637 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x14,0x01,0x00 }, 14,
AV_CODEC_ID_TIFF,
NULL, 14 },
1638 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x15,0x01,0x00 }, 14,
AV_CODEC_ID_DIRAC,
NULL, 14 },
1639 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x1b,0x01,0x00 }, 14,
AV_CODEC_ID_CFHD,
NULL, 14 },
1640 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x1c,0x01,0x00 }, 14,
AV_CODEC_ID_PRORES,
NULL, 14 },
1641 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x04,0x60,0x01 }, 14,
AV_CODEC_ID_MPEG2VIDEO,
NULL, 15 },
1642 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x01,0x04,0x01 }, 14,
AV_CODEC_ID_MPEG2VIDEO,
NULL, 15,
D10D11Wrap },
1643 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x0d,0x01,0x03,0x01,0x02,0x23,0x01,0x00 }, 14,
AV_CODEC_ID_FFV1,
NULL, 14 },
1644 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x02,0x41,0x01 }, 14,
AV_CODEC_ID_DVVIDEO,
NULL, 15 },
1645 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x05,0x00,0x00 }, 14,
AV_CODEC_ID_RAWVIDEO,
NULL, 15,
RawVWrap },
1646 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0a,0x0e,0x0f,0x03,0x01,0x02,0x20,0x01,0x01 }, 15,
AV_CODEC_ID_HQ_HQA },
1647 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0a,0x0e,0x0f,0x03,0x01,0x02,0x20,0x02,0x01 }, 15,
AV_CODEC_ID_HQX },
1648 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0a,0x0e,0x15,0x00,0x04,0x02,0x10,0x00,0x01 }, 16,
AV_CODEC_ID_HEVC,
NULL, 15 },
1649 { { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0xff,0x4b,0x46,0x41,0x41,0x00,0x0d,0x4d,0x4f }, 14,
AV_CODEC_ID_RAWVIDEO },
1650 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_CODEC_ID_NONE },
1655 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x01,0x00,0x00 }, 14,
AV_CODEC_ID_MPEG2VIDEO },
1656 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_CODEC_ID_NONE },
1661 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0A,0x04,0x01,0x02,0x02,0x01,0x32,0x00,0x00 }, 14,
AV_CODEC_ID_H264 },
1662 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x07,0x04,0x01,0x02,0x02,0x03,0x01,0x01,0x00 }, 14,
AV_CODEC_ID_JPEG2000 },
1663 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_CODEC_ID_NONE },
1668 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0A,0x04,0x01,0x02,0x02,0x01,0x32,0x21,0x01 }, 16, 1440 },
1669 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0A,0x04,0x01,0x02,0x02,0x01,0x32,0x21,0x02 }, 16, 1440 },
1670 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0A,0x04,0x01,0x02,0x02,0x01,0x32,0x21,0x03 }, 16, 1440 },
1671 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0A,0x04,0x01,0x02,0x02,0x01,0x32,0x21,0x04 }, 16, 1440 },
1672 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0, 0 },
1677 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x06,0x01,0x00 }, 14,
AV_CODEC_ID_PCM_S16LE,
NULL, 14,
RawAWrap },
1678 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x02,0x0d,0x01,0x03,0x01,0x02,0x04,0x40,0x01 }, 14,
AV_CODEC_ID_MP2,
NULL, 15 },
1679 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x01,0x0d,0x01,0x03,0x01,0x02,0x01,0x01,0x01 }, 14,
AV_CODEC_ID_PCM_S16LE,
NULL, 13 },
1680 { { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0xff,0x4b,0x46,0x41,0x41,0x00,0x0d,0x4d,0x4F }, 14,
AV_CODEC_ID_PCM_S16LE },
1681 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x03,0x04,0x02,0x02,0x02,0x03,0x03,0x01,0x00 }, 14,
AV_CODEC_ID_AAC },
1682 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x0d,0x01,0x03,0x01,0x02,0x16,0x00,0x00 }, 14,
AV_CODEC_ID_AAC,
NULL, 14 },
1683 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x0d,0x01,0x03,0x01,0x02,0x17,0x00,0x00 }, 14,
AV_CODEC_ID_AAC,
NULL, 14 },
1684 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x0d,0x01,0x03,0x01,0x02,0x18,0x00,0x00 }, 14,
AV_CODEC_ID_AAC,
NULL, 14 },
1685 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_CODEC_ID_NONE },
1689 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x09,0x0d,0x01,0x03,0x01,0x02,0x0d,0x00,0x00 }, 16,
AV_CODEC_ID_NONE,
"vbi_smpte_436M", 11 },
1690 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x09,0x0d,0x01,0x03,0x01,0x02,0x0e,0x00,0x00 }, 16,
AV_CODEC_ID_SMPTE_436M_ANC,
"vbi_vanc_smpte_436M", 11 },
1691 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x09,0x0d,0x01,0x03,0x01,0x02,0x13,0x01,0x01 }, 16,
AV_CODEC_ID_TTML },
1692 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_CODEC_ID_NONE },
1702 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x01,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1703 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x02,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1704 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x03,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1705 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x04,0x00,0x00,0x00,0x00 },
AV_CHAN_LOW_FREQUENCY,
AV_AUDIO_SERVICE_TYPE_MAIN },
1706 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x05,0x00,0x00,0x00,0x00 },
AV_CHAN_SIDE_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1707 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x06,0x00,0x00,0x00,0x00 },
AV_CHAN_SIDE_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1708 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x07,0x00,0x00,0x00,0x00 },
AV_CHAN_SIDE_SURROUND_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1709 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x08,0x00,0x00,0x00,0x00 },
AV_CHAN_SIDE_SURROUND_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1710 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x09,0x00,0x00,0x00,0x00 },
AV_CHAN_BACK_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1711 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0a,0x00,0x00,0x00,0x00 },
AV_CHAN_BACK_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1712 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0b,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_LEFT_OF_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1713 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0c,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_RIGHT_OF_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1714 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0d,0x00,0x00,0x00,0x00 },
AV_CHAN_BACK_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1715 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0e,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_CENTER,
AV_AUDIO_SERVICE_TYPE_VISUALLY_IMPAIRED },
1716 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x0f,0x00,0x00,0x00,0x00 },
AV_CHAN_FRONT_CENTER,
AV_AUDIO_SERVICE_TYPE_HEARING_IMPAIRED },
1717 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x20,0x03,0x00,0x00,0x00 },
AV_CHAN_STEREO_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1718 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x20,0x04,0x00,0x00,0x00 },
AV_CHAN_STEREO_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1719 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x01,0x00,0x00 },
AV_CHAN_TOP_FRONT_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1720 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x02,0x00,0x00 },
AV_CHAN_TOP_FRONT_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1721 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x03,0x00,0x00 },
AV_CHAN_TOP_FRONT_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1722 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x04,0x00,0x00 },
AV_CHAN_TOP_SURROUND_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1723 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x05,0x00,0x00 },
AV_CHAN_TOP_SURROUND_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1724 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x06,0x00,0x00 },
AV_CHAN_TOP_SIDE_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1725 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x07,0x00,0x00 },
AV_CHAN_TOP_SIDE_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1726 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x08,0x00,0x00 },
AV_CHAN_TOP_BACK_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1727 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x09,0x00,0x00 },
AV_CHAN_TOP_BACK_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1728 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0a,0x00,0x00 },
AV_CHAN_TOP_SIDE_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1729 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0b,0x00,0x00 },
AV_CHAN_TOP_SIDE_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1730 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0c,0x00,0x00 },
AV_CHAN_TOP_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1731 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0d,0x00,0x00 },
AV_CHAN_LOW_FREQUENCY,
AV_AUDIO_SERVICE_TYPE_MAIN },
1732 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0e,0x00,0x00 },
AV_CHAN_LOW_FREQUENCY_2,
AV_AUDIO_SERVICE_TYPE_MAIN },
1733 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x0f,0x00,0x00 },
AV_CHAN_TOP_BACK_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1734 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x10,0x00,0x00 },
AV_CHAN_BACK_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1735 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x11,0x00,0x00 },
AV_CHAN_BOTTOM_FRONT_LEFT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1736 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x12,0x00,0x00 },
AV_CHAN_BOTTOM_FRONT_RIGHT,
AV_AUDIO_SERVICE_TYPE_MAIN },
1737 { { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x0d,0x03,0x02,0x01,0x30,0x01,0x13,0x00,0x00 },
AV_CHAN_BOTTOM_FRONT_CENTER,
AV_AUDIO_SERVICE_TYPE_MAIN },
1738 { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0,
AV_AUDIO_SERVICE_TYPE_NB },
1754 val = (*essence_container_ul)[
codec_ul->wrapping_indicator_pos];
1755 switch (
codec_ul->wrapping_indicator_type) {
1760 if (
val == 0x03 ||
val == 0x04)
1781 int i, j, nb_segments = 0;
1783 int last_body_sid = -1, last_index_sid = -1, last_index_start = -1;
1787 nb_segments =
mg->metadata_sets_count;
1791 if (!(unsorted_segments =
av_calloc(nb_segments,
sizeof(*unsorted_segments))) ||
1792 !(*sorted_segments =
av_calloc(nb_segments,
sizeof(**sorted_segments)))) {
1798 for (
i = nb_segments = 0;
i <
mg->metadata_sets_count;
i++) {
1800 if (
s->edit_unit_byte_count ||
s->nb_index_entries)
1801 unsorted_segments[nb_segments++] =
s;
1803 av_log(mxf->
fc,
AV_LOG_WARNING,
"IndexSID %i segment at %"PRId64
" missing EditUnitByteCount and IndexEntryArray\n",
1804 s->index_sid,
s->index_start_position);
1813 *nb_sorted_segments = 0;
1816 for (
i = 0;
i < nb_segments;
i++) {
1817 int best = -1, best_body_sid = -1, best_index_sid = -1, best_index_start = -1;
1818 uint64_t best_index_duration = 0;
1820 for (j = 0; j < nb_segments; j++) {
1828 s->body_sid > last_body_sid ||
1829 s->body_sid == last_body_sid &&
s->index_sid > last_index_sid ||
1830 s->body_sid == last_body_sid &&
s->index_sid == last_index_sid &&
s->index_start_position > last_index_start) &&
1832 s->body_sid < best_body_sid ||
1833 s->body_sid == best_body_sid &&
s->index_sid < best_index_sid ||
1834 s->body_sid == best_body_sid &&
s->index_sid == best_index_sid &&
s->index_start_position < best_index_start ||
1835 s->body_sid == best_body_sid &&
s->index_sid == best_index_sid &&
s->index_start_position == best_index_start &&
s->index_duration > best_index_duration)) {
1837 best_body_sid =
s->body_sid;
1838 best_index_sid =
s->index_sid;
1839 best_index_start =
s->index_start_position;
1840 best_index_duration =
s->index_duration;
1848 (*sorted_segments)[(*nb_sorted_segments)++] = unsorted_segments[best];
1849 last_body_sid = best_body_sid;
1850 last_index_sid = best_index_sid;
1851 last_index_start = best_index_start;
1874 m0 = m = (
a +
b) >> 1;
1876 while (m < b && mxf->partitions[m].body_sid != body_sid)
1879 if (m < b && mxf->partitions[m].body_offset <=
offset)
1891 *partition_out = last_p;
1896 "failed to find absolute offset of %"PRIX64
" in BodySID %i - partial file?\n",
1910 if (
p->body_sid != body_sid)
1913 if (!
p->essence_length)
1916 return p->essence_offset +
p->essence_length;
1926 int64_t index_duration, index_end;
1951 if (index_duration > 0 && edit_unit <= INT64_MAX / index_table->nb_segments) {
1962 if (
s->index_start_position <= edit_unit && edit_unit < s->index_start_position +
s->index_duration) {
1966 if (
s->edit_unit_byte_count) {
1967 if (
index > INT64_MAX /
s->edit_unit_byte_count ||
1968 s->edit_unit_byte_count *
index > INT64_MAX - offset_temp)
1971 offset_temp +=
s->edit_unit_byte_count *
index;
1973 if (
s->nb_index_entries == 2 *
s->index_duration + 1)
1976 if (index < 0 || index >=
s->nb_index_entries) {
1982 offset_temp =
s->stream_offset_entries[
index];
1986 *edit_unit_out =
av_rescale_q(edit_unit, edit_rate,
s->index_edit_rate);
1989 }
else if (dir == 0) {
1992 if (edit_unit < s->index_start_position) {
2009 int8_t max_temporal_offset = -128;
2016 if (!
s->nb_index_entries) {
2021 if (
s->index_duration > INT_MAX -
index_table->nb_ptses) {
2027 if (
s->nb_index_entries !=
s->index_duration &&
2028 s->nb_index_entries !=
s->index_duration + 1 &&
2029 s->nb_index_entries !=
s->index_duration * 2 + 1) {
2031 av_log(mxf->
fc,
AV_LOG_ERROR,
"ignoring IndexSID %d, duration does not match nb_index_entries\n",
s->index_sid);
2086 int index_delta = 1;
2087 int n =
s->nb_index_entries;
2089 if (
s->nb_index_entries == 2 *
s->index_duration + 1)
2091 if (
s->nb_index_entries == index_delta *
s->index_duration + 1)
2095 for (j = 0; j < n; j += index_delta, x++) {
2096 int offset =
s->temporal_offset_entries[j] / index_delta;
2101 "x >= nb_ptses - IndexEntryCount %i < IndexDuration %"PRId64
"?\n",
2102 s->nb_index_entries,
s->index_duration);
2108 if (index < 0 || index >=
index_table->nb_ptses) {
2110 "index entry %i + TemporalOffset %i = %i, which is out of bounds\n",
2117 max_temporal_offset =
FFMAX(max_temporal_offset,
offset);
2140 int ret, nb_sorted_segments;
2144 nb_sorted_segments <= 0) {
2150 for (
int i = 0;
i < nb_sorted_segments;
i++) {
2151 if (
i == 0 || sorted_segments[
i-1]->index_sid != sorted_segments[
i]->index_sid)
2153 else if (sorted_segments[
i-1]->body_sid != sorted_segments[
i]->body_sid) {
2156 goto finish_decoding_index;
2165 goto finish_decoding_index;
2169 for (
int i = 0, j = 0;
i < nb_sorted_segments;
i++) {
2170 if (
i != 0 && sorted_segments[
i-1]->index_sid != sorted_segments[
i]->index_sid) {
2186 " pointer array\n");
2188 goto finish_decoding_index;
2191 if (sorted_segments[
i]->index_start_position)
2192 av_log(mxf->
fc,
AV_LOG_WARNING,
"IndexSID %i starts at EditUnit %"PRId64
" - seeking may not work as expected\n",
2200 goto finish_decoding_index;
2221 s->offset = offset_temp;
2224 if (
s->edit_unit_byte_count && (
s->index_duration > INT64_MAX /
s->edit_unit_byte_count ||
2225 s->edit_unit_byte_count *
s->index_duration > INT64_MAX - offset_temp)) {
2227 goto finish_decoding_index;
2236 av_log(mxf->
fc,
AV_LOG_WARNING,
"IndexSID %i segment %i has zero IndexDuration and there's more than one segment\n",
2253 finish_decoding_index:
2259 static const uint8_t st_422_essence_container_ul[] = { 0x06,0x0e,0x2b,0x34,0x04,0x01,0x01,0x07,0x0d,0x01,0x03,0x01,0x02,0x0c };
2261 return essence_container_ul &&
mxf_match_uid(*essence_container_ul, st_422_essence_container_ul,
2262 sizeof(st_422_essence_container_ul));
2274 char str[2 +
sizeof(
UID) * 4 + 1])
2282 uint16_t patch, uint16_t release,
char **str)
2284 *str =
av_asprintf(
"%d.%d.%d.%d.%d", major, minor, tertiary, patch, release);
2292 char str[2 + 4 *
sizeof(
UID) + 1];
2330 package = mxf_resolve_strong_ref(mxf, &mxf->packages_refs[i], SourcePackage);
2334 if (!memcmp(package->package_ul, package_ul, 16) && !memcmp(package->package_uid, package_uid, 16))
2351 if (!file_descriptor) {
2356 return file_descriptor;
2440 if (physical_package->
name && physical_package->
name[0])
2460 "Invalid edit rate (%d/%d) found on structural"
2461 " component #%d, defaulting to 25/1\n",
2562 if (rfc5646 && strlen(rfc5646) > 1) {
2563 char primary_tag[4] =
2564 {rfc5646[0], rfc5646[1], rfc5646[2] !=
'-' ? rfc5646[2] :
'\0',
'\0'};
2577 for (
int k = 0; k <
mg->metadata_sets_count; k++) {
2589 if (ffv1_sub_descriptor ==
NULL)
2604 int ambigous_language = 0;
2606 int ambigous_service_type = 0;
2610 char *channel_language;
2626 if (target_channel == 0 && descriptor->
channels == 1)
2628 if (target_channel <= 0 || target_channel > descriptor->
channels) {
2629 av_log(mxf->
fc,
AV_LOG_ERROR,
"AudioChannelLabelSubDescriptor has invalid MCA channel ID %d\n", target_channel);
2632 ch_layout->
u.
map[target_channel - 1].
id = channel_ordering->channel;
2634 service_type = channel_ordering->service_type;
2635 else if (service_type != channel_ordering->service_type)
2636 ambigous_service_type = 1;
2641 channel_language = label->
language;
2642 if (!channel_language) {
2645 channel_language = group->
language;
2650 channel_language = supergroup->
language;
2654 if (channel_language) {
2656 ambigous_language = 1;
2662 if (
language && !ambigous_language) {
2677 *ast = service_type;
2695 if (material_package)
break;
2697 if (!material_package) {
2703 if (material_package->
name && material_package->
name[0])
2715 UID *essence_container_ul =
NULL;
2766 if (!source_package) {
2777 source_track = temp_track;
2781 if (!source_track) {
2800 if(source_track && component)
2803 if (!source_track || !component || !source_package) {
2847 "Invalid edit rate (%d/%d) found on stream #%d, "
2848 "defaulting to 25/1\n",
2878 if (
mg->metadata_sets_count) {
2894 for (k = 0; k < 16; k++) {
2897 if (!(k+1 & 19) || k == 5)
2903 if (source_package->
name && source_package->
name[0])
2905 if (material_track->
name && material_track->
name[0])
2954 "Field dominance %d support",
2968 "Field dominance %d support",
2981 switch ((*essence_container_ul)[14]) {
3031 if (material_track->
origin) {
3034 if (source_track->
origin) {
3052 if (descriptor->
coll) {
3073 "found for stream #%d, time base forced to 1/48000\n",
3159 "with different wrapping\n",
i, j, track1->
body_sid);
3172 struct tm time = { 0 };
3174 time.tm_year = (timestamp >> 48) - 1900;
3175 time.tm_mon = (timestamp >> 40 & 0xFF) - 1;
3176 time.tm_mday = (timestamp >> 32 & 0xFF);
3177 time.tm_hour = (timestamp >> 24 & 0xFF);
3178 time.tm_min = (timestamp >> 16 & 0xFF);
3179 time.tm_sec = (timestamp >> 8 & 0xFF);
3180 msecs = (timestamp & 0xFF) * 4;
3183 time.tm_mon =
av_clip(time.tm_mon, 0, 11);
3184 time.tm_mday =
av_clip(time.tm_mday, 1, 31);
3185 time.tm_hour =
av_clip(time.tm_hour, 0, 23);
3186 time.tm_min =
av_clip(time.tm_min, 0, 59);
3187 time.tm_sec =
av_clip(time.tm_sec, 0, 59);
3188 msecs =
av_clip(msecs, 0, 999);
3193 #define SET_STR_METADATA(pb, name, str) do { \
3194 if ((ret = mxf_read_utf16be_string(pb, size, &str)) < 0) \
3196 av_dict_set(&s->metadata, name, str, AV_DICT_DONT_STRDUP_VAL); \
3199 #define SET_VERSION_METADATA(pb, name, major, minor, tertiary, patch, release, str) do { \
3200 major = avio_rb16(pb); \
3201 minor = avio_rb16(pb); \
3202 tertiary = avio_rb16(pb); \
3203 patch = avio_rb16(pb); \
3204 release = avio_rb16(pb); \
3205 if ((ret = mxf_version_to_str(major, minor, tertiary, patch, release, &str)) < 0) \
3207 av_dict_set(&s->metadata, name, str, AV_DICT_DONT_STRDUP_VAL); \
3210 #define SET_UID_METADATA(pb, name, var, str) do { \
3211 char uuid_str[2 * AV_UUID_LEN + 4 + 1]; \
3212 avio_read(pb, var, 16); \
3213 av_uuid_unparse(uid, uuid_str); \
3214 av_dict_set(&s->metadata, name, uuid_str, 0); \
3217 #define SET_TS_METADATA(pb, name, var, str) do { \
3218 var = avio_rb64(pb); \
3219 if (var && (ret = ff_dict_set_timestamp(&s->metadata, name, mxf_timestamp_to_int64(var))) < 0) \
3231 uint16_t major, minor, tertiary, patch, release;
3281 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x05,0x01,0x00 },
mxf_read_primer_pack },
3282 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x02,0x01,0x00 },
mxf_read_partition_pack },
3283 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x02,0x02,0x00 },
mxf_read_partition_pack },
3284 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x02,0x03,0x00 },
mxf_read_partition_pack },
3285 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x02,0x04,0x00 },
mxf_read_partition_pack },
3286 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x03,0x01,0x00 },
mxf_read_partition_pack },
3287 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x03,0x02,0x00 },
mxf_read_partition_pack },
3288 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x03,0x03,0x00 },
mxf_read_partition_pack },
3289 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x03,0x04,0x00 },
mxf_read_partition_pack },
3290 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x04,0x02,0x00 },
mxf_read_partition_pack },
3291 { { 0x06,0x0e,0x2b,0x34,0x02,0x05,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x04,0x04,0x00 },
mxf_read_partition_pack },
3292 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x2f,0x00 },
mxf_read_preface_metadata },
3293 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x30,0x00 },
mxf_read_identification_metadata },
3294 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x18,0x00 },
mxf_read_content_storage },
3295 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x37,0x00 },
mxf_read_package,
sizeof(
MXFPackage),
SourcePackage },
3296 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x36,0x00 },
mxf_read_package,
sizeof(
MXFPackage),
MaterialPackage },
3297 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x0f,0x00 },
mxf_read_sequence,
sizeof(
MXFSequence),
Sequence },
3298 { { 0x06,0x0E,0x2B,0x34,0x02,0x53,0x01,0x01,0x0D,0x01,0x01,0x01,0x01,0x01,0x05,0x00 },
mxf_read_essence_group,
sizeof(
MXFEssenceGroup),
EssenceGroup},
3299 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x11,0x00 },
mxf_read_source_clip,
sizeof(
MXFStructuralComponent),
SourceClip },
3300 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x3f,0x00 },
mxf_read_tagged_value,
sizeof(
MXFTaggedValue),
TaggedValue },
3301 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x44,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
MultipleDescriptor },
3302 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x42,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3303 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x28,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3304 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x29,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3305 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x48,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3306 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x47,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3307 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x51,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3308 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x5b,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3309 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x5c,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3310 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x5e,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3311 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x64,0x00 },
mxf_read_generic_descriptor,
sizeof(
MXFDescriptor),
Descriptor },
3312 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x6b,0x00 },
mxf_read_mca_sub_descriptor,
sizeof(
MXFMCASubDescriptor),
AudioChannelLabelSubDescriptor },
3313 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x6c,0x00 },
mxf_read_mca_sub_descriptor,
sizeof(
MXFMCASubDescriptor),
SoundfieldGroupLabelSubDescriptor },
3314 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x6d,0x00 },
mxf_read_mca_sub_descriptor,
sizeof(
MXFMCASubDescriptor),
GroupOfSoundfieldGroupsLabelSubDescriptor },
3315 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x81,0x03 },
mxf_read_ffv1_sub_descriptor,
sizeof(
MXFFFV1SubDescriptor),
FFV1SubDescriptor },
3316 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x3A,0x00 },
mxf_read_track,
sizeof(
MXFTrack),
Track },
3317 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x3B,0x00 },
mxf_read_track,
sizeof(
MXFTrack),
Track },
3318 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x14,0x00 },
mxf_read_timecode_component,
sizeof(
MXFTimecodeComponent),
TimecodeComponent },
3319 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x0c,0x00 },
mxf_read_pulldown_component,
sizeof(
MXFPulldownComponent),
PulldownComponent },
3320 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x04,0x01,0x02,0x02,0x00,0x00 },
mxf_read_cryptographic_context,
sizeof(
MXFCryptoContext),
CryptoContext },
3321 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x02,0x01,0x01,0x10,0x01,0x00 },
mxf_read_index_table_segment,
sizeof(
MXFIndexTableSegment),
IndexTableSegment },
3322 { { 0x06,0x0e,0x2b,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x23,0x00 },
mxf_read_essence_container_data,
sizeof(
MXFEssenceContainerData),
EssenceContainerData },
3323 { { 0x06,0x0E,0x2B,0x34,0x01,0x01,0x01,0x02,0x03,0x01,0x02,0x10,0x01,0x00,0x00,0x00 } },
3364 if (next < 0 || next > INT64_MAX -
size) {
3381 if (local_tag ==
tag) {
3388 if (meta &&
tag == 0x3C0A) {
3405 "local tag %#04x extends past end of local set @ %#"PRIx64
"\n",
3425 key[13] >= 2 &&
key[13] <= 4;
3437 if (klv.
key[5] == 0x53) {
3467 int64_t current_partition_ofs;
3498 if (klv.
offset >= current_partition_ofs) {
3500 PRIx64
" indirectly points to itself\n", current_partition_ofs);
3540 "failed to seek to FooterPartition @ 0x%" PRIx64
3541 " (%"PRId64
") - partial file?\n",
3564 for (
int i = 0;
i <
s->nb_streams;
i++) {
3594 p->essence_offset =
p->first_essence_klv.next_klv -
p->first_essence_klv.length;
3595 p->essence_length =
p->first_essence_klv.length;
3597 p->essence_offset =
p->first_essence_klv.offset;
3600 if (x < mxf->partitions_count - 1)
3603 if (
p->essence_length < 0) {
3605 p->essence_length = 0;
3607 "partition %i: bad ThisPartition = %"PRIX64
"\n",
3664 int essence_partition_count = 0;
3665 int edit_unit_byte_count = 0;
3673 for (
i = 0;
i <
mg->metadata_sets_count;
i++) {
3686 essence_partition_count++;
3690 if (essence_partition_count != 1)
3696 }
else if (st->
duration > 0 &&
p->first_essence_klv.length > 0 &&
p->first_essence_klv.length % st->
duration == 0) {
3697 edit_unit_byte_count =
p->first_essence_klv.length / st->
duration;
3700 if (edit_unit_byte_count <= 0)
3717 segment->edit_unit_byte_count = edit_unit_byte_count;
3718 segment->index_start_position = 0;
3730 int64_t file_size, max_rip_length, min_rip_length;
3746 max_rip_length = ((file_size - mxf->
run_in) / 105) * 12 + 28;
3747 max_rip_length =
FFMIN(max_rip_length, INT_MAX);
3750 min_rip_length = 16+1+24+4;
3756 if (length < min_rip_length || length > max_rip_length)
3758 avio_seek(
s->pb, file_size - length, SEEK_SET);
3834 if (!essence_offset)
3835 essence_offset = klv.
offset;
3869 if (!essence_offset) {
3880 for (
int i = 0;
i <
s->nb_streams;
i++)
3888 av_log(mxf->
fc,
AV_LOG_INFO,
"got %i index tables - only the first one (IndexSID %i) will be used\n",
3897 for (
int i = 0;
i <
s->nb_streams;
i++)
3915 m = (
a + (uint64_t)
b) >> 1;
3918 if (
offset < current_offset)
3940 if ((sample_rate.
num / sample_rate.
den) == 48000) {
3947 "seeking detected on stream #%d with time base (%d/%d) and "
3948 "sample rate (%d/%d), audio pts won't be accurate.\n",
3950 sample_rate.
num, sample_rate.
den);
3978 if (next_ofs > current_offset)
3993 av_log(mxf->
fc,
AV_LOG_WARNING,
"edit unit sync lost on stream %d, jumping from %"PRId64
" to %"PRId64
"\n", st->
index, edit_unit, new_edit_unit);
4005 if (!bits_per_sample)
4011 bits_per_sample <= 0 ||
4066 max_data_size = klv.
length;
4093 "error getting stream index %"PRIu32
"\n",
4109 if (next_ofs <= 0) {
4117 if ((
size = next_ofs -
pos) <= 0) {
4123 if (
size > max_data_size)
4124 size = max_data_size;
4134 if (klv.
key[12] == 0x06 && klv.
key[13] == 0x01 && klv.
key[14] == 0x10) {
4185 for (
int i = 0;
i <
s->nb_streams;
i++)
4186 s->streams[
i]->priv_data =
NULL;
4190 for (
int i = 0;
i <
mg->metadata_sets_count;
i++)
4192 mg->metadata_sets_count = 0;
4213 const uint8_t *bufp =
p->buf;
4222 for (; bufp < end;) {
4223 if (!((bufp[13] - 1) & 0xF2)){
4241 AVStream *st =
s->streams[stream_index];
4260 if (sample_time < 0)
4264 seekpos =
avio_seek(
s->pb, (
s->bit_rate * seconds) >> 3, SEEK_SET);
4277 for (
i = 0;
i <
s->nb_streams;
i++) {
4278 MXFTrack *new_source_track =
s->streams[
i]->priv_data;
4281 source_track = new_source_track;
4286 if (
i ==
s->nb_streams)
4292 sample_time =
FFMAX(sample_time, 0);
4301 sample_time < t->ptses[0] &&
4303 sample_time = t->
ptses[0];
4309 sample_time += t->
offsets[sample_time];
4325 if (seekpos < klv.next_klv - klv.length || seekpos >= klv.
next_klv) {
4337 for (
int i = 0;
i <
s->nb_streams;
i++) {
4341 int64_t track_edit_unit = sample_time;
4351 {
"eia608_extract",
"extract eia 608 captions from s436m track",