Go to the documentation of this file.
26 #include "config_components.h"
93 unsigned len,
const char *
key)
113 unsigned len,
const char *
key)
127 unsigned len,
const char *
key)
136 unsigned len,
const char *
key)
152 0x00C4,0x00C5,0x00C7,0x00C9,0x00D1,0x00D6,0x00DC,0x00E1,
153 0x00E0,0x00E2,0x00E4,0x00E3,0x00E5,0x00E7,0x00E9,0x00E8,
154 0x00EA,0x00EB,0x00ED,0x00EC,0x00EE,0x00EF,0x00F1,0x00F3,
155 0x00F2,0x00F4,0x00F6,0x00F5,0x00FA,0x00F9,0x00FB,0x00FC,
156 0x2020,0x00B0,0x00A2,0x00A3,0x00A7,0x2022,0x00B6,0x00DF,
157 0x00AE,0x00A9,0x2122,0x00B4,0x00A8,0x2260,0x00C6,0x00D8,
158 0x221E,0x00B1,0x2264,0x2265,0x00A5,0x00B5,0x2202,0x2211,
159 0x220F,0x03C0,0x222B,0x00AA,0x00BA,0x03A9,0x00E6,0x00F8,
160 0x00BF,0x00A1,0x00AC,0x221A,0x0192,0x2248,0x2206,0x00AB,
161 0x00BB,0x2026,0x00A0,0x00C0,0x00C3,0x00D5,0x0152,0x0153,
162 0x2013,0x2014,0x201C,0x201D,0x2018,0x2019,0x00F7,0x25CA,
163 0x00FF,0x0178,0x2044,0x20AC,0x2039,0x203A,0xFB01,0xFB02,
164 0x2021,0x00B7,0x201A,0x201E,0x2030,0x00C2,0x00CA,0x00C1,
165 0x00CB,0x00C8,0x00CD,0x00CE,0x00CF,0x00CC,0x00D3,0x00D4,
166 0xF8FF,0x00D2,0x00DA,0x00DB,0x00D9,0x0131,0x02C6,0x02DC,
167 0x00AF,0x02D8,0x02D9,0x02DA,0x00B8,0x02DD,0x02DB,0x02C7,
171 char *
dst,
int dstlen)
174 char *end =
dst+dstlen-1;
177 for (
i = 0;
i <
len;
i++) {
199 for (
int i = 0;
i <
c->nb_heif_item;
i++) {
200 if (!
c->heif_item[
i] ||
c->heif_item[
i]->item_id !=
id)
203 item =
c->heif_item[
i];
219 if (
c->fc->nb_streams < 1)
222 if (
c->cur_item_id == -1)
223 return c->fc->streams[
c->fc->nb_streams-1];
257 st =
c->fc->streams[
c->fc->nb_streams - 1];
278 char buf[200], place[100];
279 uint16_t langcode = 0;
280 double longitude, latitude, altitude;
281 const char *
key =
"location";
283 if (
len < 4 + 2 + 1 + 1 + 4 + 4 + 4) {
303 "loci too short (%u bytes left, need at least %d)\n",
len, 12);
311 snprintf(buf,
sizeof(buf),
"%+08.4f%+09.4f", latitude, longitude);
331 if (
c->ignore_chapters)
335 if (n_hmmt >
len / 4)
352 uint16_t langcode = 0;
353 uint32_t data_type = 0, str_size_alloc;
360 if (
c->trak_index >= 0 &&
c->trak_index <
c->fc->nb_streams)
361 metadata = &
c->fc->streams[
c->trak_index]->metadata;
366 case MKTAG(
'@',
'P',
'R',
'M'):
key =
"premiere_version"; raw = 1;
break;
367 case MKTAG(
'@',
'P',
'R',
'Q'):
key =
"quicktime_version"; raw = 1;
break;
368 case MKTAG(
'X',
'M',
'P',
'_'):
369 if (
c->export_xmp) {
key =
"xmp"; raw = 1; }
break;
370 case MKTAG(
'a',
'A',
'R',
'T'):
key =
"album_artist";
break;
371 case MKTAG(
'a',
'k',
'I',
'D'):
key =
"account_type";
373 case MKTAG(
'a',
'p',
'I',
'D'):
key =
"account_id";
break;
374 case MKTAG(
'c',
'a',
't',
'g'):
key =
"category";
break;
375 case MKTAG(
'c',
'p',
'i',
'l'):
key =
"compilation";
377 case MKTAG(
'c',
'p',
'r',
't'):
key =
"copyright";
break;
378 case MKTAG(
'd',
'e',
's',
'c'):
key =
"description";
break;
379 case MKTAG(
'd',
'i',
's',
'k'):
key =
"disc";
381 case MKTAG(
'e',
'g',
'i',
'd'):
key =
"episode_uid";
383 case MKTAG(
'F',
'I',
'R',
'M'):
key =
"firmware"; raw = 1;
break;
384 case MKTAG(
'g',
'n',
'r',
'e'):
key =
"genre";
386 case MKTAG(
'h',
'd',
'v',
'd'):
key =
"hd_video";
388 case MKTAG(
'H',
'M',
'M',
'T'):
390 case MKTAG(
'k',
'e',
'y',
'w'):
key =
"keywords";
break;
391 case MKTAG(
'l',
'd',
'e',
's'):
key =
"synopsis";
break;
392 case MKTAG(
'l',
'o',
'c',
'i'):
394 case MKTAG(
'm',
'a',
'n',
'u'):
key =
"make";
break;
395 case MKTAG(
'm',
'o',
'd',
'l'):
key =
"model";
break;
396 case MKTAG(
'n',
'a',
'm',
'e'):
key =
"name";
break;
397 case MKTAG(
'p',
'c',
's',
't'):
key =
"podcast";
399 case MKTAG(
'p',
'g',
'a',
'p'):
key =
"gapless_playback";
401 case MKTAG(
'p',
'u',
'r',
'd'):
key =
"purchase_date";
break;
402 case MKTAG(
'r',
't',
'n',
'g'):
key =
"rating";
404 case MKTAG(
's',
'o',
'a',
'a'):
key =
"sort_album_artist";
break;
405 case MKTAG(
's',
'o',
'a',
'l'):
key =
"sort_album";
break;
406 case MKTAG(
's',
'o',
'a',
'r'):
key =
"sort_artist";
break;
407 case MKTAG(
's',
'o',
'c',
'o'):
key =
"sort_composer";
break;
408 case MKTAG(
's',
'o',
'n',
'm'):
key =
"sort_name";
break;
409 case MKTAG(
's',
'o',
's',
'n'):
key =
"sort_show";
break;
410 case MKTAG(
's',
't',
'i',
'k'):
key =
"media_type";
412 case MKTAG(
't',
'r',
'k',
'n'):
key =
"track";
414 case MKTAG(
't',
'v',
'e',
'n'):
key =
"episode_id";
break;
415 case MKTAG(
't',
'v',
'e',
's'):
key =
"episode_sort";
417 case MKTAG(
't',
'v',
'n',
'n'):
key =
"network";
break;
418 case MKTAG(
't',
'v',
's',
'h'):
key =
"show";
break;
419 case MKTAG(
't',
'v',
's',
'n'):
key =
"season_number";
421 case MKTAG(0xa9,
'A',
'R',
'T'):
key =
"artist";
break;
422 case MKTAG(0xa9,
'P',
'R',
'D'):
key =
"producer";
break;
423 case MKTAG(0xa9,
'a',
'l',
'b'):
key =
"album";
break;
424 case MKTAG(0xa9,
'a',
'u',
't'):
key =
"artist";
break;
425 case MKTAG(0xa9,
'c',
'h',
'p'):
key =
"chapter";
break;
426 case MKTAG(0xa9,
'c',
'm',
't'):
key =
"comment";
break;
427 case MKTAG(0xa9,
'c',
'o',
'm'):
key =
"composer";
break;
428 case MKTAG(0xa9,
'c',
'p',
'y'):
key =
"copyright";
break;
429 case MKTAG(0xa9,
'd',
'a',
'y'):
key =
"date";
break;
430 case MKTAG(0xa9,
'd',
'i',
'r'):
key =
"director";
break;
431 case MKTAG(0xa9,
'd',
'i',
's'):
key =
"disclaimer";
break;
432 case MKTAG(0xa9,
'e',
'd',
'1'):
key =
"edit_date";
break;
433 case MKTAG(0xa9,
'e',
'n',
'c'):
key =
"encoder";
break;
434 case MKTAG(0xa9,
'f',
'm',
't'):
key =
"original_format";
break;
435 case MKTAG(0xa9,
'g',
'e',
'n'):
key =
"genre";
break;
436 case MKTAG(0xa9,
'g',
'r',
'p'):
key =
"grouping";
break;
437 case MKTAG(0xa9,
'h',
's',
't'):
key =
"host_computer";
break;
438 case MKTAG(0xa9,
'i',
'n',
'f'):
key =
"comment";
break;
439 case MKTAG(0xa9,
'l',
'y',
'r'):
key =
"lyrics";
break;
440 case MKTAG(0xa9,
'm',
'a',
'k'):
key =
"make";
break;
441 case MKTAG(0xa9,
'm',
'o',
'd'):
key =
"model";
break;
442 case MKTAG(0xa9,
'n',
'a',
'm'):
key =
"title";
break;
443 case MKTAG(0xa9,
'o',
'p',
'e'):
key =
"original_artist";
break;
444 case MKTAG(0xa9,
'p',
'r',
'd'):
key =
"producer";
break;
445 case MKTAG(0xa9,
'p',
'r',
'f'):
key =
"performers";
break;
446 case MKTAG(0xa9,
'r',
'e',
'q'):
key =
"playback_requirements";
break;
447 case MKTAG(0xa9,
's',
'r',
'c'):
key =
"original_source";
break;
448 case MKTAG(0xa9,
's',
't',
'3'):
key =
"subtitle";
break;
449 case MKTAG(0xa9,
's',
'w',
'r'):
key =
"encoder";
break;
450 case MKTAG(0xa9,
't',
'o',
'o'):
key =
"encoder";
break;
451 case MKTAG(0xa9,
't',
'r',
'k'):
key =
"track";
break;
452 case MKTAG(0xa9,
'u',
'r',
'l'):
key =
"URL";
break;
453 case MKTAG(0xa9,
'w',
'r',
'n'):
key =
"warning";
break;
454 case MKTAG(0xa9,
'w',
'r',
't'):
key =
"composer";
break;
455 case MKTAG(0xa9,
'x',
'y',
'z'):
key =
"location";
break;
458 if (
c->itunes_metadata && atom.
size > 8) {
461 if (
tag ==
MKTAG(
'd',
'a',
't',
'a') && data_size <= atom.size && data_size >= 16) {
464 str_size = data_size - 16;
467 if (!
key &&
c->found_hdlr_mdta &&
c->meta_keys) {
469 if (index < c->meta_keys_count &&
index > 0) {
471 }
else if (atom.
type !=
MKTAG(
'c',
'o',
'v',
'r')) {
473 "The index of 'data' is out of range: %"PRId32
" < 1 or >= %d.\n",
474 index,
c->meta_keys_count);
477 if (atom.
type ==
MKTAG(
'c',
'o',
'v',
'r') ||
478 (
key && !strcmp(
key,
"com.apple.quicktime.artwork"))) {
484 atom.
size -= str_size;
490 }
else if (atom.
size > 4 && (
key ||
c->export_all) && !
c->itunes_metadata && !raw) {
492 if (str_size > atom.
size) {
502 str_size = atom.
size;
504 if (
c->export_all && !
key) {
510 if (atom.
size < 0 || str_size >= INT_MAX/2)
515 num = (data_type >= 21 && data_type <= 23);
516 str_size_alloc = (num ? 512 : (raw ? str_size : str_size * 2)) + 1;
524 if (!raw && (data_type == 3 || (data_type == 0 && (langcode < 0x400 || langcode == 0x7fff)))) {
526 }
else if (data_type == 21) {
530 else if (str_size == 2)
532 else if (str_size == 3)
534 else if (str_size == 4)
536 if (
snprintf(str, str_size_alloc,
"%d",
val) >= str_size_alloc) {
538 "Failed to store the number (%d) in string.\n",
val);
542 }
else if (data_type == 22) {
543 unsigned int val = 0;
546 else if (str_size == 2)
548 else if (str_size == 3)
550 else if (str_size == 4)
552 if (
snprintf(str, str_size_alloc,
"%u",
val) >= str_size_alloc) {
554 "Failed to store the number (%u) in string.\n",
val);
558 }
else if (data_type == 23 && str_size >= 4) {
560 if (
snprintf(str, str_size_alloc,
"%f",
val) >= str_size_alloc) {
562 "Failed to store the float32 number (%f) in string.\n",
val);
566 }
else if (data_type > 1 && data_type != 4) {
590 if (!strcmp(
key,
"encoder")) {
591 int major, minor, micro;
592 if (sscanf(str,
"HandBrake %d.%d.%d", &major, &minor, µ) == 3) {
593 c->handbrake_version = 1000000*major + 1000*minor + micro;
597 atom.
size -= str_size;
606 if (
c->itunes_metadata && atom.
size > 8)
617 int i, nb_chapters, str_len,
version;
621 if (
c->ignore_chapters)
624 if ((atom.
size -= 5) < 0)
633 for (
i = 0;
i < nb_chapters;
i++) {
640 if ((atom.
size -= 9+str_len) < 0)
652 #define MIN_DATA_ENTRY_BOX_SIZE 12
659 if (
c->fc->nb_streams < 1)
661 st =
c->fc->streams[
c->fc->nb_streams-1];
668 entries >= UINT_MAX /
sizeof(*sc->
drefs))
683 for (
i = 0;
i < entries;
i++) {
688 if (
size < 12 || next < 0 || next > INT64_MAX -
size)
698 uint16_t volume_len,
len;
705 volume_len =
FFMIN(volume_len, 27);
709 dref->
volume[volume_len] = 0;
751 if (
len > volume_len && !strncmp(dref->
path, dref->
volume, volume_len)) {
757 for (j =
len - 1; j >= 0; j--) {
758 if (dref->
path[j] == 0)
763 for (j = 0; j <
len; j++)
764 if (dref->
path[j] ==
':' || dref->
path[j] == 0)
767 }
else if (
type == 0) {
779 for (j = 0; j <
len; j++)
780 if (dref->
dir[j] ==
':')
816 if (
c->trak_index < 0) {
818 c->found_hdlr_mdta = 1;
823 st =
c->fc->streams[
c->fc->nb_streams-1];
838 title_size = atom.
size - 24;
839 if (title_size > 0) {
840 if (title_size >
FFMIN(INT_MAX, SIZE_MAX-1))
851 title_str[title_size] = 0;
853 int off = (!
c->isom && title_str[0] == title_size - 1);
873 int ac3info, acmod, lfeon, bsmod;
876 if (
c->fc->nb_streams < 1)
878 st =
c->fc->streams[
c->fc->nb_streams-1];
889 bsmod = (ac3info >> 14) & 0x7;
890 acmod = (ac3info >> 11) & 0x7;
891 lfeon = (ac3info >> 10) & 0x1;
916 unsigned descriptors_size;
917 int nb_frames, disposition;
923 if (
c->fc->nb_streams < 1)
934 if (!descriptors_size || descriptors_size > INT_MAX)
937 st =
c->fc->streams[
c->fc->nb_streams - 1];
955 if (
ret != descriptors_size)
959 descriptor_pb = &
b.pub;
1056 for (
int j = 0; j <
mix->nb_submixes; j++) {
1063 for (
int l = 0; l <
c->fc->nb_stream_groups; l++)
1066 audio_element =
c->fc->stream_groups[l];
1071 for (
int l = 0; l < audio_element->
nb_streams; l++) {
1097 if (atom.
size < 8 ||
c->fc->nb_streams < 1)
1100 st =
c->fc->streams[
c->fc->nb_streams-1];
1113 if (sample_rate > 0) {
1115 "overwrite sample rate from %d to %d by 'srat'\n",
1120 "ignore invalid sample rate %d in 'srat'\n", sample_rate);
1131 int eac3info, acmod, lfeon, bsmod;
1134 if (
c->fc->nb_streams < 1)
1136 st =
c->fc->streams[
c->fc->nb_streams-1];
1152 bsmod = (eac3info >> 12) & 0x1f;
1153 acmod = (eac3info >> 9) & 0x7;
1154 lfeon = (eac3info >> 8) & 0x1;
1171 #define DDTS_SIZE 20
1174 uint32_t frame_duration_code = 0;
1175 uint32_t channel_layout_code = 0;
1184 if (
c->fc->nb_streams < 1) {
1187 st =
c->fc->streams[
c->fc->nb_streams-1];
1197 frame_duration_code =
get_bits(&gb, 2);
1199 channel_layout_code =
get_bits(&gb, 16);
1202 (frame_duration_code == 0) ? 512 :
1203 (frame_duration_code == 1) ? 1024 :
1204 (frame_duration_code == 2) ? 2048 :
1205 (frame_duration_code == 3) ? 4096 : 0;
1207 if (channel_layout_code > 0xff) {
1226 if (
c->fc->nb_streams < 1)
1228 st =
c->fc->streams[
c->fc->nb_streams-1];
1248 if (
c->fc->nb_streams < 1)
1250 st =
c->fc->streams[
c->fc->nb_streams-1];
1256 "Unsupported 'chnl' box with version %d, flags: %#x\n",
1280 if (
c->fc->nb_streams < 1)
1282 st =
c->fc->streams[
c->fc->nb_streams-1];
1296 AVRational aperture_width, aperture_height, horiz_off, vert_off;
1298 uint64_t top, bottom,
left, right;
1326 if (aperture_width.
num < 0 || aperture_width.
den < 0 ||
1327 aperture_height.
num < 0 || aperture_height.
den < 0 ||
1328 horiz_off.
den < 0 || vert_off.
den < 0) {
1338 "horizOff %d/%d vertOff %d/%d\n",
1339 aperture_width.
num, aperture_width.
den, aperture_height.
num, aperture_height.
den,
1340 horiz_off.
num, horiz_off.
den, vert_off.
num, vert_off.
den);
1357 if (bottom > (
height - 1) ||
1358 right > (
width - 1)) {
1363 bottom =
height - 1 - bottom;
1364 right =
width - 1 - right;
1366 if (!(
left | right | top | bottom))
1370 (top + bottom) >=
height) {
1378 sizeof(uint32_t) * 4, 0);
1406 if (
c->fc->nb_streams < 1)
1408 st =
c->fc->streams[
c->fc->nb_streams-1];
1429 #define DRM_BLOB_SIZE 56
1433 uint8_t intermediate_key[20];
1434 uint8_t intermediate_iv[20];
1437 uint8_t file_checksum[20];
1438 uint8_t calculated_checksum[20];
1439 char checksum_string[2 *
sizeof(file_checksum) + 1];
1443 uint8_t *activation_bytes =
c->activation_bytes;
1453 if (!
c->aes_decrypt) {
1467 ff_data_to_hex(checksum_string, file_checksum,
sizeof(file_checksum), 1);
1471 if (!activation_bytes) {
1476 if (
c->activation_bytes_size != 4) {
1483 if (
c->audible_fixed_key_size != 16) {
1503 if (memcmp(calculated_checksum, file_checksum, 20)) {
1510 for (
i = 0;
i < 4;
i++) {
1512 if (activation_bytes[
i] !=
output[3 -
i]) {
1518 memcpy(
c->file_key,
output + 8, 16);
1534 if (
c->audible_key_size != 16) {
1539 if (
c->audible_iv_size != 16) {
1545 if (!
c->aes_decrypt) {
1549 memcpy(
c->file_key,
c->audible_key, 16);
1550 memcpy(
c->file_iv,
c->audible_iv, 16);
1560 unsigned char iv[16];
1562 memcpy(iv,
c->file_iv, 16);
1574 int comp_brand_size;
1575 char* comp_brands_str;
1576 uint8_t
type[5] = {0};
1580 if (
c->fc->nb_streams) {
1587 if (strcmp(
type,
"qt "))
1594 comp_brand_size = atom.
size - 8;
1595 if (comp_brand_size < 0 || comp_brand_size == INT_MAX)
1597 comp_brands_str =
av_malloc(comp_brand_size + 1);
1598 if (!comp_brands_str)
1606 comp_brands_str[comp_brand_size] = 0;
1611 if (!strcmp(
type,
"aaxc")) {
1623 if (
c->found_moov) {
1645 if (index < 0 || index >= frag_index->
nb_items)
1661 if (frag_index->
current < 0 ||
1680 if (frag_index->
current < 0 ||
1708 if (moof_offset >=
offset)
1710 if (moof_offset <=
offset)
1738 if (!frag_stream_info)
1752 for (j = 0; j <
s->nb_streams; j++) {
1754 if (sc2->
id == frag_stream_info->
id)
1755 frag_stream =
s->streams[j];
1778 m0 = m = (
a +
b) >> 1;
1784 if (m <
b && frag_time <= timestamp)
1801 if (index < c->frag_index.nb_items &&
1808 &
c->frag_index.allocated_size,
1809 (
c->frag_index.nb_items + 1) *
1810 sizeof(*
c->frag_index.item));
1813 c->frag_index.item = item;
1817 if (!frag_stream_info)
1820 for (
i = 0;
i <
c->fc->nb_streams;
i++) {
1828 frag_stream_info[
i].
id = sc->
id;
1839 if (index < c->frag_index.nb_items)
1840 memmove(
c->frag_index.item +
index + 1,
c->frag_index.item +
index,
1841 (
c->frag_index.nb_items -
index) *
sizeof(*
c->frag_index.item));
1843 item = &
c->frag_index.item[
index];
1849 c->frag_index.nb_items++;
1855 int id,
int entries)
1864 if (frag_stream_info && frag_stream_info->
index_entry >= 0)
1872 c->fragment.found_tfhd = 0;
1874 if (!
c->has_looked_for_mfra &&
c->use_mfra_for > 0) {
1875 c->has_looked_for_mfra = 1;
1882 "read the mfra (may be a live ismv)\n");
1886 "seekable, can not look for mfra\n");
1889 c->fragment.moof_offset =
c->fragment.implicit_offset =
avio_tell(pb) - 8;
1908 if (time > 0 && time < 2082844800) {
1916 if ((
int64_t)(time * 1000000ULL) / 1000000 != time) {
1933 if (
c->fc->nb_streams < 1)
1935 st =
c->fc->streams[
c->fc->nb_streams-1];
1979 if (
c->time_scale <= 0) {
1993 for (
i = 0;
i < 3;
i++) {
2014 if (
fc->nb_streams < 1)
2016 st =
fc->streams[
fc->nb_streams-1];
2041 int little_endian =
avio_rb16(pb) & 0xFF;
2043 if (little_endian == 1)
2052 int pcm_sample_size;
2057 if (atom.
size < 6) {
2067 "Unsupported 'pcmC' box with version %d, flags: %x",
2073 pcm_sample_size =
avio_r8(pb);
2075 if (
fc->nb_streams < 1)
2078 st =
fc->streams[
fc->nb_streams - 1];
2082 switch (pcm_sample_size) {
2096 switch (pcm_sample_size) {
2118 if (format_flags & 1)
2129 char color_parameter_type[5] = { 0 };
2143 if (strncmp(color_parameter_type,
"nclx", 4) &&
2144 strncmp(color_parameter_type,
"nclc", 4) &&
2145 strncmp(color_parameter_type,
"prof", 4)) {
2147 color_parameter_type);
2151 if (!strncmp(color_parameter_type,
"prof", 4)) {
2153 uint8_t *icc_profile;
2161 icc_profile = sd->
data;
2163 if (
c->heif_icc_profile_items >=
c->fc->max_streams) {
2165 "HEIF ICC profile copies exceed cap %d; ignoring further items\n",
2166 c->fc->max_streams);
2176 c->heif_icc_profile_items++;
2187 "%s: pri %d trc %d matrix %d",
2190 if (!strncmp(color_parameter_type,
"nclx", 4)) {
2217 unsigned mov_field_order;
2220 if (
c->fc->nb_streams < 1)
2222 st =
c->fc->streams[
c->fc->nb_streams-1];
2226 if ((mov_field_order & 0xFF00) == 0x0100)
2228 else if ((mov_field_order & 0xFF00) == 0x0200) {
2229 switch (mov_field_order & 0xFF) {
2252 if (
size > INT_MAX || (uint64_t)atom.
size > INT_MAX)
2275 }
else if (err < atom.
size) {
2289 uint64_t original_size;
2292 if (
c->fc->nb_streams < 1)
2294 st =
c->fc->streams[
c->fc->nb_streams-1];
2343 if (!
ret &&
c->fc->nb_streams >= 1) {
2355 if (
c->fc->nb_streams >= 1) {
2356 AVStream *
const st =
c->fc->streams[
c->fc->nb_streams - 1];
2367 if (
cid == 0xd4d ||
cid == 0xd4e)
2378 if (num <= 0 || den <= 0)
2382 if (den >= INT_MAX / 2)
2402 uint64_t original_size;
2403 if (
c->fc->nb_streams >= 1) {
2407 if (atom.
size == 16) {
2412 if (length == atom.
size) {
2413 const uint8_t range_value = par->
extradata[original_size + 19];
2414 switch (range_value) {
2451 if (
c->fc->nb_streams < 1)
2453 st =
c->fc->streams[
c->fc->nb_streams-1];
2455 if ((uint64_t)atom.
size > (1<<30))
2465 }
else if (atom.
size > 8) {
2479 #define ALAC_EXTRADATA_SIZE 36
2512 if ((uint64_t)atom.
size > (1<<30))
2515 if (atom.
type ==
MKTAG(
'v',
'v',
'c',
'C')) {
2520 if (atom.
size >= 10) {
2552 uint8_t profile_level;
2555 if (
c->fc->nb_streams < 1)
2557 st =
c->fc->streams[
c->fc->nb_streams-1];
2559 if (atom.
size >= (1<<28) || atom.
size < 7)
2563 if ((profile_level & 0xf0) != 0xc0)
2576 for (
int i = 0;
i <
tag->nb_id;
i++) {
2577 if (
tag->id[
i] ==
id)
2631 if (
c->fc->nb_streams < 1)
2637 if (atom.
size > 4) {
2644 st =
c->fc->streams[
c->fc->nb_streams - 1];
2663 if (
c->fc->nb_streams < 1)
2671 st =
c->fc->streams[
c->fc->nb_streams - 1];
2695 if (
c->fc->nb_streams < 1)
2697 if (atom.
size <= 40)
2699 st =
c->fc->streams[
c->fc->nb_streams-1];
2701 if ((uint64_t)atom.
size > (1<<30))
2716 unsigned int i, entries;
2718 if (
c->trak_index < 0) {
2722 if (
c->fc->nb_streams < 1)
2724 st =
c->fc->streams[
c->fc->nb_streams-1];
2736 (atom.
type ==
MKTAG(
's',
't',
'c',
'o') ? 4 : 8)));
2753 if (atom.
type ==
MKTAG(
's',
't',
'c',
'o'))
2756 else if (atom.
type ==
MKTAG(
'c',
'o',
'6',
'4'))
2782 ((
format & 0xFFFF) ==
'm' + (
's' << 8) ||
2783 (
format & 0xFFFF) ==
'T' + (
'S' << 8)))
2820 uint8_t codec_name[32] = { 0 };
2861 if (!strncmp(codec_name,
"Planar Y'CbCr 8-bit 4:2:0", 25)) {
2868 !strncmp(codec_name,
"Sorenson H263", 13))
2884 int bits_per_sample,
flags;
2913 (compatible_brands && strstr(compatible_brands->
value,
"qt ")) ||
3044 if (str_size > 0 &&
size >= (
int)str_size + 30 &&
3046 char *reel_name =
av_malloc(str_size + 1);
3050 reel_name[str_size] = 0;
3075 #if CONFIG_DV_DEMUXER
3169 int codec_tag,
int format,
3181 : codec_tag !=
MKTAG(
'j',
'p',
'e',
'g')))) {
3219 int pseudo_stream_id;
3222 st =
c->fc->streams[
c->fc->nb_streams-1];
3225 for (pseudo_stream_id = 0;
3227 pseudo_stream_id++) {
3230 int ret, dref_id = 1;
3240 }
else if (
size <= 7) {
3242 "invalid size %"PRId64
" in stsd\n",
size);
3259 "size=%"PRId64
" 4CC=%s codec_type=%d\n",
size,
3289 }
else if (
a.size > 0)
3322 if (
c->fc->nb_streams < 1)
3324 st =
c->fc->streams[
c->fc->nb_streams - 1];
3329 "Duplicate stsd found in this track.\n");
3338 if (entries <= 0 || entries > atom.
size / 8 || entries > 1024) {
3386 unsigned int i, entries;
3388 if (
c->trak_index < 0) {
3393 if (
c->fc->nb_streams < 1)
3395 st =
c->fc->streams[
c->fc->nb_streams-1];
3402 if ((uint64_t)entries * 12 + 4 > atom.
size)
3487 unsigned i, entries;
3489 if (
c->trak_index < 0) {
3494 if (
c->fc->nb_streams < 1)
3496 st =
c->fc->streams[
c->fc->nb_streams-1];
3529 unsigned int i, entries;
3531 if (
c->trak_index < 0) {
3536 if (
c->fc->nb_streams < 1)
3538 st =
c->fc->streams[
c->fc->nb_streams-1];
3557 if (entries >= UINT_MAX /
sizeof(
int))
3583 unsigned int i, entries, sample_size, field_size, num_bytes;
3588 if (
c->trak_index < 0) {
3593 if (
c->fc->nb_streams < 1)
3595 st =
c->fc->streams[
c->fc->nb_streams-1];
3601 if (atom.
type ==
MKTAG(
's',
't',
's',
'z')) {
3620 if (field_size != 4 && field_size != 8 && field_size != 16 && field_size != 32) {
3637 num_bytes = (entries*field_size+4)>>3;
3655 for (
i = 0;
i < entries;
i++) {
3676 unsigned int i, entries;
3678 int64_t total_sample_count = 0;
3682 if (
c->trak_index < 0) {
3687 if (
c->fc->nb_streams < 1)
3689 st =
c->fc->streams[
c->fc->nb_streams-1];
3697 c->fc->nb_streams-1, entries);
3703 if (entries >= INT_MAX /
sizeof(*sc->
stts_data))
3707 unsigned int sample_duration;
3708 unsigned int sample_count;
3709 unsigned int min_entries =
FFMIN(
FFMAX(
i + 1, 1024 * 1024), entries);
3727 sample_count, sample_duration);
3732 if (sample_duration >
c->max_stts_delta) {
3735 av_log(
c->fc,
AV_LOG_WARNING,
"Too large sample offset %u in stts entry %u with count %u in st:%d. Clipping to 1.\n",
3736 sample_duration,
i, sample_count, st->
index);
3738 corrected_dts =
av_sat_add64(corrected_dts, (delta_magnitude < 0 ? (
int64_t)delta_magnitude : 1) * sample_count);
3740 corrected_dts += sample_duration * (uint64_t)sample_count;
3745 if (current_dts > corrected_dts) {
3748 current_dts -= correction * (uint64_t)sample_count;
3759 duration <= INT64_MAX - sc->duration_for_fps &&
3760 total_sample_count <= INT_MAX - sc->nb_frames_for_fps) {
3782 "All samples in data stream index:id [%d:%d] have zero "
3783 "duration, stream set to be discarded by default. Override "
3784 "using AVStream->discard or -discard for ffmpeg command.\n",
3799 if (
c->fc->nb_streams < 1)
3801 st =
c->fc->streams[
c->fc->nb_streams - 1];
3806 entries = atom.
size - 4;
3809 c->fc->nb_streams - 1, entries);
3816 if (entries < 0 || entries > UINT_MAX)
3845 unsigned int i, entries, ctts_count = 0;
3847 if (
c->trak_index < 0) {
3852 if (
c->fc->nb_streams < 1)
3854 st =
c->fc->streams[
c->fc->nb_streams-1];
3865 if (entries >= UINT_MAX /
sizeof(*sc->
ctts_data))
3874 const size_t min_size_needed = (ctts_count + 1) *
sizeof(
MOVCtts);
3875 const size_t requested_size =
3884 "ignoring CTTS entry with count=%d duration=%d\n",
3889 if (ctts_count >= UINT_MAX /
sizeof(
MOVCtts) - 1)
3927 uint32_t grouping_type;
3928 uint32_t default_length;
3929 av_unused uint32_t default_group_description_index;
3930 uint32_t entry_count;
3932 if (
c->fc->nb_streams < 1)
3934 st =
c->fc->streams[
c->fc->nb_streams - 1];
3945 if (grouping_type !=
MKTAG(
's',
'y',
'n',
'c'))
3959 uint32_t description_length = default_length;
3960 if (
version >= 1 && default_length == 0)
3962 if (grouping_type ==
MKTAG(
's',
'y',
'n',
'c')) {
3963 const uint8_t nal_unit_type =
avio_r8(pb) & 0x3f;
3965 description_length -= 1;
3982 unsigned int i, entries;
3984 uint32_t grouping_type;
3988 if (
c->fc->nb_streams < 1)
3990 st =
c->fc->streams[
c->fc->nb_streams-1];
3997 if (grouping_type ==
MKTAG(
'r',
'a',
'p',
' ')) {
4000 }
else if (grouping_type ==
MKTAG(
's',
'y',
'n',
'c')) {
4041 unsigned int edit_list_index,
4042 int64_t *edit_list_media_time,
4049 *edit_list_media_time = msc->
elst_data[edit_list_index].
time;
4053 if (global_timescale == 0) {
4060 if (*edit_list_duration + (uint64_t)*edit_list_media_time > INT64_MAX)
4061 *edit_list_duration = 0;
4134 for (
int64_t index_tts_count = 0; index_tts_count < *
index; index_tts_count++) {
4135 if (*tts_index < tts_count) {
4137 if (tts_data[*tts_index].
count == *tts_sample) {
4144 while (*
index >= 0 && (*tts_index) >= 0 && (*tts_index) < tts_count) {
4148 if ((e_old[*
index].timestamp + tts_data[*tts_index].
offset) <= timestamp_pts &&
4154 if (*tts_sample == 0) {
4156 if (*tts_index >= 0)
4157 *tts_sample = tts_data[*tts_index].
count - 1;
4167 return *
index >= 0 ? 0 : -1;
4191 const size_t requested_size =
4208 ie= &entries[
index];
4223 int64_t* frame_duration_buffer,
4224 int frame_duration_buffer_size) {
4227 av_assert0(end_index >= 0 && end_index <= sti->nb_index_entries);
4228 for (
i = 0;
i < frame_duration_buffer_size;
i++) {
4229 end_ts -= frame_duration_buffer[frame_duration_buffer_size - 1 -
i];
4238 const size_t min_size_needed = (*tts_count + 1) *
sizeof(
MOVTimeToSample);
4239 const size_t requested_size =
4240 min_size_needed > *allocated_size ?
4241 FFMAX(min_size_needed, 2 * (*allocated_size)) :
4247 tts_buf_new =
av_fast_realloc(*tts_data, allocated_size, requested_size);
4252 *tts_data = tts_buf_new;
4258 *tts_count = (*tts_count) + 1;
4262 #define MAX_REORDER_DELAY 16
4268 int ctts_sample = 0;
4271 int j,
r, num_swaps;
4274 pts_buf[j] = INT64_MIN;
4282 buf_start = (buf_start + 1);
4295 while (j != buf_start) {
4298 if (pts_buf[j] < pts_buf[
r]) {
4357 if (range_size > current_sample) {
4361 current_sample -= range_size;
4383 int64_t edit_list_media_time = 0;
4384 int64_t edit_list_duration = 0;
4386 int64_t edit_list_dts_counter = 0;
4387 int64_t edit_list_dts_entry_end = 0;
4388 int64_t edit_list_start_tts_sample = 0;
4391 int64_t empty_edits_sum_duration = 0;
4396 int64_t edit_list_start_encountered = 0;
4399 int num_discarded_begin = 0;
4400 int first_non_zero_audio_edit = -1;
4401 int packet_skip_samples = 0;
4403 int found_keyframe_after_edit = 0;
4404 int found_non_empty_edit = 0;
4437 edit_list_dts_entry_end -= msc->
dts_shift;
4441 start_dts = edit_list_dts_entry_end;
4445 av_log(mov->
fc,
AV_LOG_DEBUG,
"Processing st: %d, edit list %"PRId64
" - media time: %"PRId64
", duration: %"PRId64
"\n",
4446 st->
index, edit_list_index, edit_list_media_time, edit_list_duration);
4448 edit_list_dts_counter = edit_list_dts_entry_end;
4449 edit_list_dts_entry_end =
av_sat_add64(edit_list_dts_entry_end, edit_list_duration);
4450 if (edit_list_dts_entry_end == INT64_MAX) {
4452 edit_list_duration);
4455 num_discarded_begin = 0;
4456 if (!found_non_empty_edit && edit_list_media_time == -1) {
4457 empty_edits_sum_duration += edit_list_duration;
4460 found_non_empty_edit = 1;
4465 if (first_non_zero_audio_edit < 0) {
4466 first_non_zero_audio_edit = 1;
4468 first_non_zero_audio_edit = 0;
4471 if (first_non_zero_audio_edit > 0)
4479 search_timestamp = edit_list_media_time;
4488 &
index, &tts_index_old, &tts_sample_old) < 0) {
4490 "st: %d edit list: %"PRId64
" Missing key frame while searching for timestamp: %"PRId64
"\n",
4491 st->
index, edit_list_index, search_timestamp);
4493 &
index, &tts_index_old, &tts_sample_old) < 0) {
4495 "st: %d edit list %"PRId64
" Cannot find an index entry before timestamp: %"PRId64
".\n",
4496 st->
index, edit_list_index, search_timestamp);
4503 edit_list_start_tts_sample = tts_sample_old;
4506 edit_list_start_encountered = 0;
4507 found_keyframe_after_edit = 0;
4510 frame_duration = (
current + 1 < e_old_end) ?
4511 ((
current + 1)->timestamp -
current->timestamp) : edit_list_duration;
4519 if (tts_data_old && tts_index_old < tts_count_old) {
4520 curr_ctts = tts_data_old[tts_index_old].
offset;
4521 av_log(mov->
fc,
AV_LOG_TRACE,
"stts: %"PRId64
" ctts: %"PRId64
", tts_index: %"PRId64
", tts_count: %"PRId64
"\n",
4522 curr_cts, curr_ctts, tts_index_old, tts_count_old);
4523 curr_cts += curr_ctts;
4525 if (tts_sample_old == tts_data_old[tts_index_old].
count) {
4528 tts_data_old[tts_index_old].
count - edit_list_start_tts_sample,
4529 tts_data_old[tts_index_old].
offset, tts_data_old[tts_index_old].
duration) == -1) {
4532 tts_data_old[tts_index_old].
count - edit_list_start_tts_sample,
4533 tts_data_old[tts_index_old].
offset);
4538 edit_list_start_tts_sample = 0;
4542 if (curr_cts < edit_list_media_time || curr_cts >= (edit_list_duration + edit_list_media_time)) {
4544 curr_cts < edit_list_media_time && curr_cts + frame_duration > edit_list_media_time &&
4545 first_non_zero_audio_edit > 0) {
4546 packet_skip_samples = edit_list_media_time - curr_cts;
4550 edit_list_dts_counter -= packet_skip_samples;
4551 if (edit_list_start_encountered == 0) {
4552 edit_list_start_encountered = 1;
4555 if (frame_duration_buffer) {
4557 frame_duration_buffer, num_discarded_begin);
4562 av_log(mov->
fc,
AV_LOG_DEBUG,
"skip %d audio samples from curr_cts: %"PRId64
"\n", packet_skip_samples, curr_cts);
4567 if (edit_list_start_encountered == 0) {
4568 num_discarded_begin++;
4569 frame_duration_buffer =
av_realloc(frame_duration_buffer,
4570 num_discarded_begin *
sizeof(
int64_t));
4571 if (!frame_duration_buffer) {
4575 frame_duration_buffer[num_discarded_begin - 1] = frame_duration;
4590 if (edit_list_start_encountered == 0) {
4591 edit_list_start_encountered = 1;
4594 if (frame_duration_buffer) {
4596 frame_duration_buffer, num_discarded_begin);
4609 if (!current_index_range ||
index != current_index_range->
end) {
4610 current_index_range = current_index_range ? current_index_range + 1
4614 current_index_range->
end =
index + 1;
4617 if (edit_list_start_encountered > 0) {
4618 edit_list_dts_counter = edit_list_dts_counter + frame_duration;
4622 if ((curr_cts + frame_duration >= (edit_list_duration + edit_list_media_time)) &&
4629 found_keyframe_after_edit = 1;
4632 if (tts_sample_old != 0) {
4635 tts_sample_old - edit_list_start_tts_sample,
4636 tts_data_old[tts_index_old].
offset, tts_data_old[tts_index_old].
duration) == -1) {
4638 tts_index_old, tts_sample_old - edit_list_start_tts_sample,
4639 tts_data_old[tts_index_old].
offset);
4674 current_index_range = current_index_range ? current_index_range + 1
4676 current_index_range->
start = 0;
4677 current_index_range->
end = 0;
4736 if (sg->
index == cra_index)
4737 for (uint32_t j = 0; j < sg->
count; j++)
4739 if (sg->
count > INT_MAX - sample_id)
4741 sample_id += sg->
count;
4752 #define MOV_MERGE_CTTS 1
4753 #define MOV_MERGE_STTS 2
4828 unsigned int stts_index = 0;
4829 unsigned int stsc_index = 0;
4830 unsigned int stss_index = 0;
4831 unsigned int stps_index = 0;
4833 uint64_t stream_size = 0;
4840 int i, edit_start_index = 0, multiple_edits = 0;
4846 if (
i == 0 && e->
time == -1) {
4850 edit_start_index = 1;
4851 }
else if (
i == edit_start_index && e->
time >= 0) {
4861 "not supported in fragmented MP4 files\n");
4864 "Use -advanced_editlist to correctly decode otherwise "
4865 "a/v desync might occur\n");
4891 unsigned int current_sample = 0;
4892 unsigned int stts_sample = 0;
4893 unsigned int sample_size;
4895 unsigned int rap_group_index = 0;
4896 unsigned int rap_group_sample = 0;
4951 if (rap_group_present && rap_group_index < sc->rap_group_count) {
4954 if (++rap_group_sample == sc->
rap_group[rap_group_index].
count) {
4955 rap_group_sample = 0;
4961 && !rap_group_present
4967 if (current_offset > INT64_MAX - sample_size) {
4977 if (sample_size > 0x3FFFFFFF) {
4982 e->
pos = current_offset;
4984 e->
size = sample_size;
4987 av_log(mov->
fc,
AV_LOG_TRACE,
"AVIndex stream %d, sample %u, offset %"PRIx64
", dts %"PRId64
", "
4988 "size %u, distance %u, keyframe %d\n", st->
index, current_sample,
4989 current_offset, current_dts, sample_size,
distance, keyframe);
4994 current_offset += sample_size;
4995 stream_size += sample_size;
5011 unsigned chunk_samples, total = 0;
5018 unsigned count, chunk_count;
5033 count = (chunk_samples+1023) / 1024;
5040 total += chunk_count *
count;
5062 while (chunk_samples > 0) {
5068 "Zero bytes per frame, but %d samples per frame",
5091 if (
size > 0x3FFFFFFF) {
5096 e->
pos = current_offset;
5102 "size %u, duration %u\n", st->
index,
i, current_offset, current_dts,
5105 current_offset +=
size;
5142 av_url_split(src_proto,
sizeof(src_proto), src_auth,
sizeof(src_auth), src_host,
sizeof(src_host), &src_port,
NULL, 0,
src);
5143 av_url_split(ref_proto,
sizeof(ref_proto), ref_auth,
sizeof(ref_auth), ref_host,
sizeof(ref_host), &ref_port,
NULL, 0,
ref);
5145 if (strlen(
src) == 0) {
5147 }
else if (strlen(src_auth) + 1 >=
sizeof(src_auth) ||
5148 strlen(ref_auth) + 1 >=
sizeof(ref_auth) ||
5149 strlen(src_host) + 1 >=
sizeof(src_host) ||
5150 strlen(ref_host) + 1 >=
sizeof(ref_host)) {
5152 }
else if (strcmp(src_proto, ref_proto) ||
5153 strcmp(src_auth, ref_auth) ||
5154 strcmp(src_host, ref_host) ||
5155 src_port != ref_port) {
5165 if (
ref->nlvl_to > 0 &&
ref->nlvl_from > 0) {
5166 char filename[1025];
5167 const char *src_path;
5171 src_path = strrchr(
src,
'/');
5178 for (
i = 0, l = strlen(
ref->path) - 1; l >= 0; l--)
5179 if (
ref->path[l] ==
'/') {
5180 if (
i ==
ref->nlvl_to - 1)
5187 if (
i ==
ref->nlvl_to - 1 && src_path -
src <
sizeof(filename)) {
5188 memcpy(filename,
src, src_path -
src);
5189 filename[src_path -
src] = 0;
5191 for (
i = 1;
i <
ref->nlvl_from;
i++)
5192 av_strlcat(filename,
"../",
sizeof(filename));
5195 if (!
c->use_absolute_path) {
5200 "Reference with mismatching origin, %s not tried for security reasons, "
5201 "set demuxer option use_absolute_path to allow it anyway\n",
5206 if (strstr(
ref->path + l + 1,
"..") ||
5207 strstr(
ref->path + l + 1,
":") ||
5208 (
ref->nlvl_from > 1 && same_origin < 0) ||
5209 (filename[0] ==
'/' && src_path ==
src))
5213 if (strlen(filename) + 1 ==
sizeof(filename))
5218 }
else if (
c->use_absolute_path) {
5220 "this is a possible security issue\n");
5225 "Absolute path %s not tried for security reasons, "
5226 "set demuxer option use_absolute_path to allow absolute paths\n",
5252 for (
int j = 0; j <
c->fc->nb_stream_groups; j++)
5254 stg =
c->fc->stream_groups[j];
5262 out->codecpar->bit_rate = 0;
5315 if (!st)
return AVERROR(ENOMEM);
5318 if (!sc)
return AVERROR(ENOMEM);
5323 c->trak_index = st->
index;
5354 "MP4. disabling.\n");
5355 c->advanced_editlist = 0;
5356 c->advanced_editlist_autodisabled = 1;
5363 ret = mov_update_iamf_streams(
c, st);
5371 if (
c->enable_drefs) {
5374 "stream %d, error opening alias: path='%s', dir='%s', "
5375 "filename='%s', volume='%s', nlvl_from=%d, nlvl_to=%d\n",
5380 "Skipped opening external track: "
5381 "stream %d, alias: path='%s', dir='%s', "
5382 "filename='%s', volume='%s', nlvl_from=%d, nlvl_to=%d."
5383 "Set enable_drefs to allow this.\n",
5405 #if FF_API_R_FRAME_RATE
5417 #if CONFIG_H261_DECODER || CONFIG_H263_DECODER || CONFIG_MPEG4_DECODER
5419 #if CONFIG_H261_DECODER
5422 #if CONFIG_H263_DECODER
5425 #if CONFIG_MPEG4_DECODER
5437 int stts_constant = 1;
5462 c->itunes_metadata = 1;
5464 c->itunes_metadata = 0;
5479 if (
count >= UINT_MAX /
sizeof(*
c->meta_keys)) {
5481 "The 'keys' atom with the invalid key count: %"PRIu32
"\n",
count);
5485 c->meta_keys_count =
count + 1;
5486 c->meta_keys =
av_mallocz(
c->meta_keys_count *
sizeof(*
c->meta_keys));
5493 if (key_size < 8 || key_size > atom.
size) {
5495 "The key# %"PRIu32
" in meta has invalid size:"
5496 "%"PRIu32
"\n",
i, key_size);
5499 atom.
size -= key_size;
5506 if (!
c->meta_keys[
i])
5523 if (
c->fc->nb_streams < 1)
5525 st =
c->fc->streams[
c->fc->nb_streams-1];
5528 for (
i = 0;
i < 3;
i++) {
5539 if (len < 12 || len - 12 > end -
avio_tell(pb))
5543 if (
tag ==
MKTAG(
'm',
'e',
'a',
'n'))
5545 else if (
tag ==
MKTAG(
'n',
'a',
'm',
'e'))
5547 else if (
tag ==
MKTAG(
'd',
'a',
't',
'a') &&
len > 4) {
5571 if (strcmp(
key,
"iTunSMPB") == 0) {
5572 int priming, remainder,
samples;
5573 if(sscanf(
val,
"%*X %X %X %X", &priming, &remainder, &
samples) == 3){
5574 if(priming>0 && priming<16384)
5578 if (strcmp(
mean,
"com.apple.iTunes") == 0 &&
5579 strcmp(
key,
"DISCSUBTITLE") == 0) {
5584 if (strcmp(
key,
"cdec") != 0) {
5591 "Unhandled or malformed custom metadata of size %"PRId64
"\n", atom.
size);
5662 while (atom.
size > 8) {
5668 if (
tag ==
MKTAG(
'h',
'd',
'l',
'r')) {
5678 #define IS_MATRIX_IDENT(matrix) \
5679 ( (matrix)[0][0] == (1 << 16) && \
5680 (matrix)[1][1] == (1 << 16) && \
5681 (matrix)[2][2] == (1 << 30) && \
5682 !(matrix)[0][1] && !(matrix)[0][2] && \
5683 !(matrix)[1][0] && !(matrix)[1][2] && \
5684 !(matrix)[2][0] && !(matrix)[2][1])
5691 int display_matrix[3][3];
5692 int res_display_matrix[3][3] = { { 0 } };
5698 if (
c->fc->nb_streams < 1)
5700 st =
c->fc->streams[
c->fc->nb_streams-1];
5737 for (
i = 0;
i < 3;
i++) {
5749 for (
i = 0;
i < 3;
i++) {
5750 const int sh[3] = { 16, 16, 30 };
5751 for (j = 0; j < 3; j++) {
5752 for (e = 0; e < 3; e++) {
5753 res_display_matrix[
i][j] +=
5755 c->movie_display_matrix[e][j]) >> sh[e];
5767 for (
i = 0;
i < 3;
i++)
5768 for (j = 0; j < 3; j++)
5775 double disp_transform[2];
5777 for (
i = 0;
i < 2;
i++)
5781 if (disp_transform[0] > 1 && disp_transform[1] > 1 &&
5782 disp_transform[0] < (1<<24) && disp_transform[1] < (1<<24) &&
5783 fabs((disp_transform[0] / disp_transform[1]) - 1.0) > 0.01)
5785 disp_transform[0] / disp_transform[1],
5804 for (
i = 0;
i <
c->trex_count;
i++)
5805 if (
c->trex_data[
i].track_id == track_id) {
5806 trex = &
c->trex_data[
i];
5813 c->fragment.found_tfhd = 1;
5831 if (frag_stream_info) {
5843 num = atom.
size / 4;
5848 c->chapter_tracks = new_tracks;
5849 c->nb_chapter_tracks = num;
5854 c->nb_chapter_tracks =
i;
5864 if ((uint64_t)
c->trex_count+1 >= UINT_MAX /
sizeof(*
c->trex_data))
5867 sizeof(*
c->trex_data))) < 0) {
5874 trex = &
c->trex_data[
c->trex_count++];
5892 int64_t base_media_decode_time;
5894 for (
i = 0;
i <
c->fc->nb_streams;
i++) {
5895 sc =
c->fc->streams[
i]->priv_data;
5897 st =
c->fc->streams[
i];
5917 if (frag_stream_info)
5918 frag_stream_info->
tfdt_dts = base_media_decode_time;
5933 int data_offset = 0;
5934 unsigned entries, first_sample_flags = frag->
flags;
5937 int next_frag_index = -1, index_entry_pos;
5938 size_t requested_size;
5939 size_t old_allocated_size;
5948 for (
i = 0;
i <
c->fc->nb_streams;
i++) {
5949 sc =
c->fc->streams[
i]->priv_data;
5951 st =
c->fc->streams[
i];
5971 for (
i =
c->frag_index.current + 1; i < c->frag_index.nb_items;
i++) {
5973 if (frag_stream_info && frag_stream_info->
index_entry >= 0) {
5974 next_frag_index =
i;
5979 av_assert0(index_entry_pos <= sti->nb_index_entries);
5992 if (frag_stream_info) {
5999 ", using it for pts\n",
pts);
6004 ", using it for dts\n",
pts);
6008 int fallback_tfdt = !
c->use_tfdt && !has_sidx && has_tfdt;
6009 int fallback_sidx =
c->use_tfdt && !has_tfdt && has_sidx;
6011 if (fallback_sidx) {
6014 if (fallback_tfdt) {
6018 if (has_tfdt &&
c->use_tfdt || fallback_tfdt) {
6021 ", using it for dts\n", dts);
6022 }
else if (has_sidx && !
c->use_tfdt || fallback_sidx) {
6027 ", using it for dts\n", frag_stream_info->
sidx_pts);
6031 ", using it for dts\n", dts);
6037 ", using it for dts\n", dts);
6070 memset((uint8_t*)(sc->
tts_data) + old_allocated_size, 0,
6073 if (index_entry_pos < sti->nb_index_entries) {
6079 memmove(sc->
tts_data + index_entry_pos + entries,
6082 if (index_entry_pos < sc->current_sample) {
6094 if (frag_stream_info) {
6097 frag_stream_info->
index_base = index_entry_pos;
6100 if (index_entry_pos > 0)
6104 unsigned sample_size = frag->
size;
6105 int sample_flags =
i ? frag->
flags : first_sample_flags;
6106 unsigned sample_duration = frag->
duration;
6107 unsigned ctts_duration = 0;
6109 int index_entry_flags = 0;
6120 dts -= ctts_duration;
6125 "pts %"PRId64
" calculated dts %"PRId64
6126 " sc->dts_shift %d ctts.duration %d"
6127 " sc->time_offset %"PRId64
6128 " flags & MOV_TRUN_SAMPLE_CTS %d\n",
6144 if (prev_dts >= dts)
6158 av_log(
c->fc,
AV_LOG_TRACE,
"AVIndex stream %d, sample %d, offset %"PRIx64
", dts %"PRId64
", "
6159 "size %u, distance %d, keyframe %d\n", st->
index,
6162 if (
av_sat_add64(dts, sample_duration) != dts + (uint64_t)sample_duration)
6166 dts += sample_duration;
6170 if (sample_duration <= INT64_MAX - sc->duration_for_fps &&
6177 if (frag_stream_info)
6182 int gap = entries -
i;
6187 memmove(sc->
tts_data + index_entry_pos,
6188 sc->
tts_data + index_entry_pos + gap,
6190 (sc->
tts_count - (index_entry_pos + gap)));
6194 if (index_entry_pos < sc->current_sample) {
6204 if (index_entry_pos > 0)
6207 if (prev_dts < sti->index_entries[
i].timestamp)
6238 unsigned i, j, track_id, item_count;
6253 for (
i = 0;
i <
c->fc->nb_streams;
i++) {
6254 sc =
c->fc->streams[
i]->priv_data;
6255 if (sc->
id == track_id) {
6256 st =
c->fc->streams[
i];
6269 if (timescale.
den <= 0) {
6284 offset += (uint64_t)offadd;
6289 if (item_count == 0)
6292 for (
i = 0;
i < item_count;
i++) {
6297 if (
size & 0x80000000) {
6306 if (frag_stream_info)
6307 frag_stream_info->
sidx_pts = timestamp;
6322 is_complete =
offset == stream_size;
6326 if (!
c->have_read_mfra_size) {
6327 if ((
ret =
avio_seek(pb, stream_size - 4, SEEK_SET)) < 0)
6330 c->have_read_mfra_size = 1;
6334 if (
offset == stream_size -
c->mfra_size)
6341 for (
i = 0;
i <
c->frag_index.nb_items;
i++) {
6347 ref_st =
c->fc->streams[j];
6353 if (ref_st)
for (
i = 0;
i <
c->fc->nb_streams;
i++) {
6354 st =
c->fc->streams[
i];
6362 c->frag_index.complete = 1;
6383 if (atom.
type !=
MKTAG(
'm',
'd',
'a',
't')) {
6397 long cmov_len, moov_len;
6411 cmov_len = atom.
size - 6 * 4;
6423 goto free_and_return;
6426 if (uncompress (moov_data, (uLongf *) &moov_len, (
const Bytef *)cmov_data, cmov_len) != Z_OK)
6427 goto free_and_return;
6431 atom.
size = moov_len;
6450 if (
c->fc->nb_streams < 1 ||
c->ignore_editlist)
6452 sc =
c->fc->streams[
c->fc->nb_streams-1]->priv_data;
6459 elst_entry_size =
version == 1 ? 20 : 12;
6460 if (atom.
size != edit_count * elst_entry_size) {
6462 av_log(
c->fc,
AV_LOG_ERROR,
"Invalid edit list entry_count: %d for elst atom of size: %"PRId64
" bytes.\n",
6463 edit_count, atom.
size + 8);
6466 edit_count = atom.
size / elst_entry_size;
6467 if (edit_count * elst_entry_size != atom.
size) {
6501 if (e->
time < 0 && e->
time != -1 &&
6503 av_log(
c->fc,
AV_LOG_ERROR,
"Track %d, edit %d: Invalid edit list media time=%"PRId64
"\n",
6504 c->fc->nb_streams-1,
i, e->
time);
6523 if (
c->fc->nb_streams < 1)
6525 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6527 if (atom.
size %
sizeof(uint32_t))
6534 int nb_timecode_track = atom.
size >> 2;
6535 for (
int i = 0;
i < nb_timecode_track;
i++) {
6551 if (
c->fc->nb_streams < 1)
6553 st =
c->fc->streams[
c->fc->nb_streams - 1];
6555 if (atom.
size < 5) {
6595 if (
c->fc->nb_streams < 1)
6598 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6600 if (atom.
size < 5) {
6621 for (
i = 0;
i < 3;
i++) {
6640 const int mapping[3] = {1, 2, 0};
6641 const int chroma_den = 50000;
6642 const int luma_den = 10000;
6645 if (
c->fc->nb_streams < 1)
6648 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6650 if (atom.
size < 24) {
6664 for (
i = 0;
i < 3;
i++) {
6665 const int j = mapping[
i];
6686 if (
c->fc->nb_streams < 1)
6689 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6691 if (atom.
size < 5) {
6722 if (
c->fc->nb_streams < 1)
6725 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6727 if (atom.
size < 4) {
6750 const int illuminance_den = 10000;
6751 const int ambient_den = 50000;
6752 if (
c->fc->nb_streams < 1)
6754 sc =
c->fc->streams[
c->fc->nb_streams - 1]->priv_data;
6755 if (atom.
size < 6) {
6779 if (
c->fc->nb_streams < 1)
6782 st =
c->fc->streams[
c->fc->nb_streams - 1];
6785 if (atom.
size < 5) {
6828 if (
c->fc->nb_streams < 1)
6831 st =
c->fc->streams[
c->fc->nb_streams - 1];
6834 remaining = atom.
size;
6835 while (remaining > 0) {
6837 if (size < 8 || size > remaining ) {
6844 case MKTAG(
'p',
'k',
'i',
'n'): {
6854 case MKTAG(
's',
'i',
'd',
'e'):
6857 case MKTAG(
'o',
'v',
'e',
'r'):
6881 if (remaining != 0) {
6906 uint32_t l = 0, t = 0,
r = 0,
b = 0;
6907 uint32_t
tag, padding = 0;
6910 if (
c->fc->nb_streams < 1)
6913 st =
c->fc->streams[
c->fc->nb_streams - 1];
6916 if (atom.
size < 8) {
6922 if (size <= 12 || size > atom.
size)
6926 if (
tag !=
MKTAG(
's',
'v',
'h',
'd')) {
6944 if (
tag !=
MKTAG(
'p',
'r',
'o',
'j')) {
6954 if (
tag !=
MKTAG(
'p',
'r',
'h',
'd')) {
6984 case MKTAG(
'c',
'b',
'm',
'p'):
6988 "Unsupported cubemap layout %d\n",
layout);
6994 case MKTAG(
'e',
'q',
'u',
'i'):
7000 if (
b >= UINT_MAX - t ||
r >= UINT_MAX - l) {
7002 "Invalid bounding rectangle coordinates "
7003 "%"PRIu32
",%"PRIu32
",%"PRIu32
",%"PRIu32
"\n", l, t,
r,
b);
7007 if (l || t ||
r ||
b)
7045 if (
c->fc->nb_streams < 1)
7048 st =
c->fc->streams[
c->fc->nb_streams - 1];
7051 if (atom.
size < 16) {
7060 }
else if (
size > 16) {
7065 if (
tag !=
MKTAG(
'p',
'r',
'j',
'i')) {
7081 case MKTAG(
'r',
'e',
'c',
't'):
7084 case MKTAG(
'e',
'q',
'u',
'i'):
7087 case MKTAG(
'h',
'e',
'q',
'u'):
7090 case MKTAG(
'f',
'i',
's',
'h'):
7093 case MKTAG(
'p',
'r',
'i',
'm'):
7116 uint32_t
tag, baseline = 0;
7120 AVRational horizontal_disparity_adjustment = { 0, 1 };
7122 if (
c->fc->nb_streams < 1)
7125 st =
c->fc->streams[
c->fc->nb_streams - 1];
7128 remaining = atom.
size;
7129 while (remaining > 0) {
7131 if (size < 8 || size > remaining ) {
7138 case MKTAG(
's',
't',
'r',
'i'): {
7139 int has_right, has_left;
7159 has_right =
tmp & 2;
7162 if (has_left && has_right)
7168 if (has_left || has_right)
7173 case MKTAG(
'h',
'e',
'r',
'o'): {
7194 case MKTAG(
'c',
'a',
'm',
's'): {
7203 if (subsize != 16) {
7209 if (subtag !=
MKTAG(
'b',
'l',
'i',
'n')) {
7222 case MKTAG(
'c',
'm',
'f',
'y'): {
7232 if (subsize != 16) {
7238 if (subtag !=
MKTAG(
'd',
'a',
'd',
'j')) {
7249 horizontal_disparity_adjustment.
num = (int) adjustment;
7250 horizontal_disparity_adjustment.
den = 10000;
7263 if (remaining != 0) {
7293 if (
c->fc->nb_streams < 1)
7296 if (atom.
size < 8) {
7301 remaining = atom.
size;
7302 while (remaining > 0) {
7304 if (size < 8 || size > remaining ) {
7311 case MKTAG(
'p',
'r',
'o',
'j'): {
7318 case MKTAG(
'e',
'y',
'e',
's'): {
7325 case MKTAG(
'p',
'a',
'c',
'k'): {
7341 if (remaining != 0) {
7354 if (
c->fc->nb_streams < 1)
7357 st =
c->fc->streams[
c->fc->nb_streams - 1];
7360 if (atom.
size != 4) {
7447 static const AVUUID uuid_isml_manifest = {
7448 0xa5, 0xd4, 0x0b, 0x30, 0xe8, 0x14, 0x11, 0xdd,
7449 0xba, 0x2f, 0x08, 0x00, 0x20, 0x0c, 0x9a, 0x66
7451 static const AVUUID uuid_xmp = {
7452 0xbe, 0x7a, 0xcf, 0xcb, 0x97, 0xa9, 0x42, 0xe8,
7453 0x9c, 0x71, 0x99, 0x94, 0x91, 0xe3, 0xaf, 0xac
7455 static const AVUUID uuid_spherical = {
7456 0xff, 0xcc, 0x82, 0x63, 0xf8, 0x55, 0x4a, 0x93,
7457 0x88, 0x14, 0x58, 0x7a, 0x02, 0x52, 0x1f, 0xdd,
7463 if (
c->fc->nb_streams < 1)
7465 st =
c->fc->streams[
c->fc->nb_streams - 1];
7493 while ((ptr =
av_stristr(ptr,
"systemBitrate=\""))) {
7494 ptr +=
sizeof(
"systemBitrate=\"") - 1;
7495 c->bitrates_count++;
7496 c->bitrates =
av_realloc_f(
c->bitrates,
c->bitrates_count,
sizeof(*
c->bitrates));
7498 c->bitrates_count = 0;
7503 ret = strtol(ptr, &endptr, 10);
7504 if (
ret < 0 || errno || *endptr !=
'"') {
7505 c->bitrates[
c->bitrates_count - 1] = 0;
7507 c->bitrates[
c->bitrates_count - 1] =
ret;
7515 if (
c->export_xmp) {
7549 uint8_t content[16];
7560 && !memcmp(content,
"Anevia\x1A\x1A", 8)
7575 if (
c->fc->nb_streams < 1)
7577 st =
c->fc->streams[
c->fc->nb_streams - 1];
7582 case MKTAG(
'e',
'n',
'c',
'v'):
7583 case MKTAG(
'e',
'n',
'c',
'a'):
7588 "ignoring 'frma' atom of '%.4s', stream has codec id %d\n",
7600 "ignoring 'frma' atom of '%.4s', stream format is '%.4s'\n",
7622 if (frag_stream_info) {
7623 for (
i = 0;
i <
c->fc->nb_streams;
i++) {
7624 *sc =
c->fc->streams[
i]->priv_data;
7625 if ((*sc)->id == frag_stream_info->
id) {
7626 st =
c->fc->streams[
i];
7630 if (
i ==
c->fc->nb_streams)
7636 if (!(*sc)->cenc.default_encrypted_sample)
7647 if (
c->fc->nb_streams < 1)
7649 st =
c->fc->streams[
c->fc->nb_streams - 1];
7652 if (!(*sc)->cenc.encryption_index) {
7654 if (!(*sc)->cenc.default_encrypted_sample)
7657 if (!(*sc)->cenc.encryption_index)
7661 *encryption_index = (*sc)->cenc.encryption_index;
7669 unsigned int subsample_count;
7693 if (use_subsamples) {
7695 av_free((*sample)->subsamples);
7696 (*sample)->subsamples =
av_calloc(subsample_count,
sizeof(*subsamples));
7697 if (!(*sample)->subsamples) {
7704 (*sample)->subsamples[
i].bytes_of_clear_data =
avio_rb16(pb);
7705 (*sample)->subsamples[
i].bytes_of_protected_data =
avio_rb32(pb);
7714 (*sample)->subsample_count = subsample_count;
7725 int use_subsamples,
ret;
7726 unsigned int sample_count,
i, alloc_size = 0;
7742 if (sample_count >= INT_MAX /
sizeof(*encrypted_samples))
7745 for (
i = 0;
i < sample_count;
i++) {
7746 unsigned int min_samples =
FFMIN(
FFMAX(
i + 1, 1024 * 1024), sample_count);
7748 min_samples *
sizeof(*encrypted_samples));
7749 if (encrypted_samples) {
7780 size_t sample_count, sample_info_size,
i;
7782 unsigned int alloc_size = 0;
7791 if (sample_count >= INT_MAX /
sizeof(*encrypted_samples))
7797 av_log(
c->fc,
AV_LOG_INFO,
"Failed to seek for auxiliary info, will only parse senc atoms for encryption info\n");
7802 unsigned int min_samples =
FFMIN(
FFMAX(
i + 1, 1024 * 1024), sample_count);
7804 min_samples *
sizeof(*encrypted_samples));
7805 if (!encrypted_samples) {
7830 for (;
i > 0;
i--) {
7843 unsigned int sample_count, aux_info_type, aux_info_param;
7869 if (aux_info_param != 0) {
7875 if ((aux_info_type ==
MKBETAG(
'c',
'e',
'n',
'c') ||
7876 aux_info_type ==
MKBETAG(
'c',
'e',
'n',
's') ||
7877 aux_info_type ==
MKBETAG(
'c',
'b',
'c',
'1') ||
7878 aux_info_type ==
MKBETAG(
'c',
'b',
'c',
's')) &&
7879 aux_info_param == 0) {
7895 if (sample_count == 0)
7903 if (
ret != sample_count) {
7924 uint64_t *auxiliary_offsets;
7928 unsigned int version, entry_count, aux_info_type, aux_info_param;
7929 unsigned int alloc_size = 0;
7955 if (aux_info_param != 0) {
7961 if ((aux_info_type ==
MKBETAG(
'c',
'e',
'n',
'c') ||
7962 aux_info_type ==
MKBETAG(
'c',
'e',
'n',
's') ||
7963 aux_info_type ==
MKBETAG(
'c',
'b',
'c',
'1') ||
7964 aux_info_type ==
MKBETAG(
'c',
'b',
'c',
's')) &&
7965 aux_info_param == 0) {
7978 if (entry_count >= INT_MAX /
sizeof(*auxiliary_offsets))
7982 unsigned int min_offsets =
FFMIN(
FFMAX(
i + 1, 1024), entry_count);
7985 min_offsets *
sizeof(*auxiliary_offsets));
7986 if (!auxiliary_offsets) {
7997 if (
c->frag_index.current >= 0) {
8023 uint8_t *side_data, *extra_data;
8024 size_t side_data_size;
8026 unsigned int version, kid_count, extra_data_size, alloc_size = 0;
8028 if (
c->fc->nb_streams < 1)
8030 st =
c->fc->streams[
c->fc->nb_streams-1];
8047 if (kid_count >= INT_MAX /
sizeof(*key_ids)) {
8052 for (
unsigned int i = 0;
i < kid_count && !pb->
eof_reached;
i++) {
8053 unsigned int min_kid_count =
FFMIN(
FFMAX(
i + 1, 1024), kid_count);
8055 min_kid_count *
sizeof(*key_ids));
8060 info->key_ids = key_ids;
8063 if (!
info->key_ids[
i]) {
8067 info->num_key_ids =
i + 1;
8083 extra_data =
av_malloc(extra_data_size);
8089 if (
ret != extra_data_size) {
8098 info->data = extra_data;
8099 info->data_size = extra_data_size;
8104 if (old_side_data) {
8106 if (old_init_info) {
8114 info = old_init_info;
8130 side_data, side_data_size, 0))
8143 if (
c->fc->nb_streams < 1)
8145 st =
c->fc->streams[
c->fc->nb_streams-1];
8149 av_log(
c->fc,
AV_LOG_ERROR,
"schm boxes are only supported in first sample descriptor\n");
8173 unsigned int version, pattern, is_protected, iv_size;
8175 if (
c->fc->nb_streams < 1)
8177 st =
c->fc->streams[
c->fc->nb_streams-1];
8226 if (iv_size != 8 && iv_size != 16) {
8246 if (
c->fc->nb_streams < 1)
8248 st =
c->fc->streams[
c->fc->nb_streams-1];
8250 if ((uint64_t)atom.
size > (1<<30) || atom.
size < 42)
8259 if (
avio_read(pb, buf,
sizeof(buf)) !=
sizeof(buf)) {
8282 char kid_hex[16*2+1];
8284 if (
c->decryption_default_key &&
c->decryption_default_key_len !=
len) {
8285 av_log(
c->fc,
AV_LOG_ERROR,
"invalid default decryption key length: got %d, expected %d\n",
c->decryption_default_key_len,
len);
8289 if (!
c->decryption_keys) {
8291 memcpy(
out,
c->decryption_default_key,
len);
8295 if (
sample->key_id_size != 16) {
8302 if (!key_entry_hex) {
8303 if (!
c->decryption_default_key) {
8307 memcpy(
out,
c->decryption_default_key,
len);
8310 if (strlen(key_entry_hex->
value) !=
len*2) {
8320 int bytes_of_protected_data;
8343 if (!
sample->subsample_count) {
8349 for (
i = 0;
i <
sample->subsample_count;
i++) {
8357 size -=
sample->subsamples[
i].bytes_of_clear_data;
8361 bytes_of_protected_data =
sample->subsamples[
i].bytes_of_protected_data;
8364 input += bytes_of_protected_data;
8365 size -= bytes_of_protected_data;
8379 int num_of_encrypted_blocks;
8381 uint8_t decryption_key[16];
8401 memcpy(iv,
sample->iv, 16);
8404 if (!
sample->subsample_count) {
8410 for (
i = 0;
i <
sample->subsample_count;
i++) {
8416 if (
sample->subsamples[
i].bytes_of_protected_data % 16) {
8423 size -=
sample->subsamples[
i].bytes_of_clear_data;
8426 num_of_encrypted_blocks =
sample->subsamples[
i].bytes_of_protected_data/16;
8427 if (num_of_encrypted_blocks > 0) {
8430 input +=
sample->subsamples[
i].bytes_of_protected_data;
8431 size -=
sample->subsamples[
i].bytes_of_protected_data;
8444 int i,
ret, rem_bytes;
8469 if (!
sample->subsample_count) {
8473 }
else if (!
sample->crypt_byte_block && !
sample->skip_byte_block) {
8478 for (
i = 0;
i <
sample->subsample_count;
i++) {
8486 size -=
sample->subsamples[
i].bytes_of_clear_data;
8490 rem_bytes =
sample->subsamples[
i].bytes_of_protected_data;
8491 while (rem_bytes > 0) {
8492 if (rem_bytes < 16*sample->crypt_byte_block) {
8497 rem_bytes -= 16*
sample->crypt_byte_block;
8499 rem_bytes -=
FFMIN(16*
sample->skip_byte_block, rem_bytes);
8501 input +=
sample->subsamples[
i].bytes_of_protected_data;
8502 size -=
sample->subsamples[
i].bytes_of_protected_data;
8515 int i,
ret, rem_bytes;
8518 uint8_t decryption_key[16];
8539 if (!
sample->subsample_count) {
8541 memcpy(iv,
sample->iv, 16);
8544 }
else if (!
sample->crypt_byte_block && !
sample->skip_byte_block) {
8549 for (
i = 0;
i <
sample->subsample_count;
i++) {
8557 size -=
sample->subsamples[
i].bytes_of_clear_data;
8560 memcpy(iv,
sample->iv, 16);
8562 rem_bytes =
sample->subsamples[
i].bytes_of_protected_data;
8563 while (rem_bytes > 0) {
8564 if (rem_bytes < 16*sample->crypt_byte_block) {
8569 rem_bytes -= 16*
sample->crypt_byte_block;
8571 rem_bytes -=
FFMIN(16*
sample->skip_byte_block, rem_bytes);
8573 input +=
sample->subsamples[
i].bytes_of_protected_data;
8574 size -=
sample->subsamples[
i].bytes_of_protected_data;
8609 if (
current >= 0 && current < frag_index->nb_items) {
8631 int encrypted_index,
ret;
8634 encrypted_index = current_index;
8635 encryption_index =
NULL;
8636 if (frag_stream_info) {
8638 if (frag_stream_info->
stsd_id == 1) {
8640 encrypted_index = current_index - frag_stream_info->
index_base;
8650 if (encryption_index) {
8662 encrypted_sample =
NULL;
8666 }
else if (encrypted_index >= 0 && encrypted_index < encryption_index->nb_encrypted_samples) {
8669 if (!encrypted_sample) {
8674 if (!encrypted_sample) {
8704 if (
c->fc->nb_streams < 1)
8706 st =
c->fc->streams[
c->fc->nb_streams-1];
8752 unsigned format_info;
8753 int channel_assignment, channel_assignment1, channel_assignment2;
8757 if (
c->fc->nb_streams < 1)
8759 st =
c->fc->streams[
c->fc->nb_streams-1];
8766 ratebits = (format_info >> 28) & 0xF;
8767 channel_assignment1 = (format_info >> 15) & 0x1F;
8768 channel_assignment2 = format_info & 0x1FFF;
8769 if (channel_assignment2)
8770 channel_assignment = channel_assignment2;
8772 channel_assignment = channel_assignment1;
8791 if (
c->fc->nb_streams < 1)
8793 st =
c->fc->streams[
c->fc->nb_streams-1];
8810 if (
c->fc->nb_streams < 1)
8812 st =
c->fc->streams[
c->fc->nb_streams - 1];
8835 int ret, old_size, num_arrays;
8837 if (
c->fc->nb_streams < 1)
8839 st =
c->fc->streams[
c->fc->nb_streams-1];
8862 num_arrays = buf[5];
8886 AVBPrint scheme_buf, value_buf;
8887 int64_t scheme_str_len = 0, value_str_len = 0;
8895 if (
c->fc->nb_streams < 1)
8897 st =
c->fc->streams[
c->fc->nb_streams-1];
8905 "Unsupported 'kind' box with version %d, flags: %x",
8915 ret = scheme_str_len;
8919 if (scheme_str_len + 1 >=
size) {
8927 size -= scheme_str_len + 1;
8931 ret = value_str_len;
8935 if (value_str_len ==
size) {
8942 "%s stream %d KindBox(scheme: %s, value: %s)\n",
8945 scheme_buf.str, value_buf.str);
8952 for (
int j = 0;
map.value_maps[j].disposition; j++) {
8976 int ambisonic_order, channel_order, normalization, channel_count;
8977 int ambi_channels, non_diegetic_channels;
8979 if (
c->fc->nb_streams < 1)
8982 st =
c->fc->streams[
c->fc->nb_streams - 1];
8984 if (atom.
size < 16) {
8998 "Unsupported ambisonic type %d\n",
type & 0x7f);
9001 non_diegetic_channels = (
type >> 7) * 2;
9006 if (channel_order) {
9008 "Unsupported channel_order %d\n", channel_order);
9013 if (normalization) {
9015 "Unsupported normalization %d\n", normalization);
9020 if (ambisonic_order < 0 || ambisonic_order > 31 ||
9021 channel_count != ((ambisonic_order + 1LL) * (ambisonic_order + 1LL) +
9022 non_diegetic_channels)) {
9024 "Invalid number of channels (%d / %d)\n",
9025 channel_count, ambisonic_order);
9028 ambi_channels = channel_count - non_diegetic_channels;
9034 for (
i = 0;
i < channel_count;
i++) {
9037 if (
channel >= channel_count) {
9066 if (
c->fc->nb_streams < 1)
9069 st =
c->fc->streams[
c->fc->nb_streams - 1];
9071 if (atom.
size < 5) {
9097 else if (
size == 8) {
9123 int version, offset_size, length_size, base_offset_size, index_size;
9124 int item_count, extent_count;
9125 int64_t base_offset, extent_offset, extent_length;
9128 if (
c->found_iloc) {
9137 offset_size = (
value >> 4) & 0xF;
9138 length_size =
value & 0xF;
9140 base_offset_size = (
value >> 4) & 0xF;
9151 c->heif_item = heif_item;
9152 if (item_count >
c->nb_heif_item)
9153 memset(&
c->heif_item[
c->nb_heif_item], 0,
9154 sizeof(*
c->heif_item) * (item_count -
c->nb_heif_item));
9155 c->nb_heif_item =
FFMAX(
c->nb_heif_item, item_count);
9158 for (
int i = 0;
i < item_count;
i++) {
9166 if (offset_type > 1) {
9172 if (
rb_size(pb, &base_offset, base_offset_size) < 0)
9175 if (extent_count > 1) {
9181 if (
rb_size(pb, &extent_offset, offset_size) < 0 ||
9182 rb_size(pb, &extent_length, length_size) < 0 ||
9183 base_offset > INT64_MAX - extent_offset)
9186 for (j = 0; j <
c->nb_heif_item; j++) {
9187 item =
c->heif_item[j];
9189 item =
c->heif_item[j] =
av_mallocz(
sizeof(*item));
9190 else if (item->
item_id != item_id)
9196 if (j ==
c->nb_heif_item)
9201 if (offset_type == 1)
9206 "extent_offset %"PRId64
", extent_length %"PRId64
"\n",
9256 for (
i = 0;
i <
c->nb_heif_item;
i++) {
9257 item =
c->heif_item[
i];
9260 else if (item->
item_id != item_id)
9268 if (
i ==
c->nb_heif_item) {
9276 item->
type = item_type;
9278 switch (item_type) {
9279 case MKTAG(
'a',
'v',
'0',
'1'):
9280 case MKTAG(
'j',
'p',
'e',
'g'):
9281 case MKTAG(
'h',
'v',
'c',
'1'):
9297 if (
c->found_iinf) {
9309 c->heif_item = heif_item;
9310 if (entry_count >
c->nb_heif_item)
9311 memset(&
c->heif_item[
c->nb_heif_item], 0,
9312 sizeof(*
c->heif_item) * (entry_count -
c->nb_heif_item));
9313 c->nb_heif_item =
FFMAX(
c->nb_heif_item, entry_count);
9315 for (
i = 0;
i < entry_count;
i++) {
9331 c->found_iinf = got_stream;
9334 for (;
i >= 0;
i--) {
9353 for (
int i = 0;
i <
c->nb_heif_grid;
i++) {
9354 if (
c->heif_grid[
i].item->item_id == from_item_id) {
9356 "referencing the same Derived Image item\n");
9360 for (
int i = 0;
i <
c->nb_heif_item;
i++) {
9361 if (!
c->heif_item[
i] ||
c->heif_item[
i]->item_id != from_item_id)
9363 item =
c->heif_item[
i];
9365 switch (item->
type) {
9366 case MKTAG(
'g',
'r',
'i',
'd'):
9367 case MKTAG(
'i',
'o',
'v',
'l'):
9384 "Derived image item references no input images\n");
9389 sizeof(*
c->heif_grid));
9392 c->heif_grid = grid;
9393 grid = &grid[
c->nb_heif_grid];
9403 for (
i = 0;
i < entries;
i++) {
9417 from_item_id, entries);
9443 for (
int i = 0;
i < entries;
i++) {
9483 if (
size < 14 || next < 0 || next > INT64_MAX -
size)
9489 case MKTAG(
'd',
'i',
'm',
'g'):
9494 case MKTAG(
'c',
'd',
's',
'c'):
9495 case MKTAG(
't',
'h',
'm',
'b'):
9547 c->cur_item_id, angle);
9567 c->cur_item_id, axis);
9572 item->
vflip = !axis;
9580 typedef struct MOVAtoms {
9586 MOVAtoms *atoms =
NULL;
9596 if (
a.size < 8 ||
a.type !=
MKTAG(
'i',
'p',
'c',
'o'))
9600 while (
a.size >= 8) {
9609 if (
ref->size >
a.size ||
ref->size < 8)
9623 a.size -=
ref->size;
9634 if (
a.size < 8 ||
a.type !=
MKTAG(
'i',
'p',
'm',
'a')) {
9643 for (
int i = 0;
i < count;
i++) {
9645 int assoc_count =
avio_r8(pb);
9652 for (
int j = 0; j < assoc_count; j++) {
9668 c->cur_item_id = item_id;
9671 (
MOVAtom) { .size = ref->size,
9672 .type = MKTAG(
'i',
'p',
'c',
'o') });
9681 c->cur_item_id = -1;
9682 for (
int i = 0;
i < nb_atoms;
i++)
9815 {
MKTAG(
'i',
'a',
'c',
'b'), mov_read_iacb },
9827 if (
c->atom_depth > 10) {
9834 atom.
size = INT64_MAX;
9835 while (total_size <= atom.
size - 8) {
9841 if (((
a.type ==
MKTAG(
'f',
'r',
'e',
'e') &&
c->moov_retry) ||
9842 a.type ==
MKTAG(
'h',
'o',
'o',
'v')) &&
9854 a.type =
MKTAG(
'm',
'o',
'o',
'v');
9857 if (atom.
type !=
MKTAG(
'r',
'o',
'o',
't') &&
9859 if (
a.type ==
MKTAG(
't',
'r',
'a',
'k') ||
9860 a.type ==
MKTAG(
'm',
'd',
'a',
't')) {
9868 if (
a.size == 1 && total_size + 8 <= atom.
size) {
9875 a.size = atom.
size - total_size + 8;
9897 if (!
parse &&
c->found_hdlr_mdta &&
9899 a.type ==
MKTAG(
'k',
'e',
'y',
's') &&
9900 c->meta_keys_count == 0) {
9914 if (
c->found_moov &&
c->found_mdat &&
a.size <= INT64_MAX - start_pos &&
9918 c->next_root_atom = start_pos +
a.size;
9925 else if (
left < 0) {
9927 "overread end of atom '%s' by %"PRId64
" bytes\n",
9933 total_size +=
a.size;
9936 if (total_size < atom.
size && atom.
size < 0x7ffff)
9948 int moov_offset = -1;
9956 if ((
offset + 8ULL) > (
unsigned int)
p->buf_size)
9959 if (
size == 1 &&
offset + 16 <= (
unsigned int)
p->buf_size) {
9962 }
else if (
size == 0) {
9965 if (
size < minsize) {
9972 case MKTAG(
'm',
'o',
'o',
'v'):
9973 moov_offset =
offset + 4;
9975 case MKTAG(
'm',
'd',
'a',
't'):
9976 case MKTAG(
'p',
'n',
'o',
't'):
9977 case MKTAG(
'u',
'd',
't',
'a'):
9978 case MKTAG(
'f',
't',
'y',
'p'):
9979 if (
tag ==
MKTAG(
'f',
't',
'y',
'p') &&
9984 score =
FFMAX(score, 5);
9990 case MKTAG(
'e',
'd',
'i',
'w'):
9991 case MKTAG(
'w',
'i',
'd',
'e'):
9992 case MKTAG(
'f',
'r',
'e',
'e'):
9993 case MKTAG(
'j',
'u',
'n',
'k'):
9994 case MKTAG(
'p',
'i',
'c',
't'):
9997 case MKTAG(0x82,0x82,0x7f,0x7d):
10000 case MKTAG(
's',
'k',
'i',
'p'):
10001 case MKTAG(
'u',
'u',
'i',
'd'):
10002 case MKTAG(
'p',
'r',
'f',
'l'):
10016 while (
offset < (
p->buf_size - 16)) {
10050 for (
i = 0;
i <
s->nb_streams;
i++) {
10052 if (sc->
id == chapter_track) {
10053 st =
s->streams[
i];
10088 int len, title_len;
10090 if (end < sample->timestamp) {
10104 title_len = 2*
len + 1;
10117 else if (ch == 0xfffe)
10121 if (
len == 1 ||
len == 2)
10157 int hh, mm,
ss, ff, drop;
10170 hh, mm,
ss, drop ?
';' :
':', ff);
10186 int rounded_tc_rate;
10191 if (!tc_rate.
num || !tc_rate.
den || !tmcd_nb_frames)
10210 rounded_tc_rate = (tc_rate.
num + tc_rate.
den / 2LL) / tc_rate.
den;
10213 if (tmcd_nb_frames == tc_rate.
num / tc_rate.
den &&
10215 tmcd_nb_frames = rounded_tc_rate;
10227 for (
i = 0;
i < (*index)->nb_encrypted_samples;
i++) {
10230 av_freep(&(*index)->encrypted_samples);
10231 av_freep(&(*index)->auxiliary_info_sizes);
10232 av_freep(&(*index)->auxiliary_offsets);
10306 for (
i = 0;
i <
s->nb_streams;
i++) {
10360 for (
i = 0;
i <
s->nb_streams;
i++) {
10378 for (
i = 0;
i <
s->nb_streams;
i++) {
10397 unsigned track_id, item_count;
10409 for (
i = 0;
i < item_count;
i++) {
10431 if (frag_stream_info &&
10435 for (j = 0; j < ((fieldlength >> 4) & 3) + 1; j++)
10437 for (j = 0; j < ((fieldlength >> 2) & 3) + 1; j++)
10439 for (j = 0; j < ((fieldlength >> 0) & 3) + 1; j++)
10453 if ((seek_ret =
avio_seek(
f, stream_size - 4, SEEK_SET)) < 0) {
10458 c->have_read_mfra_size = 1;
10459 if (!
c->mfra_size ||
c->mfra_size > stream_size) {
10482 c->frag_index.complete = 1;
10484 seek_ret =
avio_seek(
f, original_pos, SEEK_SET);
10485 if (seek_ret < 0) {
10487 "failed to seek back after looking for mfra\n");
10512 nb_coded_side_data,
10514 9 *
sizeof(*
matrix), 0);
10533 int64_t coded_width = 0, coded_height = 0;
10545 if (!
c->idat_offset) {
10566 av_log(
c->fc,
AV_LOG_TRACE,
"grid: grid_rows %d grid_cols %d output_width %d output_height %d\n",
10582 if (coded_width > INT_MAX || coded_height > INT_MAX)
10592 while (y < tile_grid->coded_height) {
10595 while (x < tile_grid->coded_width) {
10628 uint16_t canvas_fill_value[4];
10637 if (!
c->idat_offset) {
10652 for (
int i = 0;
i < 4;
i++)
10655 canvas_fill_value[0], canvas_fill_value[1],
10656 canvas_fill_value[2], canvas_fill_value[3]);
10657 for (
int i = 0;
i < 4;
i++)
10681 "horizontal_offset[%d] %d, vertical_offset[%d] %d\n",
10708 if (
ref->is_idat_relative) {
10709 if (!
c->idat_offset) {
10720 if (
offset > INT64_MAX -
ref->extent_offset) {
10727 if (err !=
ref->extent_length) {
10792 for (
int j = 0; j < grid->
nb_tiles; j++) {
10800 if (!item || item->
item_id != tile_id)
10805 "reference a stream\n",
10849 case MKTAG(
'g',
'r',
'i',
'd'):
10852 case MKTAG(
'i',
'o',
'v',
'l'):
10865 switch(
ref->type) {
10866 case MKTAG(
'E',
'x',
'i',
'f'):
10950 switch(
ref->type) {
10951 case MKTAG(
'E',
'x',
'i',
'f'):
10985 for (
int i = 0;
i <
s->nb_streams;
i++) {
11000 for (
int j = 0; j <
s->nb_streams; j++) {
11008 for (
int k = 0; k <
tag->nb_id; k++) {
11009 if (
tag->id[k] != st->
id)
11038 uint32_t *tref_id,
int nb_tref_id,
int first_index)
11043 for (
int i = first_index;
i <
s->nb_streams;
i++)
11044 for (
int j = 0; j < nb_tref_id; j++)
11045 if (
s->streams[
i]->index != st->
index &&
11046 s->streams[
i]->id == tref_id[j])
11047 return s->streams[
i];
11057 if (
s->nb_streams <= 1)
11060 for (
int i = 0;
i <
s->nb_streams;
i++) {
11085 j = st_base->
index + 1;
11089 av_log(
s, loglevel,
"Failed to find base stream for LCEVC stream\n");
11110 if (
s->nb_streams <= 1)
11119 for (
int i = 0;
i <
s->nb_streams;
i++) {
11151 av_log(
s, loglevel,
"Failed to find base layer for Dolby Vision EL stream\n");
11181 int highest_id = 0, lowest_iamf_id = INT_MAX;
11183 for (
int i = 0;
i <
s->nb_streams;
i++) {
11187 highest_id =
FFMAX(highest_id, st->
id);
11190 for (
int i = 0;
i <
s->nb_stream_groups;
i++) {
11196 lowest_iamf_id =
FFMIN(lowest_iamf_id, st->
id);
11200 if (highest_id < lowest_iamf_id)
11203 highest_id += !lowest_iamf_id;
11204 for (
int i = 0; highest_id > 1 &&
i <
s->nb_stream_groups;
i++) {
11211 st->
id += highest_id;
11233 atom.
size = INT64_MAX;
11264 for (
i = 0;
i <
s->nb_streams;
i++)
11265 if (
s->streams[
i]->codecpar->codec_tag ==
AV_RL32(
"tmcd")) {
11267 }
else if (
s->streams[
i]->codecpar->codec_tag ==
AV_RL32(
"rtmd")) {
11287 for (
i = 0;
i <
s->nb_streams;
i++) {
11348 for (
i = 0;
i <
s->nb_streams;
i++) {
11367 s->streams[
i]->codecpar->bit_rate = mov->
bitrates[
i];
11373 for (
i = 0;
i <
s->nb_streams;
i++) {
11450 int64_t best_dts = INT64_MAX;
11454 for (
i = 0;
i <
s->nb_streams;
i++) {
11461 uint64_t dtsdiff = best_dts > dts ? best_dts - (uint64_t)dts : ((uint64_t)dts - best_dts);
11463 if (!
sample || (no_interleave && current_sample->
pos <
sample->pos) ||
11466 ((dtsdiff <= AV_TIME_BASE && current_sample->pos < sample->
pos) ||
11467 (dtsdiff >
AV_TIME_BASE && dts < best_dts && mov->interleaved_read)))))) {
11468 sample = current_sample;
11489 if (
index >= 0 && index < mov->frag_index.nb_items)
11491 if (target >= 0 &&
avio_seek(
s->pb, target, SEEK_SET) != target) {
11499 if (
index >= 0 && index < mov->frag_index.nb_items &&
11523 uint8_t *side, *extradata;
11524 int extradata_size;
11538 memcpy(side, extradata, extradata_size);
11548 const uint32_t cdat =
AV_RB32(
"cdat");
11557 if ((src_size - 8) / 2 >= INT_MAX / 3)
11565 while (src_size >= 10) {
11566 const uint32_t atom_size =
avio_rb32(pb);
11567 const uint32_t atom_type =
avio_rb32(pb);
11568 const uint32_t data_size = atom_size - 8;
11569 const uint8_t cc_field =
11570 atom_type == cdat ? 1 :
11571 atom_type ==
cdt2 ? 2 :
11578 if (data_size < 2 || data_size > src_size) {
11584 if (data_size % 2 != 0) {
11592 src_size -= data_size;
11596 for (uint32_t
i = 0;
i < data_size;
i += 2) {
11631 if (next_dts >=
pkt->
dts)
11649 uint8_t sample_is_depended_on = (sample_flags >> 2) & 0x3;
11689 if (
s->pb->pos == 0) {
11703 for (
i = 0;
i <
s->nb_streams;
i++) {
11743 if (ret64 !=
sample->pos) {
11748 }
else if (ret64 < 0) {
11762 else if (sc->
iamf) {
11795 if (au_size >
sample->size - 4) {
11797 "APV au_size %u exceeds sample body %d\n",
11798 au_size,
sample->size - 4);
11801 au_size =
sample->size - 4;
11812 #if CONFIG_DV_DEMUXER
11898 int64_t key_sample_dts, key_sample_pts;
11925 int sample, time_sample,
ret, requested_sample;
11940 if (sample < 0 && sti->nb_index_entries && timestamp < sti->index_entries[0].timestamp)
11950 if (requested_sample < 0)
11959 timestamp = next_ts;
11974 time_sample = next;
11989 time_sample = next;
12009 (
AVRational){1, st->codecpar->sample_rate});
12021 if (stream_index >=
s->nb_streams)
12024 st =
s->streams[stream_index];
12030 if (
mc->seek_individually) {
12035 for (
i = 0;
i <
s->nb_streams;
i++) {
12040 if (stream_index ==
i)
12049 for (
i = 0;
i <
s->nb_streams;
i++) {
12051 st =
s->streams[
i];
12069 #define OFFSET(x) offsetof(MOVContext, x)
12070 #define FLAGS AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_DECODING_PARAM
12072 {
"use_absolute_path",
12073 "allow using absolute path when opening alias, this is a possible security issue",
12076 {
"seek_streams_individually",
12077 "Seek each stream individually to the closest point",
12080 {
"ignore_editlist",
"Ignore the edit list atom.",
OFFSET(ignore_editlist),
AV_OPT_TYPE_BOOL, {.i64 = 0},
12082 {
"advanced_editlist",
12083 "Modify the AVIndex according to the editlists. Use this option to decode in the order specified by the edits.",
12089 "use mfra for fragment timestamps",
12092 .unit =
"use_mfra_for"},
12094 FLAGS, .unit =
"use_mfra_for" },
12096 FLAGS, .unit =
"use_mfra_for" },
12098 FLAGS, .unit =
"use_mfra_for" },
12101 {
"export_all",
"Export unrecognized metadata entries",
OFFSET(export_all),
12103 {
"export_xmp",
"Export full XMP metadata",
OFFSET(export_xmp),
12105 {
"activation_bytes",
"Secret bytes for Audible AAX files",
OFFSET(activation_bytes),
12107 {
"audible_key",
"AES-128 Key for Audible AAXC files",
OFFSET(audible_key),
12109 {
"audible_iv",
"AES-128 IV for Audible AAXC files",
OFFSET(audible_iv),
12111 {
"audible_fixed_key",
12112 "Fixed key used for handling Audible AAX files",
OFFSET(audible_fixed_key),
12118 {.i64 = 0}, 0, 1,
FLAGS },
12133 .
p.
name =
"mov,mp4,m4a,3gp,3g2,mj2",
12136 .p.extensions =
"mov,mp4,m4a,3gp,3g2,mj2,psp,m4v,m4b,ism,ismv,isma,f4v,avif,heic,heif",
AVChapter * avpriv_new_chapter(AVFormatContext *s, int64_t id, AVRational time_base, int64_t start, int64_t end, const char *title)
Add a new chapter.
unsigned int ctts_allocated_size
@ AV_EXIF_T_OFF
The first four bytes point to the actual start, then it's AV_EXIF_TIFF_HEADER.
static int mov_finalize_stsd_entry(MOVContext *c, AVStream *st)
static int mov_read_chpl(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_frma(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_meta(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_PKT_DATA_DISPLAYMATRIX
This side data contains a 3x3 transformation matrix describing an affine transformation that needs to...
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
int found_iloc
'iloc' atom has been found
int ff_rfps_add_frame(AVFormatContext *ic, AVStream *st, int64_t ts)
add frame for rfps calculation.
static int read_image_iovl(AVFormatContext *s, const HEIFGrid *grid, AVStreamGroupTileGrid *tile_grid)
@ AV_PRIMARY_EYE_RIGHT
Right eye.
static int mov_read_irot(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVIAMFSubmixElement ** elements
Array of submix elements.
static void skip_bits_long(GetBitContext *s, int n)
Skips the specified number of bits.
#define AV_LOG_WARNING
Something somehow does not look correct.
#define AV_BPRINT_SIZE_UNLIMITED
#define MOV_TFHD_DEFAULT_FLAGS
#define PUT_UTF8(val, tmp, PUT_BYTE)
#define AV_TIMECODE_STR_SIZE
int av_aes_init(AVAES *a, const uint8_t *key, int key_bits, int decrypt)
Initialize an AVAES context.
int skip_samples
Number of samples to skip at the start of the frame decoded from the next packet.
int16_t audio_cid
stsd audio compression id
AVSphericalProjection
Projection of the video surface(s) on a sphere.
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
static int mov_read_dops(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int can_seek_to_key_sample(AVStream *st, int sample, int64_t requested_pts)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option name
@ AV_CODEC_ID_ADPCM_IMA_QT
#define AV_EF_EXPLODE
abort decoding on minor error detection
int64_t id
Group type-specific group ID.
@ AV_STEREO3D_VIEW_LEFT
Frame contains only the left view.
#define MOV_TRUN_SAMPLE_FLAGS
@ AV_PKT_DATA_AMBIENT_VIEWING_ENVIRONMENT
Ambient viewing environment metadata, as defined by H.274.
unsigned int nb_chapter_tracks
static int mix(int c0, int c1)
const uint16_t ff_ac3_channel_layout_tab[8]
Map audio coding mode (acmod) to channel layout mask.
union AVStreamGroup::@450 params
Group type-specific parameters.
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
static HEIFItem * get_heif_item(MOVContext *c, unsigned id)
Get the requested item.
#define MOV_TKHD_FLAG_ENABLED
enum AVMediaType codec_type
General type of the encoded data.
struct AVStreamGroupTileGrid * tile_grid
enum AVSphericalProjection projection
Projection type.
static struct @589 current
int av_exif_parse_buffer(void *logctx, const uint8_t *buf, size_t size, AVExifMetadata *ifd, enum AVExifHeaderMode header_mode)
Decodes the EXIF data provided in the buffer and writes it into the struct *ifd.
uint8_t ** extradata
extradata array (and size) for multiple stsd
static const AVClass mov_class
uint32_t bound_bottom
Distance from the bottom edge.
uint8_t AVUUID[AV_UUID_LEN]
static int mov_parse_tmcd_streams(AVFormatContext *s)
static int mov_read_targa_y216(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_chnl(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_moof(MOVContext *c, AVIOContext *pb, MOVAtom atom)
void av_bprint_init(AVBPrint *buf, unsigned size_init, unsigned size_max)
@ AV_PKT_DATA_FRAME_CROPPING
The number of pixels to discard from the top/bottom/left/right border of the decoded frame to obtain ...
int av_exif_write(void *logctx, const AVExifMetadata *ifd, AVBufferRef **buffer, enum AVExifHeaderMode header_mode)
Allocates a buffer using av_malloc of an appropriate size and writes the EXIF data represented by ifd...
This struct describes the properties of an encoded stream.
static int sanity_checks(void *log_obj, MOVStreamContext *sc, int index)
char * av_stristr(const char *s1, const char *s2)
Locate the first case-independent occurrence in the string haystack of the string needle.
enum AVColorSpace color_space
AVStream * avformat_new_stream(AVFormatContext *s, const struct AVCodec *c)
Add a new stream to a media file.
int ff_replaygain_export(AVStream *st, AVDictionary *metadata)
Parse replaygain tags and export them as per-stream side data.
static int tmcd_is_referenced(AVFormatContext *s, int tmcd_id)
@ AV_PKT_DATA_NEW_EXTRADATA
The AV_PKT_DATA_NEW_EXTRADATA is used to notify the codec or the format that the extradata buffer was...
unsigned int nb_substreams
#define AVERROR_EOF
End of file.
uint8_t * data
The data buffer.
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed.
static const AVOption mov_options[]
static int mov_codec_id(AVStream *st, uint32_t format)
@ AV_PKT_DATA_MASTERING_DISPLAY_METADATA
Mastering display metadata (based on SMPTE-2086:2014).
static av_always_inline double av_int2double(uint64_t i)
Reinterpret a 64-bit integer as a double.
static int mov_read_iloc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_PKT_FLAG_DISCARD
Flag is used to discard packets which are required to maintain valid decoder state but are not requir...
static unsigned int get_bits_long(GetBitContext *s, int n)
Read 0-32 bits.
filter_frame For filters that do not use the this method is called when a frame is pushed to the filter s input It can be called at any time except in a reentrant way If the input frame is enough to produce output
static int mov_read_alac(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int test_same_origin(const char *src, const char *ref)
static int cbcs_scheme_decrypt(MOVContext *c, MOVStreamContext *sc, AVEncryptionInfo *sample, uint8_t *input, int size)
uint64_t base_data_offset
AVChannelCustom * map
This member must be used when the channel order is AV_CHANNEL_ORDER_CUSTOM.
int ff_buffer_packet(AVFormatContext *s, AVPacket *pkt)
#define IS_MATRIX_IDENT(matrix)
int disposition
Stream group disposition - a combination of AV_DISPOSITION_* flags.
static void mov_update_dts_shift(MOVStreamContext *sc, int duration, void *logctx)
AVSphericalMapping * spherical
unsigned MaxCLL
Max content light level (cd/m^2).
int avio_get_str16be(AVIOContext *pb, int maxlen, char *buf, int buflen)
void av_encryption_init_info_free(AVEncryptionInitInfo *info)
Frees the given encryption init info object.
static int mov_read_avss(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int found_moov
'moov' atom has been found
int ff_iamf_read_packet(AVFormatContext *s, IAMFDemuxContext *c, AVIOContext *pb, int max_size, int stream_id_offset, AVPacket *pkt)
static int mov_read_custom(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static av_cold void cleanup(FlashSV2Context *s)
AVStream ** streams
A list of all streams in the file.
This structure stores auxiliary information for decoding, presenting, or otherwise processing the cod...
static int mov_read_extradata(MOVContext *c, AVIOContext *pb, MOVAtom atom, enum AVCodecID codec_id)
@ AVCOL_RANGE_JPEG
Full range content.
unsigned int rap_group_count
void av_display_matrix_flip(int32_t matrix[9], int hflip, int vflip)
Flip the input matrix horizontally and/or vertically.
av_cold int av_sha_init(AVSHA *ctx, int bits)
Initialize SHA-1 or SHA-2 hashing.
static int mov_read_mvhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_idat(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int found_mdat
'mdat' atom has been found
uint32_t crypt_byte_block
Only used for pattern encryption.
@ AV_PKT_DATA_ENCRYPTION_INIT_INFO
This side data is encryption initialization data.
static int mov_read_avid(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVRational ambient_light_x
Normalized x chromaticity coordinate of the environmental ambient light in the nominal viewing enviro...
int seek_preroll
Number of audio samples to skip after a discontinuity.
void * av_dynarray2_add(void **tab_ptr, int *nb_ptr, size_t elem_size, const uint8_t *elem_data)
Add an element of size elem_size to a dynamic array.
static int mov_read_stps(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int * bitrates
bitrates read before streams creation
static int mov_read_tkhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVRational avg_frame_rate
Average framerate.
static const uint16_t table[]
static int mov_read_colr(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static void set_last_stream_little_endian(AVFormatContext *fc)
static int mov_read_strf(MOVContext *c, AVIOContext *pb, MOVAtom atom)
An strf atom is a BITMAPINFOHEADER struct.
#define FF_COMPLIANCE_STRICT
Strictly conform to all the things in the spec no matter what consequences.
#define AV_DICT_APPEND
If the entry already exists, append to it.
int error
contains the error code or 0 if no error happened
void av_iamf_mix_presentation_free(AVIAMFMixPresentation **pmix_presentation)
Free an AVIAMFMixPresentation and all its contents.
unsigned int metadata_index
Index of the metadata stream in the AVStreamGroup.
static int mov_parse_auxiliary_info(MOVContext *c, MOVStreamContext *sc, AVIOContext *pb, MOVEncryptionIndex *encryption_index)
static int mov_seek_stream(AVFormatContext *s, AVStream *st, int64_t timestamp, int flags)
static int mov_read_saio(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int64_t mov_get_stsc_samples(MOVStreamContext *sc, unsigned int index)
#define AV_LOG_VERBOSE
Detailed information.
const AVCodecTag ff_codec_wav_tags[]
static int get_edit_list_entry(MOVContext *mov, const MOVStreamContext *msc, unsigned int edit_list_index, int64_t *edit_list_media_time, int64_t *edit_list_duration, int64_t global_timescale)
Get ith edit list entry (media time, duration).
static int mov_change_extradata(AVStream *st, AVPacket *pkt)
static unsigned int nb_streams
void av_display_rotation_set(int32_t matrix[9], double angle)
Initialize a transformation matrix describing a pure clockwise rotation by the specified angle (in de...
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
struct AVStreamGroupTREF * tref
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
static const uint8_t fixed_key[]
@ AV_SPHERICAL_EQUIRECTANGULAR_TILE
Video represents a portion of a sphere mapped on a flat surface using equirectangular projection.
uint32_t baseline
The distance between the centres of the lenses of the camera system, in micrometers.
static void mov_current_sample_set(MOVStreamContext *sc, int current_sample)
void ffio_init_read_context(FFIOContext *s, const uint8_t *buffer, int buffer_size)
Wrap a buffer in an AVIOContext for reading.
#define AV_PKT_FLAG_DISPOSABLE
Flag is used to indicate packets that contain frames that can be discarded by the decoder.
enum AVChannelOrder order
Channel order used in this layout.
int vertical
Offset in pixels from the top edge of the canvas where the tile should be placed.
static int mov_read_moov(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVRational av_sub_q(AVRational b, AVRational c)
Subtract one rational from another.
static int mov_read_esds(MOVContext *c, AVIOContext *pb, MOVAtom atom)
unsigned int sample_count
int nb_channels
Number of channels in this layout.
@ AV_SPHERICAL_EQUIRECTANGULAR
Video represents a sphere mapped on a flat surface using equirectangular projection.
int ff_dvdclut_yuv_to_rgb(uint32_t *clut, const size_t clut_size)
AVEncryptionInitInfo * av_encryption_init_info_get_side_data(const uint8_t *side_data, size_t side_data_size)
Creates a copy of the AVEncryptionInitInfo that is contained in the given side data.
@ AV_STEREO3D_VIEW_RIGHT
Frame contains only the right view.
int advanced_editlist_autodisabled
int64_t avio_size(AVIOContext *s)
Get the filesize.
size_t av_strlcatf(char *dst, size_t size, const char *fmt,...)
static int mov_read_stco(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_STEREO3D_VIEW_UNSPEC
Content is unspecified.
static int mov_read_vexu(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
struct AVAESCTR * aes_ctr
static int cenc_filter(MOVContext *mov, AVStream *st, MOVStreamContext *sc, AVPacket *pkt, int current_index)
static int mov_read_sdtp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_jp2h(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_STEREO3D_UNSPEC
Video is stereoscopic but the packing is unspecified.
static int mov_read_tfhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define OPUS_SEEK_PREROLL_MS
const AVIAMFMixPresentation * cmix
uint8_t * decryption_default_key
static int mov_read_wide(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_FIELD_BT
Bottom coded first, top displayed first.
int ff_mov_lang_to_iso639(unsigned code, char to[4])
int ff_generate_avci_extradata(AVStream *st)
Generate standard extradata for AVC-Intra based on width/height and field order.
int ff_get_extradata(void *logctx, AVCodecParameters *par, AVIOContext *pb, int size)
Allocate extradata with additional AV_INPUT_BUFFER_PADDING_SIZE at end which is always set to 0 and f...
static int mov_add_tref_id(MovTref *tag, uint32_t id)
@ AV_PKT_DATA_DOVI_CONF
DOVI configuration ref: dolby-vision-bitstreams-within-the-iso-base-media-file-format-v2....
AVRational horizontal_field_of_view
Horizontal field of view, in degrees.
static void skip_bits(GetBitContext *s, int n)
enum AVColorPrimaries color_primaries
uint32_t scheme
The fourcc encryption scheme, in big-endian byte order.
@ AV_STEREO3D_SIDEBYSIDE
Views are next to each other.
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
HEIFItem ** tile_item_list
static int set_icc_profile_from_item(AVPacketSideData **coded_side_data, int *nb_coded_side_data, const HEIFItem *item)
@ AV_FIELD_TT
Top coded_first, top displayed first.
@ AV_STEREO3D_VIEW_PACKED
Frame contains two packed views.
@ AV_SPHERICAL_PARAMETRIC_IMMERSIVE
Parametric Immersive projection (Apple).
#define FF_DVDCLUT_CLUT_LEN
uint32_t skip_byte_block
Only used for pattern encryption.
static int aax_filter(uint8_t *input, int size, MOVContext *c)
@ AV_OPT_TYPE_BINARY
Underlying C type is a uint8_t* that is either NULL or points to an array allocated with the av_mallo...
const char * av_color_space_name(enum AVColorSpace space)
int av_packet_add_side_data(AVPacket *pkt, enum AVPacketSideDataType type, uint8_t *data, size_t size)
Wrap an existing array as a packet side data.
AVMasteringDisplayMetadata * mastering
#define AV_FOURCC_MAX_STRING_SIZE
@ AV_PKT_DATA_PALETTE
An AV_PKT_DATA_PALETTE side data packet contains exactly AVPALETTE_SIZE bytes worth of palette.
static int mov_find_tref_id(const MovTref *tag, uint32_t id)
static MovTref * mov_add_tref_tag(MOVStreamContext *sc, uint32_t name)
static int mov_read_mdhd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_ctts(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define MOV_FRAG_SAMPLE_FLAG_IS_NON_SYNC
static int mov_read_aclr(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static av_always_inline float av_int2float(uint32_t i)
Reinterpret a 32-bit integer as a float.
AVStreamGroupTileGrid holds information on how to combine several independent images on a single canv...
#define FF_DVDCLUT_CLUT_SIZE
@ AV_STEREO3D_2D
Video is not stereoscopic (and metadata has to be there).
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
void av_shrink_packet(AVPacket *pkt, int size)
Reduce packet size, correctly zeroing padding.
static MOVFragmentStreamInfo * get_current_frag_stream_info(MOVFragmentIndex *frag_index)
int coded_width
Width of the canvas.
void av_iamf_audio_element_free(AVIAMFAudioElement **paudio_element)
Free an AVIAMFAudioElement and all its contents.
unsigned int index_entries_allocated_size
static av_cold int read_close(AVFormatContext *ctx)
static int mov_read_amve(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_enda(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_chap(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
void av_exif_free(AVExifMetadata *ifd)
Frees all resources associated with the given EXIF metadata struct.
#define MOV_TRUN_SAMPLE_DURATION
static double val(void *priv, double ch)
static int set_display_matrix_from_item(AVPacketSideData **coded_side_data, int *nb_coded_side_data, const HEIFItem *item)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf type
int coded_height
Width of the canvas.
int v_spacing
pasp vSpacing
uint8_t * iv
The initialization vector.
@ AV_CODEC_ID_MP3
preferred ID for decoding MPEG audio layer 1, 2 or 3
int64_t duration
Decoding: duration of the stream, in stream time base.
AVRational ambient_illuminance
Environmental illuminance of the ambient viewing environment in lux.
#define ss(width, name, subs,...)
static int get_key_from_kid(uint8_t *out, int len, MOVContext *c, AVEncryptionInfo *sample)
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
enum AVIAMFAudioElementType audio_element_type
Audio element type as defined in section 3.6 of IAMF.
static int update_frag_index(MOVContext *c, int64_t offset)
size_t auxiliary_info_sample_count
@ AV_FIELD_TB
Top coded first, bottom displayed first.
static int mov_read_pack(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVPacket attached_pic
For streams with AV_DISPOSITION_ATTACHED_PIC disposition, this packet will contain the attached pictu...
static int mov_read_saiz(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define MOV_FRAG_SAMPLE_FLAG_DEPENDS_YES
static int mov_merge_tts_data(MOVContext *mov, AVStream *st, int flags)
#define MOV_TRUN_DATA_OFFSET
AVEncryptionInfo * av_encryption_info_clone(const AVEncryptionInfo *info)
Allocates an AVEncryptionInfo structure with a copy of the given data.
AVAmbientViewingEnvironment * av_ambient_viewing_environment_alloc(size_t *size)
Allocate an AVAmbientViewingEnvironment structure.
#define AV_DICT_DONT_STRDUP_VAL
Take ownership of a value that's been allocated with av_malloc() or another memory allocation functio...
AVIAMFAudioElement * element
element backs celement iff the AVIAMFAudioElement is owned by this structure.
static int mov_read_ares(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_adrm(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int av_get_bits_per_sample(enum AVCodecID codec_id)
Return codec bits per sample.
enum AVColorTransferCharacteristic color_trc
IAMFAudioElement ** audio_elements
union AVChannelLayout::@518 u
Details about which channels are present in this layout.
unsigned int avio_rb32(AVIOContext *s)
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static void mov_free_encryption_index(MOVEncryptionIndex **index)
#define AV_CH_LOW_FREQUENCY
uint64_t * auxiliary_offsets
Absolute seek position.
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
int dts_shift
dts shift when ctts is negative
int av_timecode_init(AVTimecode *tc, AVRational rate, int flags, int frame_start, void *log_ctx)
Init a timecode struct with the passed parameters.
int frame_size
Audio frame size, if known.
static int mov_read_srat(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int avio_get_str16le(AVIOContext *pb, int maxlen, char *buf, int buflen)
Read a UTF-16 string from pb and convert it to UTF-8.
static int mov_metadata_track_or_disc_number(MOVContext *c, AVIOContext *pb, unsigned len, const char *key)
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
static int mov_parse_exif_item(AVFormatContext *s, AVPacketSideData **coded_side_data, int *nb_coded_side_data, const HEIFItem *ref)
int ff_add_attached_pic(AVFormatContext *s, AVStream *st, AVIOContext *pb, AVBufferRef **buf, int size)
Add an attached pic to an AVStream.
static int add_tts_entry(MOVTimeToSample **tts_data, unsigned int *tts_count, unsigned int *allocated_size, int count, int offset, unsigned int duration)
void * av_fast_realloc(void *ptr, unsigned int *size, size_t min_size)
Reallocate the given buffer if it is not large enough, otherwise do nothing.
#define FF_MOV_FLAG_MFRA_PTS
int ff_mov_read_esds(AVFormatContext *fc, AVIOContext *pb)
static int mov_read_coll(MOVContext *c, AVIOContext *pb, MOVAtom atom)
MOVEncryptionIndex * encryption_index
static int mov_read_trak(MOVContext *c, AVIOContext *pb, MOVAtom atom)
unsigned int audio_substream_id
#define MOV_TFHD_DEFAULT_BASE_IS_MOOF
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values.
unsigned int substream_count
#define MOV_TFHD_DEFAULT_DURATION
#define ALAC_EXTRADATA_SIZE
void * av_realloc_array(void *ptr, size_t nmemb, size_t size)
struct AVAES * aes_decrypt
uint32_t bound_top
Distance from the top edge.
int width
The width of the video frame in pixels.
@ AV_CHANNEL_ORDER_UNSPEC
Only the channel count is specified, without any further information about the channel order.
#define MOV_TRUN_FIRST_SAMPLE_FLAGS
static double av_q2d(AVRational a)
Convert an AVRational to a double.
int av_channel_layout_from_mask(AVChannelLayout *channel_layout, uint64_t mask)
Initialize a native channel layout from a bitmask indicating which channels are present.
#define fc(width, name, range_min, range_max)
static void mov_estimate_video_delay(MOVContext *c, AVStream *st)
int64_t timestamp
Timestamp in AVStream.time_base units, preferably the time from which on correctly decoded frames are...
#define av_assert0(cond)
assert() equivalent, that is always enabled.
int64_t min_corrected_pts
minimum Composition time shown by the edits excluding empty edits.
unsigned int ffio_read_leb(AVIOContext *s)
Read a unsigned integer coded as a variable number of up to eight little-endian bytes,...
static int mov_read_lhvc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
static AVFormatContext * ctx
static int mov_read_sidx(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_PKT_DATA_STEREO3D
This side data should be associated with a video stream and contains Stereoscopic 3D information in f...
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
int ff_iamfdec_read_descriptors(IAMFContext *c, AVIOContext *pb, int max_size, void *log_ctx)
AVRational display_aspect_ratio
display aspect ratio (0 if unknown)
static AVIndexEntry * mov_find_next_sample(AVFormatContext *s, AVStream **st)
int ff_mov_read_chnl(AVFormatContext *s, AVIOContext *pb, AVStream *st, int version)
Read 'chnl' tag from the input stream.
int min_distance
Minimum distance between this and the previous keyframe, used to avoid unneeded searching.
static int mov_read_dvcc_dvvc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int(* parse)(MOVContext *ctx, AVIOContext *pb, MOVAtom atom)
int nb_coded_side_data
Amount of entries in coded_side_data.
@ AVMEDIA_TYPE_DATA
Opaque data information usually continuous.
static int mov_read_udta_string(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_stss(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_ddts(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_uuid(MOVContext *c, AVIOContext *pb, MOVAtom atom)
struct AVStreamGroupLayeredVideo * layered_video
void av_sha_final(AVSHA *ctx, uint8_t *digest)
Finish hashing and output digest value.
#define MAX_REORDER_DELAY
AVEncryptionInfo ** encrypted_samples
static int mov_read_close(AVFormatContext *s)
int flags
Additional information about the frame packing.
static enum AVCodecID ff_mov_get_lpcm_codec_id(int bps, int flags)
Compute codec id for 'lpcm' tag.
static int mov_read_cmov(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define FF_INFMT_FLAG_INIT_CLEANUP
For an FFInputFormat with this flag set read_close() needs to be called by the caller upon read_heade...
static int mov_read_sample_encryption_info(MOVContext *c, AVIOContext *pb, MOVStreamContext *sc, AVEncryptionInfo **sample, int use_subsamples)
enum AVStreamParseType need_parsing
unsigned int keyframe_count
static int mov_read_SAND(MOVContext *c, AVIOContext *pb, MOVAtom atom)
unsigned int audio_element_id
@ AVDISCARD_ALL
discard all
#define av_realloc_f(p, o, n)
static int mov_read_stts(MOVContext *c, AVIOContext *pb, MOVAtom atom)
MOVIndexRange * index_ranges
static int find_prev_closest_index(AVStream *st, AVIndexEntry *e_old, int nb_old, MOVTimeToSample *tts_data, int64_t tts_count, int64_t timestamp_pts, int flag, int64_t *index, int64_t *tts_index, int64_t *tts_sample)
Find the closest previous frame to the timestamp_pts, in e_old index entries.
static void set_frag_stream(MOVFragmentIndex *frag_index, int id)
static int mov_read_free(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_realloc_extradata(AVCodecParameters *par, MOVAtom atom)
AVCodecParameters * codecpar
Codec parameters associated with this stream.
#define LIBAVUTIL_VERSION_INT
int32_t av_exif_get_tag_id(const char *name)
Retrieves the tag ID associated with the provided tag string name.
@ AV_PKT_DATA_EXIF
Extensible image file format metadata.
Describe the class of an AVClass context structure.
and forward the result(frame or status change) to the corresponding input. If nothing is possible
static __device__ float fabs(float a)
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
static uint64_t truehd_layout(int chanmap)
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
New swscale design to change SwsGraph is what coordinates multiple passes These can include cascaded scaling error diffusion and so on Or we could have separate passes for the vertical and horizontal scaling In between each SwsPass lies a fully allocated image buffer Graph passes may have different levels of e g we can have a single threaded error diffusion pass following a multi threaded scaling pass SwsGraph is internally recreated whenever the image format
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
@ FLAC_METADATA_TYPE_STREAMINFO
This describes info used to initialize an encryption key system.
static int mov_read_ftyp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int read_image_grid(AVFormatContext *s, const HEIFGrid *grid, AVStreamGroupTileGrid *tile_grid)
struct AVAESCTR * av_aes_ctr_alloc(void)
Allocate an AVAESCTR context.
static av_always_inline void flac_parse_block_header(const uint8_t *block_header, int *last, int *type, int *size)
Parse the metadata block parameters from the header.
AVPacketSideData * coded_side_data
Additional data associated with the grid.
Rational number (pair of numerator and denominator).
@ AV_PRIMARY_EYE_LEFT
Left eye.
static int mov_read_sgpd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_CHANNEL_LAYOUT_RETYPE_FLAG_CANONICAL
The specified retype target order is ignored and the simplest possible (canonical) order is used for ...
static int mov_probe(const AVProbeData *p)
@ AV_OPT_TYPE_DICT
Underlying C type is AVDictionary*.
static int get_eia608_packet(AVIOContext *pb, AVPacket *pkt, int src_size)
@ AV_CODEC_ID_DVD_SUBTITLE
int64_t time_offset
time offset of the edit list entries
static int mov_read_smdm(MOVContext *c, AVIOContext *pb, MOVAtom atom)
const char * av_default_item_name(void *ptr)
Return the context name.
AVRational horizontal_disparity_adjustment
Relative shift of the left and right images, which changes the zero parallax plane.
uint64_t avio_rb64(AVIOContext *s)
void av_aes_crypt(AVAES *a, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt)
Encrypt or decrypt a buffer using a previously initialized context.
MOVIndexRange * current_index_range
static int mov_open_dref(MOVContext *c, AVIOContext **pb, const char *src, MOVDref *ref)
This structure contains the data a format has to probe a file.
struct AVAES * av_aes_alloc(void)
Allocate an AVAES context.
static int mov_read_schm(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define FLAC_STREAMINFO_SIZE
const char * av_color_primaries_name(enum AVColorPrimaries primaries)
#define FF_MOV_FLAG_MFRA_DTS
#define MOV_SAMPLE_DEPENDENCY_NO
#define AV_DICT_DONT_OVERWRITE
Don't overwrite existing entries.
const AVCodecTag ff_codec_movvideo_tags[]
static int mov_read_ilst(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_CH_FRONT_CENTER
AVChannelLayout ch_layout
The channel layout and number of channels.
static MOVFragmentStreamInfo * get_frag_stream_info_from_pkt(MOVFragmentIndex *frag_index, AVPacket *pkt, int id)
static uint32_t get_sgpd_sync_index(const MOVStreamContext *sc, int nal_unit_type)
static int mov_read_fiel(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int parse(AVCodecParserContext *s, AVCodecContext *avctx, const uint8_t **poutbuf, int *poutbuf_size, const uint8_t *buf, int buf_size)
@ AV_PKT_DATA_CONTENT_LIGHT_LEVEL
Content light level (based on CTA-861.3).
uint8_t * av_encryption_info_add_side_data(const AVEncryptionInfo *info, size_t *size)
Allocates and initializes side data that holds a copy of the given encryption info.
#define MOV_TFHD_BASE_DATA_OFFSET
int av_exif_remove_entry(void *logctx, AVExifMetadata *ifd, uint16_t id, int flags)
Remove an entry from the provided EXIF metadata struct.
int open_key_samples_count
const AVCodecTag ff_codec_movaudio_tags[]
const AVCodecTag ff_codec_movdata_tags[]
static int mov_read_wfex(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVStereo3D * av_stereo3d_alloc_size(size_t *size)
Allocate an AVStereo3D structure and set its fields to default values.
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
int sample_rate
The number of audio samples per second.
static void mov_parse_stsd_subtitle(MOVContext *c, AVIOContext *pb, AVStream *st, MOVStreamContext *sc, int64_t size)
static int mov_skip_multiple_stsd(MOVContext *c, AVIOContext *pb, int codec_tag, int format, int64_t size)
@ AV_CODEC_ID_GSM
as in Berlin toast format
int64_t nb_frames
number of frames in this stream if known or 0
AVCodecID
Identify the syntax and semantics of the bitstream.
const AVPacketSideData * av_packet_side_data_get(const AVPacketSideData *sd, int nb_sd, enum AVPacketSideDataType type)
Get side information from a side data array.
unsigned int audio_element_id
The id of the Audio Element this submix element references.
static int should_retry(AVIOContext *pb, int error_code)
int avformat_stream_group_add_stream(AVStreamGroup *stg, AVStream *st)
Add an already allocated stream to a stream group.
@ AV_PKT_DATA_SPHERICAL
This side data should be associated with a video stream and corresponds to the AVSphericalMapping str...
int extradata_size
Size of the extradata content in bytes.
Submix layout as defined in section 3.7 of IAMF.
static int mov_read_pasp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
DVDemuxContext * dv_demux
enum AVStereo3DPrimaryEye primary_eye
Which eye is the primary eye when rendering in 2D.
static const AVColorPrimariesDesc color_primaries[AVCOL_PRI_NB]
static int mov_read_SA3D(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_elst(MOVContext *c, AVIOContext *pb, MOVAtom atom)
uint8_t auxiliary_info_default_size
static int mov_read_header(AVFormatContext *s)
static int mov_read_vdep(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_SPHERICAL_HALF_EQUIRECTANGULAR
Video frame displays as a 180 degree equirectangular projection.
static int cbc1_scheme_decrypt(MOVContext *c, MOVStreamContext *sc, AVEncryptionInfo *sample, uint8_t *input, int size)
unsigned int avio_rl32(AVIOContext *s)
@ AVDISCARD_NONKEY
discard all frames except keyframes
static int mov_read_wave(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_SPHERICAL_CUBEMAP
Video frame is split into 6 faces of a cube, and arranged on a 3x2 layout.
unsigned int avio_rb24(AVIOContext *s)
static int cens_scheme_decrypt(MOVContext *c, MOVStreamContext *sc, AVEncryptionInfo *sample, uint8_t *input, int size)
static void mov_free_stream_context(AVFormatContext *s, AVStream *st)
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
AVFormatContext * avformat_alloc_context(void)
Allocate an AVFormatContext.
static int get_current_encryption_info(MOVContext *c, MOVEncryptionIndex **encryption_index, MOVStreamContext **sc)
Gets the current encryption info and associated current stream context.
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable.
int av_aes_ctr_init(struct AVAESCTR *a, const uint8_t *key)
Initialize an AVAESCTR context.
int av_bprint_finalize(AVBPrint *buf, char **ret_str)
Finalize a print buffer.
An AVChannelLayout holds information about the channel layout of audio data.
static int mov_read_dref(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static void mov_current_sample_dec(MOVStreamContext *sc)
uint32_t bound_right
Distance from the right edge.
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
#define i(width, name, range_min, range_max)
unsigned int stsz_sample_size
always contains sample size from stsz atom
#define FF_MOV_FLAG_MFRA_AUTO
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
static int64_t start_time
int ff_dvdclut_palette_extradata_cat(const uint32_t *clut, const size_t clut_size, AVCodecParameters *par)
static int mov_read_trun(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int avio_get_str(AVIOContext *pb, int maxlen, char *buf, int buflen)
Read a string from pb into buf.
static int mov_read_iprp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
void av_sha_update(struct AVSHA *ctx, const uint8_t *data, size_t len)
Update hash value.
static av_const double hypot(double x, double y)
static int mov_read_chan(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static AVRational av_make_q(int num, int den)
Create an AVRational.
static int mov_read_stsc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int av_reallocp(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory through a pointer to a pointer.
int ff_get_qtpalette(int codec_id, AVIOContext *pb, uint32_t *palette)
Retrieve the palette (or "color table" in QuickTime terms), either from the video sample description,...
#define AV_NOPTS_VALUE
Undefined timestamp value.
#define MKBETAG(a, b, c, d)
char * av_fourcc_make_string(char *buf, uint32_t fourcc)
Fill the provided buffer with a string containing a FourCC (four-character code) representation.
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
void avpriv_report_missing_feature(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
void av_aes_ctr_set_full_iv(struct AVAESCTR *a, const uint8_t *iv)
Forcefully change the "full" 16-byte iv, including the counter.
struct AVIAMFAudioElement * iamf_audio_element
AVContentLightMetadata * coll
struct AVStreamGroupTileGrid::@449 * offsets
An nb_tiles sized array of offsets in pixels from the topleft edge of the canvas, indicating where ea...
static int mov_parse_heif_items(AVFormatContext *s)
static int64_t add_index_entry(AVStream *st, int64_t pos, int64_t timestamp, int size, int distance, int flags)
Add index entry with the given values, to the end of ffstream(st)->index_entries.
static void mov_current_sample_inc(MOVStreamContext *sc)
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
static int mov_read_vexu_proj(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static void fix_timescale(MOVContext *c, MOVStreamContext *sc)
int avio_r8(AVIOContext *s)
IAMFSubStream * substreams
uint32_t padding
Number of pixels to pad from the edge of each cube face.
The reader does not expect b to be semantically here and if the code is changed by maybe adding a a division or other the signedness will almost certainly be mistaken To avoid this confusion a new type was SUINT is the C unsigned type but it holds a signed int to use the same example SUINT a
int av_channel_layout_retype(AVChannelLayout *channel_layout, enum AVChannelOrder order, int flags)
Change the AVChannelOrder of a channel layout.
static int mov_parse_dovi_streams(AVFormatContext *s)
int av_reallocp_array(void *ptr, size_t nmemb, size_t size)
Allocate, reallocate an array through a pointer to a pointer.
Information on how to combine one or more audio streams, as defined in section 3.6 of IAMF.
@ AV_PRIMARY_EYE_NONE
Neither eye.
static int mov_read_default(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_TIMECODE_FLAG_24HOURSMAX
timecode wraps after 24 hours
static AVStream * mov_find_reference_track(AVFormatContext *s, AVStream *st, uint32_t *tref_id, int nb_tref_id, int first_index)
int ffio_ensure_seekback(AVIOContext *s, int64_t buf_size)
Ensures that the requested seekback buffer size will be available.
unsigned int nb_tiles
Amount of tiles in the grid.
AVPacketSideData * av_packet_side_data_add(AVPacketSideData **psd, int *pnb_sd, enum AVPacketSideDataType type, void *data, size_t size, int flags)
Wrap existing data as packet side data.
static int mov_read_packet(AVFormatContext *s, AVPacket *pkt)
static int mov_read_infe(MOVContext *c, AVIOContext *pb, MOVAtom atom)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
size_t auxiliary_offsets_count
int flags
A combination of AV_PKT_FLAG values.
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
void av_encryption_info_free(AVEncryptionInfo *info)
Frees the given encryption info object.
static int read_header(FFV1Context *f, RangeCoder *c)
int av_strstart(const char *str, const char *pfx, const char **ptr)
Return non-zero if pfx is a prefix of str.
This file is part of FFmpeg.
AVBufferRef * av_buffer_alloc(size_t size)
Allocate an AVBuffer of the given size using av_malloc().
MOVFragmentStreamInfo * stream_info
struct AVEncryptionInitInfo * next
An optional pointer to the next initialization info in the list.
#define AV_STEREO3D_FLAG_INVERT
Inverted views, Right/Bottom represents the left view.
AVStream ** streams
A list of streams in the group.
void ff_rfps_calculate(AVFormatContext *ic)
and forward the test the status of outputs and forward it to the corresponding return FFERROR_NOT_READY If the filters stores internally one or a few frame for some input
static int mov_read_clli(MOVContext *c, AVIOContext *pb, MOVAtom atom)
uint32_t * id
trackID of the referenced track
struct AVIAMFMixPresentation * iamf_mix_presentation
size_t size
Size of data in bytes.
MOVFragmentIndexItem * item
#define AV_LOG_INFO
Standard information.
struct IAMFDemuxContext * iamf
#define FFERROR_REDO
Returned by demuxers to indicate that data was consumed but discarded (ignored streams or junk data).
AVEncryptionInitInfo * av_encryption_init_info_alloc(uint32_t system_id_size, uint32_t num_key_ids, uint32_t key_id_size, uint32_t data_size)
Allocates an AVEncryptionInitInfo structure and sub-pointers to hold the given sizes.
int av_channel_layout_custom_init(AVChannelLayout *channel_layout, int nb_channels)
Initialize a custom channel layout with the specified number of channels.
void av_aes_ctr_free(struct AVAESCTR *a)
Release an AVAESCTR context.
int error_recognition
Error recognition; higher values will detect more errors but may misdetect some more or less valid pa...
static int mov_read_dfla(MOVContext *c, AVIOContext *pb, MOVAtom atom)
uint64_t count
number of bytes in buffer
@ AV_SPHERICAL_RECTILINEAR
Video frame displays on a flat, rectangular 2D surface.
static const MOVParseTableEntry mov_default_parse_table[]
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel layout
int nb_coded_side_data
Amount of entries in coded_side_data.
static void mov_metadata_creation_time(MOVContext *c, AVIOContext *pb, AVDictionary **metadata, int version)
static int mov_metadata_hmmt(MOVContext *c, AVIOContext *pb, unsigned len)
struct AVSHA * av_sha_alloc(void)
Allocate an AVSHA context.
static int mov_read_tenc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int av_uuid_equal(const AVUUID uu1, const AVUUID uu2)
Compares two UUIDs for equality.
static int mov_stsc_index_valid(unsigned int index, unsigned int count)
static int mov_finalize_packet(AVFormatContext *s, AVStream *st, AVIndexEntry *sample, int64_t current_index, AVPacket *pkt)
static int mov_read_seek(AVFormatContext *s, int stream_index, int64_t sample_time, int flags)
static const uint32_t mac_to_unicode[128]
int width
Width of the final image for presentation.
unsigned int bytes_per_frame
int32_t roll
Rotation around the forward vector [-180, 180].
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
static int mov_read_trex(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int search_frag_timestamp(AVFormatContext *s, MOVFragmentIndex *frag_index, AVStream *st, int64_t timestamp)
static void mov_fix_index(MOVContext *mov, AVStream *st)
Fix ffstream(st)->index_entries, so that it contains only the entries (and the entries which are need...
int ff_isom_parse_dvcc_dvvc(void *logctx, AVStream *st, const uint8_t *buf_ptr, uint64_t size)
static int mov_read_pssh(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_stsd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_SPHERICAL_FISHEYE
Fisheye projection (Apple).
int height
The height of the video frame in pixels.
#define AV_TIME_BASE
Internal time base represented as integer.
int block_align
The number of bytes per coded audio frame, required by some formats.
static int rb_size(AVIOContext *pb, int64_t *value, int size)
AVStereo3DPrimaryEye
List of possible primary eyes.
#define av_malloc_array(a, b)
int ff_mov_read_stsd_entries(MOVContext *c, AVIOContext *pb, int entries)
@ AV_FIELD_BB
Bottom coded first, bottom displayed first.
@ AV_PKT_DATA_ICC_PROFILE
ICC profile data consisting of an opaque octet buffer following the format described by ISO 15076-1.
struct MOVStreamContext::@481 cenc
@ AV_STEREO3D_TOPBOTTOM
Views are on top of each other.
Information on how to render and mix one or more AVIAMFAudioElement to generate the final audio outpu...
const char *const ff_id3v1_genre_str[ID3v1_GENRE_MAX+1]
ID3v1 genres.
unsigned int * sample_sizes
MOVFragmentIndex frag_index
static int mov_read_vpcc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int width
Width of the final stream for presentation.
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default value
void av_url_split(char *proto, int proto_size, char *authorization, int authorization_size, char *hostname, int hostname_size, int *port_ptr, char *path, int path_size, const char *url)
Split a URL string into components.
AVRational av_d2q(double d, int max)
Convert a double precision floating point number to a rational.
static void fix_frag_index_entries(MOVFragmentIndex *frag_index, int index, int id, int entries)
static int mov_finalize_stsd_codec(MOVContext *c, AVIOContext *pb, AVStream *st, MOVStreamContext *sc)
static int mov_read_mdcv(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_TIMECODE_FLAG_ALLOWNEGATIVE
negative time values are allowed
static int mov_read_mdat(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_keys(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_iref_cdsc(MOVContext *c, AVIOContext *pb, uint32_t type, int version)
enum AVColorRange color_range
Additional colorspace characteristics.
#define MOV_TFHD_DEFAULT_SIZE
int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian)
static void fix_stream_ids(AVFormatContext *s)
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest.
static void mov_build_index(MOVContext *mov, AVStream *st)
AVPacketSideData * coded_side_data
Additional data associated with the entire stream.
static int mov_read_svq3(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static MovTref * mov_find_tref_tag(const MOVStreamContext *sc, uint32_t name)
@ AVCOL_RANGE_MPEG
Narrow or limited range content.
void * av_calloc(size_t nmemb, size_t size)
@ AV_IAMF_AUDIO_ELEMENT_TYPE_SCENE
enum AVFieldOrder field_order
The order of the fields in interlaced video.
static int mov_read_iinf(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int64_t ff_read_string_to_bprint_overwrite(AVIOContext *s, struct AVBPrint *bp, int64_t max_len)
Read a whole null-terminated string of text from AVIOContext to an AVBPrint buffer overwriting its co...
int horizontal
Offset in pixels from the left edge of the canvas where the tile should be placed.
static int64_t get_stream_info_time(MOVFragmentStreamInfo *frag_stream_info)
static void fix_index_entry_timestamps(AVStream *st, int end_index, int64_t end_ts, int64_t *frame_duration_buffer, int frame_duration_buffer_size)
Rewrite timestamps of index entries in the range [end_index - frame_duration_buffer_size,...
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
@ AV_TIMECODE_FLAG_DROPFRAME
timecode is drop frame
Undefined Behavior In the C language
AVAmbientViewingEnvironment * ambient
int avcodec_parameters_copy(AVCodecParameters *dst, const AVCodecParameters *src)
Copy the contents of src to dst.
static int mov_read_tmcd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int disposition
Stream disposition - a combination of AV_DISPOSITION_* flags.
int id
Format-specific stream ID.
#define AV_LOG_FATAL
Something went wrong and recovery is not possible.
unsigned int nb_encrypted_samples
static int mov_read_senc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
int height
Height of the final image for presentation.
#define FFSWAP(type, a, b)
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
uint8_t * key_id
The ID of the key used to encrypt the packet.
size_t av_strlcat(char *dst, const char *src, size_t size)
Append the string src to the string dst, but to a total length of no more than size - 1 bytes,...
int32_t pitch
Rotation around the right vector [-90, 90].
AVDictionary * metadata
Metadata that applies to the whole group.
unsigned int avio_rb16(AVIOContext *s)
enum AVStereo3DType type
How views are packed within the video.
static const int16_t cdt2[8]
AVPacketSideData * av_packet_side_data_new(AVPacketSideData **psd, int *pnb_sd, enum AVPacketSideDataType type, size_t size, int flags)
Allocate a new packet side data.
@ AV_AUDIO_SERVICE_TYPE_KARAOKE
static int mov_read_dmlp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_INPUT_BUFFER_PADDING_SIZE
int pseudo_stream_id
-1 means demux all ids
static int mov_read_tfdt(MOVContext *c, AVIOContext *pb, MOVAtom atom)
Tag MUST be and< 10hcoeff half pel interpolation filter coefficients, hcoeff[0] are the 2 middle coefficients[1] are the next outer ones and so on, resulting in a filter like:...eff[2], hcoeff[1], hcoeff[0], hcoeff[0], hcoeff[1], hcoeff[2] ... the sign of the coefficients is not explicitly stored but alternates after each coeff and coeff[0] is positive, so ...,+,-,+,-,+,+,-,+,-,+,... hcoeff[0] is not explicitly stored but found by subtracting the sum of all stored coefficients with signs from 32 hcoeff[0]=32 - hcoeff[1] - hcoeff[2] - ... a good choice for hcoeff and htaps is htaps=6 hcoeff={40,-10, 2} an alternative which requires more computations at both encoder and decoder side and may or may not be better is htaps=8 hcoeff={42,-14, 6,-2}ref_frames minimum of the number of available reference frames and max_ref_frames for example the first frame after a key frame always has ref_frames=1spatial_decomposition_type wavelet type 0 is a 9/7 symmetric compact integer wavelet 1 is a 5/3 symmetric compact integer wavelet others are reserved stored as delta from last, last is reset to 0 if always_reset||keyframeqlog quality(logarithmic quantizer scale) stored as delta from last, last is reset to 0 if always_reset||keyframemv_scale stored as delta from last, last is reset to 0 if always_reset||keyframe FIXME check that everything works fine if this changes between framesqbias dequantization bias stored as delta from last, last is reset to 0 if always_reset||keyframeblock_max_depth maximum depth of the block tree stored as delta from last, last is reset to 0 if always_reset||keyframequant_table quantization tableHighlevel bitstream structure:==============================--------------------------------------------|Header|--------------------------------------------|------------------------------------|||Block0||||split?||||yes no||||......... intra?||||:Block01 :yes no||||:Block02 :....... ..........||||:Block03 ::y DC ::ref index:||||:Block04 ::cb DC ::motion x :||||......... :cr DC ::motion y :||||....... ..........|||------------------------------------||------------------------------------|||Block1|||...|--------------------------------------------|------------ ------------ ------------|||Y subbands||Cb subbands||Cr subbands||||--- ---||--- ---||--- ---|||||LL0||HL0||||LL0||HL0||||LL0||HL0|||||--- ---||--- ---||--- ---||||--- ---||--- ---||--- ---|||||LH0||HH0||||LH0||HH0||||LH0||HH0|||||--- ---||--- ---||--- ---||||--- ---||--- ---||--- ---|||||HL1||LH1||||HL1||LH1||||HL1||LH1|||||--- ---||--- ---||--- ---||||--- ---||--- ---||--- ---|||||HH1||HL2||||HH1||HL2||||HH1||HL2|||||...||...||...|||------------ ------------ ------------|--------------------------------------------Decoding process:=================------------|||Subbands|------------||||------------|Intra DC||||LL0 subband prediction ------------|\ Dequantization ------------------- \||Reference frames|\ IDWT|------- -------|Motion \|||Frame 0||Frame 1||Compensation . OBMC v -------|------- -------|--------------. \------> Frame n output Frame Frame<----------------------------------/|...|------------------- Range Coder:============Binary Range Coder:------------------- The implemented range coder is an adapted version based upon "Range encoding: an algorithm for removing redundancy from a digitised message." by G. N. N. Martin. The symbols encoded by the Snow range coder are bits(0|1). The associated probabilities are not fix but change depending on the symbol mix seen so far. bit seen|new state ---------+----------------------------------------------- 0|256 - state_transition_table[256 - old_state];1|state_transition_table[old_state];state_transition_table={ 0, 0, 0, 0, 0, 0, 0, 0, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, 152, 152, 153, 154, 155, 156, 157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 190, 191, 192, 194, 194, 195, 196, 197, 198, 199, 200, 201, 202, 202, 204, 205, 206, 207, 208, 209, 209, 210, 211, 212, 213, 215, 215, 216, 217, 218, 219, 220, 220, 222, 223, 224, 225, 226, 227, 227, 229, 229, 230, 231, 232, 234, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247, 248, 248, 0, 0, 0, 0, 0, 0, 0};FIXME Range Coding of integers:------------------------- FIXME Neighboring Blocks:===================left and top are set to the respective blocks unless they are outside of the image in which case they are set to the Null block top-left is set to the top left block unless it is outside of the image in which case it is set to the left block if this block has no larger parent block or it is at the left side of its parent block and the top right block is not outside of the image then the top right block is used for top-right else the top-left block is used Null block y, cb, cr are 128 level, ref, mx and my are 0 Motion Vector Prediction:=========================1. the motion vectors of all the neighboring blocks are scaled to compensate for the difference of reference frames scaled_mv=(mv *(256 *(current_reference+1)/(mv.reference+1))+128)> the median of the scaled left
static int heif_add_stream(MOVContext *c, HEIFItem *item)
static int search_frag_moof_offset(MOVFragmentIndex *frag_index, int64_t offset)
#define AV_DICT_MATCH_CASE
Only get an entry with exact-case key match.
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
static int mov_switch_root(AVFormatContext *s, int64_t target, int index)
This describes encryption info for a packet.
MOVEncryptionIndex * encryption_index
#define MIN_DATA_ENTRY_BOX_SIZE
const char * av_get_media_type_string(enum AVMediaType media_type)
Return a string describing the media_type enum, NULL if media_type is unknown.
int index
stream index in AVFormatContext
static int mov_seek_fragment(AVFormatContext *s, AVStream *st, int64_t timestamp)
void ff_configure_buffers_for_index(AVFormatContext *s, int64_t time_tolerance)
static void mov_parse_stsd_video(MOVContext *c, AVIOContext *pb, AVStream *st, MOVStreamContext *sc)
const AVCodecTag ff_codec_bmp_tags[]
int h_spacing
pasp hSpacing
static int mov_read_dec3(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int64_t get_frag_time(AVFormatContext *s, AVStream *dst_st, MOVFragmentIndex *frag_index, int index)
unsigned int sample_size
may contain value calculated from stsd or value from stsz atom
unsigned int nb_streams
Number of elements in AVStreamGroup.streams.
static int mlp_samplerate(int in)
#define ISOM_DVCC_DVVC_SIZE
static int mov_read_sbgp(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AVIO_SEEKABLE_NORMAL
Seeking works like for a local file.
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, size_t size)
Allocate new information of a packet.
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
static int mov_read_glbl(MOVContext *c, AVIOContext *pb, MOVAtom atom)
This function reads atom content and puts data in extradata without tag nor size unlike mov_read_extr...
static int mov_parse_uuid_spherical(MOVStreamContext *sc, AVIOContext *pb, size_t len)
@ AV_OPT_TYPE_INT
Underlying C type is int.
AVFormatContext * dv_fctx
void av_channel_layout_uninit(AVChannelLayout *channel_layout)
Free any allocated data in the channel layout and reset the channel count to 0.
void avformat_free_context(AVFormatContext *s)
Free an AVFormatContext and all its streams.
unsigned int aax_mode
'aax' file has been detected
static int mov_read_sv3d(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
static int mov_aaxc_crypto(MOVContext *c)
static int64_t mov_get_skip_samples(AVStream *st, int sample)
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_WB24 unsigned int_TMPL AV_WB16 unsigned int_TMPL AV_RB8
static int ref[MAX_W *MAX_W]
AVRational r_frame_rate
Real base framerate of the stream.
int64_t track_end
used for dts generation in fragmented movie files
MOVFragment fragment
current fragment in moof atom
int eof_reached
true if was unable to read due to error or eof
static int mov_metadata_int8_bypass_padding(MOVContext *c, AVIOContext *pb, unsigned len, const char *key)
Filter the word “frame” indicates either a video frame or a group of audio samples
static float mean(const float *input, int size)
static int mov_read_covr(MOVContext *c, AVIOContext *pb, int type, int len)
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
unsigned int per_sample_iv_size
const AVCodecTag ff_codec_movsubtitle_tags[]
AVRational av_mul_q(AVRational b, AVRational c)
Multiply two rationals.
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
static void export_orphan_timecode(AVFormatContext *s)
static int mov_read_sbas(MOVContext *c, AVIOContext *pb, MOVAtom atom)
#define AV_CH_FRONT_RIGHT
void av_aes_ctr_crypt(struct AVAESCTR *a, uint8_t *dst, const uint8_t *src, int count)
Process a buffer using a previously initialized context.
static int mov_metadata_gnre(MOVContext *c, AVIOContext *pb, unsigned len, const char *key)
@ AV_PKT_DATA_ENCRYPTION_INFO
This side data contains encryption info for how to decrypt the packet.
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
int av_dict_set_int(AVDictionary **pm, const char *key, int64_t value, int flags)
Convenience wrapper for av_dict_set() that converts the value to a string and stores it.
static int mov_read_dpxe(MOVContext *c, AVIOContext *pb, MOVAtom atom)
unsigned int nb_elements
Number of elements in the submix.
#define AVIO_FLAG_READ
read-only
@ AV_PKT_DATA_AUDIO_SERVICE_TYPE
This side data should be associated with an audio stream and corresponds to enum AVAudioServiceType.
AVSphericalMapping * av_spherical_alloc(size_t *size)
Allocate a AVSphericalVideo structure and initialize its fields to default values.
#define AV_OPT_FLAG_DECODING_PARAM
A generic parameter which can be set by the user for demuxing or decoding.
static int mov_read_rtmd_track(AVFormatContext *s, AVStream *st)
static int read_probe(const AVProbeData *p)
int bits_per_coded_sample
The number of bits per sample in the codedwords.
static int mov_parse_tiles(AVFormatContext *s)
enum AVStreamGroupParamsType type
Group type.
A reference to a data buffer.
static int mov_read_iref_dimg(MOVContext *c, AVIOContext *pb, int version)
static int mov_read_pcmc(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int build_open_gop_key_points(AVStream *st)
static void mov_parse_stsd_audio(MOVContext *c, AVIOContext *pb, AVStream *st, MOVStreamContext *sc)
IAMFMixPresentation ** mix_presentations
int trak_index
Index of the current 'trak'.
static int mov_read_timecode_track(AVFormatContext *s, AVStream *st)
uint32_t bound_left
Distance from the left edge.
static int mov_read_mac_string(MOVContext *c, AVIOContext *pb, int len, char *dst, int dstlen)
uint8_t * auxiliary_info_sizes
int video_delay
Number of delayed frames.
#define avpriv_request_sample(...)
MOVTimeToSample * tts_data
const VDPAUPixFmtMap * map
AVStreamGroup * avformat_stream_group_create(AVFormatContext *s, enum AVStreamGroupParamsType type, AVDictionary **options)
Add a new empty stream group to a media file.
#define AV_CHANNEL_LAYOUT_MONO
int height
Height of the final image for presentation.
enum AVStereo3DView view
Determines which views are packed.
static int read_tfra(MOVContext *mov, AVIOContext *f)
static int mov_read_hvce(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVRational av_add_q(AVRational b, AVRational c)
Add two rationals.
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
@ AV_PKT_DATA_HEVC_CONF
Dolby Vision enhancement-layer HEVC decoder configuration.
AVStereo3DView
List of possible view types.
This structure stores compressed data.
unsigned MaxFALL
Max average light level per frame (cd/m^2).
static int mov_parse_lcevc_streams(AVFormatContext *s)
static int mov_read_hfov(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_OPT_TYPE_BOOL
Underlying C type is int.
unsigned * stps_data
partial sync sample for mpeg-2 open gop
@ AV_CODEC_ID_ADPCM_IMA_WAV
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
int av_dict_copy(AVDictionary **dst, const AVDictionary *src, int flags)
Copy entries from one AVDictionary struct into another.
AVEncryptionInfo * av_encryption_info_alloc(uint32_t subsample_count, uint32_t key_id_size, uint32_t iv_size)
Allocates an AVEncryptionInfo structure and sub-pointers to hold the given number of subsamples.
int64_t pos
byte position in stream, -1 if unknown
AVDictionary * decryption_keys
static int mov_metadata_loci(MOVContext *c, AVIOContext *pb, unsigned len)
static int mov_read_eyes(MOVContext *c, AVIOContext *pb, MOVAtom atom)
@ AV_CHAN_AMBISONIC_BASE
Range of channels between AV_CHAN_AMBISONIC_BASE and AV_CHAN_AMBISONIC_END represent Ambisonic compon...
#define MOV_TRUN_SAMPLE_SIZE
uint32_t tmcd_flags
tmcd track flags
static float distance(float x, float y, int band)
static int parse_timecode_in_framenum_format(AVFormatContext *s, AVStream *st, int64_t value, int flags)
uint8_t tmcd_nb_frames
tmcd number of frames per tick / second
Submix element as defined in section 3.7 of IAMF.
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
int start_pad
amount of samples to skip due to enc-dec delay
AVStereo3DType
List of possible 3D Types.
const FFInputFormat ff_mov_demuxer
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
uint32_t min_sample_duration
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
const struct MP4TrackKindMapping ff_mov_track_kind_table[]
static AVStream * get_curr_st(MOVContext *c)
Get the current stream in the parsing process.
unsigned int stts_allocated_size
static int cenc_decrypt(MOVContext *c, MOVStreamContext *sc, AVEncryptionInfo *sample, uint8_t *input, int size)
#define MKTAG(a, b, c, d)
int ffio_read_size(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
unsigned int sync_group_count
int64_t start_time
Decoding: pts of the first frame of the stream in presentation order, in stream time base.
unsigned int samples_per_frame
unsigned int tts_allocated_size
static int mov_read_ispe(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVRational ambient_light_y
Normalized y chromaticity coordinate of the environmental ambient light in the nominal viewing enviro...
static int mov_read_iref(MOVContext *c, AVIOContext *pb, MOVAtom atom)
AVIAMFMixPresentation * mix
mix backs cmix iff the AVIAMFMixPresentation is owned by this structure.
static int mov_read_clap(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_mfra(MOVContext *c, AVIOContext *f)
static int mov_metadata_int8_no_padding(MOVContext *c, AVIOContext *pb, unsigned len, const char *key)
unsigned int idx
Index of the stream in the group this tile references.
static MOVFragmentStreamInfo * get_frag_stream_info(MOVFragmentIndex *frag_index, int index, int id)
AVCodecParameters * codecpar
static int mov_read_kind(MOVContext *c, AVIOContext *pb, MOVAtom atom)
unsigned int el_index
Index of the enhancement layer stream in AVStreamGroup.
#define MOV_TRUN_SAMPLE_CTS
@ AV_OPT_TYPE_CONST
Special option type for declaring named constants.
#define MOV_ISMV_TTML_TAG
unsigned int mix_presentation_id
int initial_padding
Number of padding audio samples at the start.
static int mov_read_st3d(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_imir(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int is_open_key_sample(const MOVStreamContext *sc, int sample)
static int mov_read_dvc1(MOVContext *c, AVIOContext *pb, MOVAtom atom)
const char * av_color_transfer_name(enum AVColorTransferCharacteristic transfer)
static int64_t mov_read_atom_into_extradata(MOVContext *c, AVIOContext *pb, MOVAtom atom, AVCodecParameters *par, uint8_t *buf)
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_RB64
int32_t yaw
Rotation around the up vector [-180, 180].
static void mov_read_chapters(AVFormatContext *s)
AVEncryptionInfo * default_encrypted_sample
char * av_timecode_make_string(const AVTimecode *tc, char *buf, int framenum_arg)
Load timecode string in buf.
#define AV_DICT_DONT_STRDUP_KEY
Take ownership of a key that's been allocated with av_malloc() or another memory allocation function.
int64_t next_root_atom
offset of the next root atom
int found_iinf
'iinf' atom has been found
uint8_t background[4]
The pixel value per channel in RGBA format used if no pixel of any tile is located at a particular pi...
static int cenc_scheme_decrypt(MOVContext *c, MOVStreamContext *sc, AVEncryptionInfo *sample, uint8_t *input, int size)
static int mov_read_hdlr(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_parse_stsd_data(MOVContext *c, AVIOContext *pb, AVStream *st, MOVStreamContext *sc, int64_t size)
void ff_iamf_read_deinit(IAMFDemuxContext *c)
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_WB24 unsigned int_TMPL AV_RB16
uint8_t * av_encryption_init_info_add_side_data(const AVEncryptionInitInfo *info, size_t *side_data_size)
Allocates and initializes side data that holds a copy of the given encryption init info.
#define av_fourcc2str(fourcc)
int ff_mov_read_chan(AVFormatContext *s, AVIOContext *pb, AVStream *st, int64_t size)
Read 'chan' tag from the input stream.
int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags)
Get the index for a specific timestamp.
static int mov_read_pitm(MOVContext *c, AVIOContext *pb, MOVAtom atom)
static int mov_read_dac3(MOVContext *c, AVIOContext *pb, MOVAtom atom)
int avio_feof(AVIOContext *s)
Similar to feof() but also returns nonzero on read errors.
int ffindex
AVStream index.
static int mov_read_stsz(MOVContext *c, AVIOContext *pb, MOVAtom atom)