769 if ((ret =
avio_seek(pb, last_pos + 1, SEEK_SET)) < 0) {
819 int max_size, uint64_t *number)
832 "Read error at pos. %"PRIu64
" (0x%"PRIx64
")\n",
841 if (read > max_size) {
844 "Invalid EBML number size tag 0x%02x at pos %"PRIu64
" (0x%"PRIx64
")\n",
852 total = (total << 8) |
avio_r8(pb);
868 if (res > 0 && *number + 1 == 1ULL << (7 * res))
869 *number = 0xffffffffffffffULL;
887 *num = (*num << 8) |
avio_r8(pb);
910 *num = ((uint64_t)*num << 8) |
avio_r8(pb);
1027 *num = unum - ((1LL << (7 * res - 1)) - 1);
1036 uint32_t
id,
void *
data)
1039 for (i = 0; syntax[i].
id; i++)
1040 if (
id == syntax[i].
id)
1073 for (i = 0; syntax[i].
id; i++)
1074 switch (syntax[i].
type) {
1076 *(int64_t *) ((
char *) data + syntax[i].
data_offset) = syntax[i].def.
i;
1079 *(uint64_t *) ((
char *) data + syntax[i].data_offset) = syntax[i].
def.
u;
1082 *(
double *) ((
char *) data + syntax[i].
data_offset) = syntax[i].def.
f;
1087 if (syntax[i].def.
s) {
1108 return id && (bits + 7) / 8 == (8 - bits % 8);
1164 uint32_t
id = syntax->
id;
1176 list->
elem = newelem;
1186 if (max_lengths[syntax->
type] && length > max_lengths[syntax->
type]) {
1188 "Invalid length 0x%"PRIx64
" > 0x%"PRIx64
" for syntax element %i\n",
1189 length, max_lengths[syntax->
type], syntax->
type);
1194 switch (syntax->
type) {
1245 for (i = 0; syntax[i].
id; i++) {
1246 void *data_off = (
char *) data + syntax[i].data_offset;
1247 switch (syntax[i].
type) {
1257 if (syntax[i].list_elem_size) {
1259 char *ptr = list->
elem;
1260 for (j = 0; j < list->
nb_elem;
1279 int len_mask = 0x80,
size = 1,
n = 1, i;
1287 while (
size <= 8 && !(total & len_mask)) {
1293 total &= (len_mask - 1);
1295 total = (total << 8) | p->
buf[4 +
n++];
1307 if (total < probelen)
1309 for (
n = 4 +
size;
n <= 4 +
size + total - probelen;
n++)
1325 if (tracks[i].num == num)
1337 int isize = *buf_size;
1340 int pkt_size = isize;
1344 if (pkt_size >= 10000000
U)
1347 switch (encodings[0].compression.algo) {
1353 if (header_size && !header) {
1361 pkt_size = isize + header_size;
1366 memcpy(pkt_data, header, header_size);
1367 memcpy(pkt_data + header_size, data, isize);
1373 olen = pkt_size *= 3;
1379 pkt_data = newpktdata;
1392 z_stream zstream = { 0 };
1393 if (inflateInit(&zstream) != Z_OK)
1395 zstream.next_in =
data;
1396 zstream.avail_in = isize;
1401 inflateEnd(&zstream);
1405 pkt_data = newpktdata;
1406 zstream.avail_out = pkt_size - zstream.total_out;
1407 zstream.next_out = pkt_data + zstream.total_out;
1408 result =
inflate(&zstream, Z_NO_FLUSH);
1409 }
while (result == Z_OK && pkt_size < 10000000);
1410 pkt_size = zstream.total_out;
1411 inflateEnd(&zstream);
1412 if (result != Z_STREAM_END) {
1413 if (result == Z_MEM_ERROR)
1425 bz_stream bzstream = { 0 };
1426 if (BZ2_bzDecompressInit(&bzstream, 0, 0) != BZ_OK)
1428 bzstream.next_in =
data;
1429 bzstream.avail_in = isize;
1434 BZ2_bzDecompressEnd(&bzstream);
1438 pkt_data = newpktdata;
1439 bzstream.avail_out = pkt_size - bzstream.total_out_lo32;
1440 bzstream.next_out = pkt_data + bzstream.total_out_lo32;
1441 result = BZ2_bzDecompress(&bzstream);
1442 }
while (result == BZ_OK && pkt_size < 10000000);
1443 pkt_size = bzstream.total_out_lo32;
1444 BZ2_bzDecompressEnd(&bzstream);
1445 if (result != BZ_STREAM_END) {
1446 if (result == BZ_MEM_ERROR)
1460 *buf_size = pkt_size;
1475 for (i = 0; i < list->
nb_elem; i++) {
1476 const char *lang = tags[i].
lang &&
1477 strcmp(tags[i].lang,
"und") ? tags[i].
lang :
NULL;
1479 if (!tags[i].
name) {
1484 snprintf(key,
sizeof(key),
"%s/%s", prefix, tags[i].name);
1487 if (tags[i].def || !lang) {
1489 if (tags[i].sub.nb_elem)
1496 if (tags[i].sub.nb_elem)
1510 if (tags[i].target.attachuid) {
1514 if (attachment[j].
uid == tags[i].target.attachuid &&
1517 &attachment[j].stream->metadata,
NULL);
1523 "The tags at index %d refer to a "
1524 "non-existent attachment %"PRId64
".\n",
1525 i, tags[i].target.attachuid);
1527 }
else if (tags[i].target.chapteruid) {
1531 if (chapter[j].
uid == tags[i].target.chapteruid &&
1534 &chapter[j].chapter->metadata,
NULL);
1540 "The tags at index %d refer to a non-existent chapter "
1542 i, tags[i].target.chapteruid);
1544 }
else if (tags[i].target.trackuid) {
1548 if (track[j].
uid == tags[i].target.trackuid &&
1551 &track[j].stream->metadata,
NULL);
1557 "The tags at index %d refer to a non-existent track "
1559 i, tags[i].target.trackuid);
1571 uint32_t level_up = matroska->
level_up;
1585 "Max EBML element depth (%d) reached, "
1590 level.
length = (uint64_t) -1;
1595 ret =
ebml_parse(matroska, matroska_segment, matroska);
1600 if (length == (uint64_t) -1)
1622 for (i = 0; i < seekhead_list->
nb_elem; i++) {
1624 uint32_t
id = seekheads[i].
id;
1625 uint64_t pos = seekheads[i].
pos;
1628 if (!elem || elem->
parsed)
1651 uint64_t index_scale = 1;
1657 index_list = &matroska->
index;
1658 index = index_list->
elem;
1661 if (index[1].time > 1E14 / matroska->
time_scale) {
1665 for (i = 0; i < index_list->
nb_elem; i++) {
1668 for (j = 0; j < pos_list->
nb_elem; j++) {
1671 if (track && track->stream)
1674 index[i].
time / index_scale, 0, 0,
1701 static const char *
const aac_profiles[] = {
"MAIN",
"LC",
"SSR" };
1704 for (profile = 0; profile <
FF_ARRAY_ELEMS(aac_profiles); profile++)
1705 if (strstr(codec_id, aac_profiles[profile]))
1747 int block_last, block_type, block_size;
1753 if (block_size > size)
1762 chmask =
av_dict_get(dict,
"WAVEFORMATEXTENSIBLE_CHANNEL_MASK",
NULL, 0);
1765 if (!mask || mask & ~0x3ffffULL) {
1767 "Invalid value of WAVEFORMATEXTENSIBLE_CHANNEL_MASK\n");
1783 int major, minor, micro, bttb = 0;
1787 if (matroska->
muxingapp && sscanf(matroska->
muxingapp,
"Lavf%d.%d.%d", &major, &minor, µ) == 3)
1788 bttb = (major == 57 && minor >= 36 && minor <= 51 && micro >= 100);
1790 switch (field_order) {
1809 int *h_width,
int *h_height)
1811 switch (stereo_mode) {
1836 int has_mastering_primaries, has_mastering_luminance;
1843 has_mastering_primaries =
1844 mastering_meta->
r_x > 0 && mastering_meta->
r_y > 0 &&
1845 mastering_meta->
g_x > 0 && mastering_meta->
g_y > 0 &&
1846 mastering_meta->
b_x > 0 && mastering_meta->
b_y > 0 &&
1848 has_mastering_luminance = mastering_meta->
max_luminance > 0;
1870 if (has_mastering_primaries || has_mastering_luminance) {
1872 const int chroma_den = 50000;
1873 const int luma_den = 10000;
1882 if (has_mastering_primaries) {
1884 round(mastering_meta->
r_x * chroma_den), chroma_den);
1886 round(mastering_meta->
r_y * chroma_den), chroma_den);
1888 round(mastering_meta->
g_x * chroma_den), chroma_den);
1890 round(mastering_meta->
g_y * chroma_den), chroma_den);
1892 round(mastering_meta->
b_x * chroma_den), chroma_den);
1894 round(mastering_meta->
b_y * chroma_den), chroma_den);
1896 round(mastering_meta->
white_x * chroma_den), chroma_den);
1898 round(mastering_meta->
white_y * chroma_den), chroma_den);
1901 if (has_mastering_luminance) {
1915 size_t spherical_size;
1916 uint32_t l = 0, t = 0,
r = 0,
b = 0;
1917 uint32_t padding = 0;
1924 if (bytestream2_get_byte(&gb) != 0) {
1934 t = bytestream2_get_be32(&gb);
1935 b = bytestream2_get_be32(&gb);
1936 l = bytestream2_get_be32(&gb);
1937 r = bytestream2_get_be32(&gb);
1939 if (
b >= UINT_MAX - t ||
r >= UINT_MAX - l) {
1941 "Invalid bounding rectangle coordinates "
1942 "%"PRIu32
",%"PRIu32
",%"PRIu32
",%"PRIu32
"\n",
1951 if (l || t ||
r ||
b)
1961 uint32_t
layout = bytestream2_get_be32(&gb);
1964 "Unknown spherical cubemap layout %"PRIu32
"\n", layout);
1968 padding = bytestream2_get_be32(&gb);
2045 int extradata_size = 0;
2046 int extradata_offset = 0;
2049 char* key_id_base64 =
NULL;
2058 "Unknown or unsupported track type %"PRIu64
"\n",
2068 "Invalid sample rate %f, defaulting to 8000 instead.\n",
2086 if (encodings_list->
nb_elem > 1) {
2088 "Multiple combined encodings not supported");
2089 }
else if (encodings_list->
nb_elem == 1) {
2090 if (encodings[0].
type) {
2091 if (encodings[0].encryption.key_id.size > 0) {
2094 const int b64_size =
AV_BASE64_SIZE(encodings[0].encryption.key_id.size);
2096 if (key_id_base64 ==
NULL)
2100 encodings[0].encryption.key_id.data,
2103 encodings[0].
scope = 0;
2105 "Unsupported encoding type");
2118 encodings[0].
scope = 0;
2120 "Unsupported encoding type");
2130 "Failed to decode codec private data\n");
2152 if (key_id_base64) {
2158 if (!strcmp(track->
codec_id,
"V_MS/VFW/FOURCC") &&
2169 extradata_offset = 40;
2170 }
else if (!strcmp(track->
codec_id,
"A_MS/ACM") &&
2183 }
else if (!strcmp(track->
codec_id,
"A_QUICKTIME")
2187 uint16_t sample_size;
2193 if (sample_size == 8) {
2194 fourcc =
MKTAG(
'r',
'a',
'w',
' ');
2196 }
else if (sample_size == 16) {
2197 fourcc =
MKTAG(
't',
'w',
'o',
's');
2201 if ((fourcc ==
MKTAG(
't',
'w',
'o',
's') ||
2202 fourcc ==
MKTAG(
's',
'o',
'w',
't')) &&
2205 }
else if (!strcmp(track->
codec_id,
"V_QUICKTIME") &&
2212 fourcc =
MKTAG(
'S',
'V',
'Q',
'3');
2261 extradata[0] = (profile << 3) | ((sri & 0x0E) >> 1);
2262 extradata[1] = ((sri & 0x01) << 7) | (track->
audio.
channels << 3);
2263 if (strstr(track->
codec_id,
"SBR")) {
2265 extradata[2] = 0x56;
2266 extradata[3] = 0xE5;
2267 extradata[4] = 0x80 | (sri << 3);
2280 AV_WB32(extradata, extradata_size);
2281 memcpy(&extradata[4],
"alac", 4);
2286 extradata_size = 30;
2297 "Too large audio channel number %"PRIu64
2298 " or bitdepth %"PRIu64
". Skipping track.\n",
2318 extradata_offset = 26;
2354 static const int sipr_bit_rate[4] = { 6504, 8496, 5000, 16000 };
2359 extradata_offset = 78;
2372 "Unknown/unsupported AVCodecID %s.\n", track->
codec_id);
2377 1000 * 1000 * 1000);
2386 if (strcmp(track->language,
"und"))
2390 if (track->flag_default)
2392 if (track->flag_forced)
2399 }
else if (track->codec_priv.data && track->codec_priv.size > 0) {
2403 track->codec_priv.data + extradata_offset,
2404 track->codec_priv.size);
2410 int display_width_mul = 1;
2411 int display_height_mul = 1;
2431 st->
codecpar->
height * track->video.display_width * display_width_mul,
2432 st->
codecpar->
width * track->video.display_height * display_height_mul,
2438 if (track->default_duration) {
2440 1000000000, track->default_duration, 30000);
2441 #if FF_API_R_FRAME_RATE
2453 if (track->video.alpha_mode)
2457 for (j=0; j < track->operation.combine_planes.nb_elem; j++) {
2461 snprintf(buf,
sizeof(buf),
"%s_%d",
2464 if (planes[j].
uid == tracks[k].
uid && tracks[k].stream) {
2466 "stereo_mode", buf, 0);
2472 track->video.stereo_mode != 10 && track->video.stereo_mode != 12) {
2495 if (track->codec_delay > 0) {
2501 if (track->seek_preroll > 0) {
2509 if (!strcmp(track->codec_id,
"D_WEBVTT/CAPTIONS")) {
2511 }
else if (!strcmp(track->codec_id,
"D_WEBVTT/DESCRIPTIONS")) {
2513 }
else if (!strcmp(track->codec_id,
"D_WEBVTT/METADATA")) {
2519 matroska->contains_ssa = 1;
2533 uint64_t max_start = 0;
2548 ebml.
max_size >
sizeof(uint64_t) ||
2552 "EBML version %"PRIu64
", doctype %s, doc version %"PRIu64,
2558 "EBML header using unsupported features\n"
2559 "(EBML version %"PRIu64
", doctype %s, doc version %"PRIu64
")\n",
2576 res =
ebml_parse(matroska, matroska_segments, matroska);
2583 res =
ebml_parse(matroska, matroska_segment, matroska);
2602 attachments = attachments_list->
elem;
2603 for (j = 0; j < attachments_list->
nb_elem; j++) {
2604 if (!(attachments[j].filename && attachments[j].mime &&
2605 attachments[j].bin.data && attachments[j].
bin.
size > 0)) {
2623 attachments[j].
stream = st;
2653 chapters = chapters_list->
elem;
2654 for (i = 0; i < chapters_list->
nb_elem; i++)
2656 (max_start == 0 || chapters[i].
start > max_start)) {
2660 chapters[i].
start, chapters[i].
end,
2662 if (chapters[i].chapter) {
2664 "title", chapters[i].
title, 0);
2666 max_start = chapters[i].
start;
2709 matroska->
packets = newpackets;
2739 int *buf_size,
int type,
2740 uint32_t **lace_buf,
int *laces)
2742 int res = 0,
n,
size = *buf_size;
2744 uint32_t *lace_size;
2752 *lace_buf[0] =
size;
2760 lace_size =
av_mallocz(*laces *
sizeof(
int));
2769 for (
n = 0; res == 0 &&
n < *laces - 1;
n++) {
2771 if (size <= total) {
2777 lace_size[
n] +=
temp;
2784 if (size <= total) {
2789 lace_size[
n] = size - total;
2794 if (size % (*laces)) {
2798 for (
n = 0;
n < *laces;
n++)
2799 lace_size[
n] = size / *laces;
2807 if (n < 0 || num > INT_MAX) {
2809 "EBML block data error\n");
2815 total = lace_size[0] = num;
2816 for (
n = 1; res == 0 &&
n < *laces - 1;
n++) {
2820 if (r < 0 || lace_size[
n - 1] + snum > (uint64_t)INT_MAX) {
2822 "EBML block data error\n");
2828 lace_size[
n] = lace_size[
n - 1] + snum;
2829 total += lace_size[
n];
2831 if (size <= total) {
2835 lace_size[*laces - 1] = size - total;
2841 *lace_buf = lace_size;
2864 if (size < cfs * h / 2) {
2866 "Corrupt int4 RM-style audio packet size\n");
2869 for (x = 0; x < h / 2; x++)
2870 memcpy(track->
audio.
buf + x * 2 * w + y * cfs,
2871 data + x * cfs, cfs);
2875 "Corrupt sipr RM-style audio packet size\n");
2878 memcpy(track->
audio.
buf + y * w, data, w);
2880 if (size < sps * w / sps || h<=0 || w%sps) {
2882 "Corrupt generic RM-style audio packet size\n");
2885 for (x = 0; x < w / sps; x++)
2887 sps * (h * x + ((h + 1) / 2) * (y & 1) + (y >> 1)),
2888 data + x * sps, sps);
2934 if (srclen < 12 || track->stream->codecpar->extradata_size < 2)
2943 while (srclen >= 8) {
2949 uint32_t crc =
AV_RL32(src + 4);
2953 multiblock = (flags & 0x1800) != 0x1800;
2965 if (blocksize > srclen) {
2970 tmp =
av_realloc(dst, dstlen + blocksize + 32);
2976 dstlen += blocksize + 32;
2979 AV_WL32(dst + offset + 4, blocksize + 24);
2980 AV_WL16(dst + offset + 8, ver);
2981 AV_WL16(dst + offset + 10, 0);
2982 AV_WL32(dst + offset + 12, 0);
2983 AV_WL32(dst + offset + 16, 0);
2984 AV_WL32(dst + offset + 20, samples);
2985 AV_WL32(dst + offset + 24, flags);
2986 AV_WL32(dst + offset + 28, crc);
2987 memcpy(dst + offset + 32, src, blocksize);
2990 srclen -= blocksize;
2991 offset += blocksize + 32;
3014 int id_len, settings_len, text_len;
3022 q = data + data_len;
3027 if (*p ==
'\r' || *p ==
'\n') {
3036 if (p >= q || *p !=
'\n')
3043 if (*p ==
'\r' || *p ==
'\n') {
3044 settings_len = p - settings;
3052 if (p >= q || *p !=
'\n')
3058 while (text_len > 0) {
3059 const int len = text_len - 1;
3061 if (c !=
'\r' && c !=
'\n')
3078 memcpy(pkt->
data, text, text_len);
3088 memcpy(buf,
id, id_len);
3091 if (settings_len > 0) {
3099 memcpy(buf, settings, settings_len);
3106 pkt->
pts = timecode;
3123 uint64_t timecode, uint64_t lace_duration,
3125 uint8_t *additional, uint64_t additional_id,
int additional_size,
3126 int64_t discard_padding)
3133 if (encodings && !encodings->
type && encodings->
scope & 1) {
3144 "Error parsing a wavpack block.\n");
3147 if (pkt_data != data)
3158 if (pkt_data != data)
3171 bytestream_put_be32(&buf, pkt_size);
3172 bytestream_put_be32(&buf,
MKBETAG(
'i',
'c',
'p',
'f'));
3175 memcpy(pkt->
data + offset, pkt_data, pkt_size);
3177 if (pkt_data != data)
3183 if (additional_size > 0) {
3186 additional_size + 8);
3192 AV_WB64(side_data, additional_id);
3193 memcpy(side_data + 8, additional, additional_size);
3196 if (discard_padding) {
3208 if (discard_padding > 0) {
3209 AV_WL32(side_data + 4, discard_padding);
3211 AV_WL32(side_data, -discard_padding);
3216 pkt->
dts = timecode;
3218 pkt->
pts = timecode;
3222 #if FF_API_CONVERGENCE_DURATION
3236 if (pkt_data != data)
3242 int size, int64_t pos, uint64_t cluster_time,
3244 uint8_t *additional, uint64_t additional_id,
int additional_size,
3245 int64_t cluster_pos, int64_t discard_padding)
3252 uint32_t *lace_size =
NULL;
3255 int trust_default_duration = 1;
3265 if (!track || !track->
stream) {
3267 "Invalid stream %"PRIu64
" or size %u\n", num, size);
3269 }
else if (size <= 3)
3280 if (is_keyframe == -1)
3283 if (cluster_time != (uint64_t) -1 &&
3284 (block_time >= 0 || cluster_time >= -block_time)) {
3287 timecode < track->end_timecode)
3312 &lace_size, &laces);
3321 trust_default_duration = 0;
3325 if (!block_duration && trust_default_duration)
3328 if (cluster_time != (uint64_t)-1 && (block_time >= 0 || cluster_time >= -block_time))
3332 for (n = 0; n < laces; n++) {
3333 int64_t lace_duration = block_duration*(n+1) / laces - block_duration*n / laces;
3335 if (lace_size[n] > size) {
3354 timecode, lace_duration,
3360 timecode, lace_duration, pos,
3361 !n ? is_keyframe : 0,
3362 additional, additional_id, additional_size,
3369 timecode = lace_duration ? timecode + lace_duration :
AV_NOPTS_VALUE;
3370 data += lace_size[
n];
3371 size -= lace_size[
n];
3385 matroska_cluster_incremental_parsing,
3400 matroska_clusters_incremental,
3405 matroska_cluster_incremental_parsing,
3413 blocks = blocks_list->
elem;
3417 if (blocks[i].bin.size > 0 && blocks[i].
bin.
data) {
3421 if (!blocks[i].non_simple)
3451 res =
ebml_parse(matroska, matroska_clusters, &cluster);
3452 blocks_list = &cluster.
blocks;
3453 blocks = blocks_list->
elem;
3454 for (i = 0; i < blocks_list->
nb_elem; i++)
3455 if (blocks[i].bin.size > 0 && blocks[i].
bin.
data) {
3460 is_keyframe,
NULL, 0, 0, pos,
3484 int64_t timestamp,
int flags)
3489 int i,
index, index_min;
3586 for (i = 1; i < nb_index_entries; i++) {
3587 if (index_entries[i - 1].timestamp * matroska->
time_scale <= ts &&
3595 if (i != nb_index_entries - 1) {
3611 int64_t cluster_pos, before_pos;
3616 if (index < 0)
return 0;
3620 int64_t cluster_id = 0, cluster_length = 0;
3626 if (cluster_id != 0xF43B675) {
3637 cluster_pos += cluster_length + 12;
3648 double min_buffer,
double*
buffer,
3652 double nano_seconds_per_second = 1000000000.0;
3653 double time_sec = time_ns / nano_seconds_per_second;
3655 int64_t time_to_search_ns = (int64_t)(search_sec * nano_seconds_per_second);
3656 int64_t end_time_ns = time_ns + time_to_search_ns;
3657 double sec_downloaded = 0.0;
3661 *sec_to_download = 0.0;
3665 int64_t cue_nano = desc_curr.
end_time_ns - time_ns;
3668 double timeToDownload = (cueBytes * 8.0) /
bps;
3670 sec_downloaded += (cue_nano / nano_seconds_per_second) - timeToDownload;
3671 *sec_to_download += timeToDownload;
3675 double desc_end_time_sec = desc_curr.
end_time_ns / nano_seconds_per_second;
3676 double percent_to_sub = search_sec / (desc_end_time_sec - time_sec);
3677 sec_downloaded = percent_to_sub * sec_downloaded;
3678 *sec_to_download = percent_to_sub * *sec_to_download;
3681 if ((sec_downloaded + *buffer) <= min_buffer) {
3692 double desc_sec = desc_ns / nano_seconds_per_second;
3693 double bits = (desc_bytes * 8.0);
3694 double time_to_download = bits /
bps;
3696 sec_downloaded += desc_sec - time_to_download;
3697 *sec_to_download += time_to_download;
3700 double desc_end_time_sec = desc_curr.
end_time_ns / nano_seconds_per_second;
3701 double percent_to_sub = search_sec / (desc_end_time_sec - time_sec);
3702 sec_downloaded = percent_to_sub * sec_downloaded;
3703 *sec_to_download = percent_to_sub * *sec_to_download;
3705 if ((sec_downloaded + *buffer) <= min_buffer)
3710 if ((sec_downloaded + *buffer) <= min_buffer) {
3717 *buffer = *buffer + sec_downloaded;
3732 double bandwidth = 0.0;
3736 int64_t prebuffer_ns = 1000000000;
3738 double nano_seconds_per_second = 1000000000.0;
3739 int64_t prebuffered_ns = time_ns + prebuffer_ns;
3740 double prebuffer_bytes = 0.0;
3741 int64_t temp_prebuffer_ns = prebuffer_ns;
3742 int64_t pre_bytes, pre_ns;
3743 double pre_sec, prebuffer, bits_per_second;
3761 bits_per_second = 0.0;
3767 pre_sec = pre_ns / nano_seconds_per_second;
3769 pre_bytes * ((temp_prebuffer_ns / nano_seconds_per_second) / pre_sec);
3771 prebuffer = prebuffer_ns / nano_seconds_per_second;
3774 bits_per_second = 0.0;
3778 double desc_sec = desc_ns / nano_seconds_per_second;
3779 double calc_bits_per_second = (desc_bytes * 8) / desc_sec;
3782 double percent = (desc_bytes - prebuffer_bytes) / desc_bytes;
3783 double mod_bits_per_second = calc_bits_per_second * percent;
3785 if (prebuffer < desc_sec) {
3791 int64_t
bps = (int64_t)(mod_bits_per_second) + 1;
3792 const double min_buffer = 0.0;
3793 double buffer = prebuffer;
3794 double sec_to_download = 0.0;
3797 min_buffer, &buffer, &sec_to_download,
3801 }
else if (rv == 0) {
3802 bits_per_second = (double)(bps);
3810 if (bandwidth < bits_per_second) bandwidth = bits_per_second;
3812 return (int64_t)bandwidth;
3821 int64_t cues_start = -1, cues_end = -1, before_pos, bandwidth;
3825 for (i = 0; i < seekhead_list->
nb_elem; i++)
3829 if (i >= seekhead_list->
nb_elem)
return -1;
3833 if (
avio_seek(matroska->
ctx->
pb, cues_start, SEEK_SET) == cues_start) {
3837 uint64_t cues_length = 0, cues_id = 0, bytes_read = 0;
3840 cues_end = cues_start + cues_length + bytes_read - 1;
3843 if (cues_start == -1 || cues_end == -1)
return -1;
3856 if (bandwidth < 0)
return -1;
3865 if (!buf)
return -1;
3868 snprintf(buf, (i + 1) * 20 *
sizeof(
char),
3871 strncat(buf,
",",
sizeof(
char));
3897 if (!buf)
return AVERROR(ENOMEM);
3923 #define OFFSET(x) offsetof(MatroskaDemuxContext, x)
3937 .
name =
"matroska,webm",
3939 .extensions =
"mkv,mk3d,mka,mks",
3946 .mime_type =
"audio/webm,audio/x-matroska,video/webm,video/x-matroska"
3950 .
name =
"webm_dash_manifest",
3956 .priv_class = &webm_dash_class,
int32_t pitch
Rotation around the right vector [-90, 90].
#define MATROSKA_ID_SEEKPREROLL
#define MATROSKA_ID_VIDEOPROJECTIONPOSEYAW
AVSphericalMapping * av_spherical_alloc(size_t *size)
Allocate a AVSphericalVideo structure and initialize its fields to default values.
uint64_t codec_delay_in_track_tb
enum AVChromaLocation chroma_location
#define MATROSKA_ID_BLOCKADDID
#define MATROSKA_ID_TRACKDEFAULTDURATION
enum AVFieldOrder field_order
Video only.
void avio_wl16(AVIOContext *s, unsigned int val)
static int matroska_parse_rm_audio(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVStream *st, uint8_t *data, int size, uint64_t timecode, int64_t pos)
enum AVColorTransferCharacteristic color_trc
#define MATROSKA_ID_VIDEOFLAGINTERLACED
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
#define MATROSKA_ID_VIDEOCOLOR_GX
static const EbmlSyntax matroska_blockgroup[]
const char *const ff_matroska_video_stereo_plane[MATROSKA_VIDEO_STEREO_PLANE_COUNT]
static const EbmlSyntax matroska_simpletag[]
static void matroska_convert_tags(AVFormatContext *s)
#define MATROSKA_ID_DATEUTC
The optional first identifier line of a WebVTT cue.
static const EbmlSyntax matroska_tracks[]
#define MATROSKA_ID_TRACKFLAGLACING
static int webm_dash_manifest_read_packet(AVFormatContext *s, AVPacket *pkt)
#define MATROSKA_ID_TRACKENTRY
static int matroska_deliver_packet(MatroskaDemuxContext *matroska, AVPacket *pkt)
#define MATROSKA_ID_VIDEODISPLAYHEIGHT
void * av_realloc(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory.
AVInputFormat ff_matroska_demuxer
ptrdiff_t const GLvoid * data
static int is_keyframe(NalUnitType naltype)
int av_add_index_entry(AVStream *st, int64_t pos, int64_t timestamp, int size, int distance, int flags)
Add an index entry into a sorted list.
#define MATROSKA_ID_VIDEOPROJECTIONPOSEROLL
static const EbmlSyntax matroska_info[]
#define MATROSKA_ID_CUETRACKPOSITION
#define MATROSKA_ID_CODECPRIVATE
const unsigned char ff_sipr_subpk_size[4]
#define MATROSKA_ID_TAGTARGETS_TYPE
#define AV_LOG_WARNING
Something somehow does not look correct.
static int ebml_level_end(MatroskaDemuxContext *matroska)
#define LIBAVUTIL_VERSION_INT
#define INITIALIZATION_RANGE
int64_t pos
byte position in stream, -1 if unknown
static int matroska_ebmlnum_sint(MatroskaDemuxContext *matroska, uint8_t *data, uint32_t size, int64_t *num)
static int webm_clusters_start_with_keyframe(AVFormatContext *s)
static const EbmlSyntax matroska_tagtargets[]
#define MATROSKA_ID_ENCODINGTYPE
#define MATROSKA_ID_AUDIOBITDEPTH
static const EbmlSyntax matroska_track_video[]
static av_always_inline float av_int2float(uint32_t i)
Reinterpret a 32-bit integer as a float.
#define MATROSKA_ID_TRACKFLAGDEFAULT
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
MatroskaCluster current_cluster
Video represents a portion of a sphere mapped on a flat surface using equirectangular projection...
static int matroska_parse_frame(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVStream *st, uint8_t *data, int pkt_size, uint64_t timecode, uint64_t lace_duration, int64_t pos, int is_keyframe, uint8_t *additional, uint64_t additional_id, int additional_size, int64_t discard_padding)
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
#define MATROSKA_ID_TAGTARGETS_ATTACHUID
int index
stream index in AVFormatContext
#define MATROSKA_ID_CLUSTERPOSITION
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
#define MATROSKA_ID_FILEDATA
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
MatroskaTrackVideoProjection projection
#define EBML_ID_DOCTYPEREADVERSION
#define MATROSKA_ID_BLOCKREFERENCE
#define MATROSKA_ID_TRACKTYPE
int current_cluster_num_blocks
#define MATROSKA_ID_TAGTARGETS_CHAPTERUID
static av_always_inline void bytestream2_init(GetByteContext *g, const uint8_t *buf, int buf_size)
#define MATROSKA_ID_VIDEOCOLOR_RX
Video represents a sphere mapped on a flat surface using equirectangular projection.
void av_fast_padded_malloc(void *ptr, unsigned int *size, size_t min_size)
Same behaviour av_fast_malloc but the buffer has additional AV_INPUT_BUFFER_PADDING_SIZE at the end w...
#define MATROSKA_ID_VIDEOASPECTRATIO
static const EbmlSyntax matroska_track_encodings[]
uint64_t chroma_siting_vert
#define MATROSKA_ID_MUXINGAPP
#define MATROSKA_ID_AUDIOCHANNELS
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
#define MATROSKA_ID_VIDEOPROJECTIONTYPE
MatroskaLevel levels[EBML_MAX_DEPTH]
#define MATROSKA_ID_CUECLUSTERPOSITION
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX
unsigned int avio_rb16(AVIOContext *s)
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
#define MATROSKA_ID_VIDEOCOLORCHROMASITINGHORZ
const struct EbmlSyntax * n
#define MATROSKA_ID_EDITIONFLAGDEFAULT
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_RL16
#define MATROSKA_ID_CLUSTERTIMECODE
#define MATROSKA_ID_ENCODINGENCALGO
#define MATROSKA_ID_CHAPTERTIMEEND
enum AVColorSpace color_space
static const EbmlSyntax matroska_track_plane[]
#define MATROSKA_ID_TRACKCONTENTENCODINGS
int frame_size
Audio only.
Mastering display metadata (based on SMPTE-2086:2014).
#define AV_LZO_OUTPUT_FULL
decoded data did not fit into output buffer
#define MATROSKA_ID_FILEDESC
#define MATROSKA_ID_TRACKCONTENTENCODING
static const EbmlSyntax matroska_cluster[]
#define MATROSKA_ID_CODECDOWNLOADURL
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
static int webm_dash_manifest_read_header(AVFormatContext *s)
static int ebml_read_sint(AVIOContext *pb, int size, int64_t *num)
#define av_assert0(cond)
assert() equivalent, that is always enabled.
int avpriv_dict_set_timestamp(AVDictionary **dict, const char *key, int64_t timestamp)
Set a dictionary value to an ISO-8601 compliant timestamp string.
int ffio_limit(AVIOContext *s, int size)
static const EbmlSyntax matroska_chapters[]
static MatroskaLevel1Element * matroska_find_level1_elem(MatroskaDemuxContext *matroska, uint32_t id)
void avio_wl32(AVIOContext *s, unsigned int val)
uint64_t bits_per_channel
static av_always_inline double av_int2double(uint64_t i)
Reinterpret a 64-bit integer as a double.
#define MATROSKA_ID_VIDEOCOLOR_BX
#define MATROSKA_ID_CHAPLANG
MatroskaTrackOperation operation
#define MATROSKA_ID_EDITIONFLAGORDERED
static const EbmlSyntax matroska_track_video_projection[]
static CueDesc get_cue_desc(AVFormatContext *s, int64_t ts, int64_t cues_start)
#define MATROSKA_ID_TRACKLANGUAGE
MatroskaTrackCompression compression
static int webm_dash_manifest_cues(AVFormatContext *s)
const AVCodecTag ff_codec_movvideo_tags[]
unsigned int avio_rb32(AVIOContext *s)
int ff_mkv_stereo3d_conv(AVStream *st, MatroskaVideoStereoModeType stereo_mode)
static av_cold int end(AVCodecContext *avctx)
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
#define MATROSKA_ID_VIDEOPIXELCROPT
static const EbmlSyntax matroska_track_video_color[]
#define MATROSKA_ID_TIMECODESCALE
static int matroska_aac_sri(int samplerate)
enum AVStreamParseType need_parsing
#define MATROSKA_ID_VIDEOCOLORCBSUBVERT
#define MATROSKA_ID_SIMPLEBLOCK
#define MATROSKA_ID_TAGTARGETS_TYPEVALUE
#define MATROSKA_ID_EDITIONFLAGHIDDEN
#define AV_LZO_OUTPUT_PADDING
static const EbmlSyntax matroska_segment[]
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
#define MATROSKA_ID_CODECNAME
#define MATROSKA_ID_BLOCKMORE
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
AVStream ** streams
A list of all streams in the file.
#define MATROSKA_ID_CUERELATIVEPOSITION
#define MATROSKA_ID_AUDIOOUTSAMPLINGFREQ
#define MATROSKA_ID_VIDEOCOLOR
int initial_padding
Audio only.
static const EbmlSyntax matroska_segments[]
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
int flags
Flags modifying the (de)muxer behaviour.
static int matroska_parse_cluster_incremental(MatroskaDemuxContext *matroska)
static void inflate(uint8_t *dst, const uint8_t *p1, int width, int threshold, const uint8_t *coordinates[], int coord)
#define MATROSKA_ID_VIDEODISPLAYWIDTH
#define MATROSKA_ID_EDITIONUID
int ff_vorbis_comment(AVFormatContext *ms, AVDictionary **m, const uint8_t *buf, int size, int parse_picture)
#define MATROSKA_ID_BLOCKADDITIONS
static const EbmlSyntax matroska_index[]
#define AVERROR_EOF
End of file.
#define MATROSKA_ID_CODECDECODEALL
#define MATROSKA_ID_ENCODINGENCRYPTION
static av_cold int read_close(AVFormatContext *ctx)
static int mkv_parse_video_color(AVStream *st, const MatroskaTrack *track)
uint64_t avio_rb64(AVIOContext *s)
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
static const uint8_t header[24]
#define MATROSKA_ID_TRACKNUMBER
#define MATROSKA_ID_VIDEOCOLOR_WHITEY
void avio_write(AVIOContext *s, const unsigned char *buf, int size)
void * av_realloc_array(void *ptr, size_t nmemb, size_t size)
#define MATROSKA_ID_SEGMENTUID
uint64_t channel_layout
Audio only.
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian)
static int matroska_parse_seekhead_entry(MatroskaDemuxContext *matroska, uint64_t pos)
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
static int matroska_parse_cluster(MatroskaDemuxContext *matroska)
static int ebml_parse_nest(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, void *data)
#define MATROSKA_ID_CUEBLOCKNUMBER
#define MATROSKA_ID_TRACKUID
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
#define MATROSKA_ID_ENCODINGORDER
#define MATROSKA_ID_VIDEOSTEREOMODE
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values.
AVCodecID
Identify the syntax and semantics of the bitstream.
#define MATROSKA_ID_VIDEOCOLOR_BY
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
AVDictionary * metadata
Metadata that applies to the whole file.
#define MATROSKA_ID_BLOCKDURATION
An AV_PKT_DATA_PALETTE side data packet contains exactly AVPALETTE_SIZE bytes worth of palette...
#define EBML_ID_EBMLREADVERSION
int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags)
Get the index for a specific timestamp.
#define MATROSKA_ID_VIDEOCOLORMAXCLL
MatroskaMasteringMeta mastering_meta
#define MATROSKA_ID_VIDEOCOLOR_WHITEX
static const uint16_t mask[17]
FLAC (Free Lossless Audio Codec) decoder/demuxer common functions.
static int ebml_read_length(MatroskaDemuxContext *matroska, AVIOContext *pb, uint64_t *number)
Read a EBML length value.
static av_always_inline void bytestream2_skip(GetByteContext *g, unsigned int size)
int64_t timestamp
Timestamp in AVStream.time_base units, preferably the time from which on correctly decoded frames are...
#define MATROSKA_ID_CLUSTER
#define MATROSKA_ID_VIDEOCOLORCHROMASITINGVERT
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...