FFmpeg
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
matroskadec.c
Go to the documentation of this file.
1 /*
2  * Matroska file demuxer
3  * Copyright (c) 2003-2008 The FFmpeg Project
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 /**
23  * @file
24  * Matroska file demuxer
25  * @author Ronald Bultje <rbultje@ronald.bitfreak.net>
26  * @author with a little help from Moritz Bunkus <moritz@bunkus.org>
27  * @author totally reworked by Aurelien Jacobs <aurel@gnuage.org>
28  * @see specs available on the Matroska project page: http://www.matroska.org/
29  */
30 
31 #include "config.h"
32 #include "config_components.h"
33 
34 #include <inttypes.h>
35 #include <stdio.h>
36 
37 #include "libavutil/avstring.h"
38 #include "libavutil/base64.h"
39 #include "libavutil/bprint.h"
40 #include "libavutil/dict.h"
41 #include "libavutil/display.h"
43 #include "libavutil/intfloat.h"
44 #include "libavutil/intreadwrite.h"
45 #include "libavutil/lzo.h"
47 #include "libavutil/mathematics.h"
48 #include "libavutil/mem.h"
49 #include "libavutil/opt.h"
50 #include "libavutil/pixdesc.h"
52 #include "libavutil/spherical.h"
53 
54 #include "libavcodec/bytestream.h"
55 #include "libavcodec/defs.h"
56 #include "libavcodec/flac.h"
57 #include "libavcodec/itut35.h"
58 #include "libavcodec/mpeg4audio.h"
60 
61 #include "avformat.h"
62 #include "avio_internal.h"
63 #include "demux.h"
64 #include "dovi_isom.h"
65 #include "internal.h"
66 #include "isom.h"
67 #include "matroska.h"
68 #include "oggdec.h"
69 /* For ff_codec_get_id(). */
70 #include "riff.h"
71 #include "rmsipr.h"
72 
73 #if CONFIG_BZLIB
74 #include <bzlib.h>
75 #endif
76 #if CONFIG_ZLIB
77 #include <zlib.h>
78 #endif
79 
80 #include "qtpalette.h"
81 
82 #define EBML_UNKNOWN_LENGTH UINT64_MAX /* EBML unknown length, in uint64_t */
83 #define NEEDS_CHECKING 2 /* Indicates that some error checks
84  * still need to be performed */
85 #define LEVEL_ENDED 3 /* return value of ebml_parse when the
86  * syntax level used for parsing ended. */
87 #define SKIP_THRESHOLD 1024 * 1024 /* In non-seekable mode, if more than SKIP_THRESHOLD
88  * of unkown, potentially damaged data is encountered,
89  * it is considered an error. */
90 #define UNKNOWN_EQUIV 50 * 1024 /* An unknown element is considered equivalent
91  * to this many bytes of unknown data for the
92  * SKIP_THRESHOLD check. */
93 
94 typedef enum {
100  EBML_UTF8,
101  EBML_BIN,
103  EBML_LEVEL1,
107 
108 typedef struct CountedElement {
109  union {
110  uint64_t u;
111  int64_t i;
112  double f;
113  char *s;
114  } el;
115  unsigned count;
117 
118 typedef const struct EbmlSyntax {
119  uint32_t id;
120  uint8_t type;
121  uint8_t is_counted;
123  size_t data_offset;
124  union {
125  int64_t i;
126  uint64_t u;
127  double f;
128  const char *s;
129  const struct EbmlSyntax *n;
130  } def;
131 } EbmlSyntax;
132 
133 typedef struct EbmlList {
134  int nb_elem;
135  unsigned int alloc_elem_size;
136  void *elem;
138 
139 typedef struct EbmlBin {
140  int size;
142  uint8_t *data;
145 
146 typedef struct Ebml {
147  uint64_t version;
148  uint64_t max_size;
149  uint64_t id_length;
150  char *doctype;
151  uint64_t doctype_version;
152 } Ebml;
153 
154 typedef struct MatroskaTrackCompression {
155  uint64_t algo;
158 
159 typedef struct MatroskaTrackEncryption {
160  uint64_t algo;
163 
164 typedef struct MatroskaTrackEncoding {
165  uint64_t scope;
166  uint64_t type;
170 
171 typedef struct MatroskaMasteringMeta {
172  double r_x;
173  double r_y;
174  double g_x;
175  double g_y;
176  double b_x;
177  double b_y;
178  double white_x;
179  double white_y;
183 
184 typedef struct MatroskaTrackVideoColor {
187  uint64_t chroma_sub_horz;
188  uint64_t chroma_sub_vert;
189  uint64_t cb_sub_horz;
190  uint64_t cb_sub_vert;
193  uint64_t range;
194  uint64_t transfer_characteristics;
195  uint64_t primaries;
196  uint64_t max_cll;
197  uint64_t max_fall;
200 
201 typedef struct MatroskaTrackVideoProjection {
202  uint64_t type;
203  EbmlBin private;
204  double yaw;
205  double pitch;
206  double roll;
208 
209 typedef struct MatroskaTrackVideo {
210  double frame_rate;
211  uint64_t display_width;
212  uint64_t display_height;
213  uint64_t pixel_width;
214  uint64_t pixel_height;
215  uint64_t cropped_width;
216  uint64_t cropped_height;
218  uint64_t pixel_cropt;
219  uint64_t pixel_cropl;
220  uint64_t pixel_cropb;
221  uint64_t pixel_cropr;
222  uint64_t display_unit;
223  uint64_t interlaced;
224  uint64_t field_order;
225  uint64_t stereo_mode;
226  uint64_t alpha_mode;
230 
231 typedef struct MatroskaTrackAudio {
232  double samplerate;
234  uint64_t bitdepth;
235  uint64_t channels;
236 
237  /* real audio header (extracted from extradata) */
240  int frame_size;
241  int sub_packet_size;
243  int pkt_cnt;
244  uint64_t buf_timecode;
245  uint8_t *buf;
247 
248 typedef struct MatroskaTrackPlane {
249  uint64_t uid;
250  uint64_t type;
252 
253 typedef struct MatroskaTrackOperation {
256 
257 typedef struct MatroskaBlockAdditionMapping {
258  uint64_t value;
259  char *name;
260  uint64_t type;
263 
264 typedef struct MatroskaTrack {
265  uint64_t num;
266  uint64_t uid;
267  uint64_t type;
268  char *name;
269  char *codec_id;
271  char *language;
272  double time_scale;
274  uint64_t flag_default;
275  uint64_t flag_forced;
276  uint64_t flag_comment;
281  uint64_t seek_preroll;
286  uint64_t codec_delay;
288 
289  AVStream *stream;
292  int needs_decoding;
293  uint64_t max_block_additional_id;
295 
299 
300 typedef struct MatroskaAttachment {
301  uint64_t uid;
302  char *filename;
303  char *description;
304  char *mime;
306 
309 
310 typedef struct MatroskaChapter {
311  uint64_t start;
312  uint64_t end;
313  uint64_t uid;
314  char *title;
315 
318 
319 typedef struct MatroskaIndexPos {
320  uint64_t track;
321  uint64_t pos;
323 
324 typedef struct MatroskaIndex {
325  uint64_t time;
328 
329 typedef struct MatroskaTag {
330  char *name;
331  char *string;
332  char *lang;
333  uint64_t def;
336 
337 typedef struct MatroskaTagTarget {
338  char *type;
339  uint64_t typevalue;
340  uint64_t trackuid;
341  uint64_t chapteruid;
342  uint64_t attachuid;
344 
345 typedef struct MatroskaTags {
347  EbmlList tag;
348 } MatroskaTags;
349 
350 typedef struct MatroskaSeekhead {
351  uint64_t id;
352  uint64_t pos;
354 
355 typedef struct MatroskaLevel {
356  uint64_t start;
357  uint64_t length;
358 } MatroskaLevel;
359 
360 typedef struct MatroskaBlockMore {
361  uint64_t additional_id;
364 
365 typedef struct MatroskaBlock {
366  uint64_t duration;
368  uint64_t non_simple;
372 } MatroskaBlock;
373 
374 typedef struct MatroskaCluster {
376  uint64_t timecode;
379 
380 typedef struct MatroskaLevel1Element {
382  uint32_t id;
383  int parsed;
385 
386 typedef struct MatroskaDemuxContext {
387  const AVClass *class;
389 
390  /* EBML stuff */
393  uint32_t current_id;
396 
397  uint64_t time_scale;
398  double duration;
399  char *title;
400  char *muxingapp;
405  EbmlList index;
406  EbmlList tags;
408 
409  /* byte position of the segment inside the stream */
411 
412  /* This packet coincides with FFFormatContext.parse_pkt
413  * and is not owned by us. */
414  AVPacket *pkt;
415 
416  /* the packet queue */
418 
419  int done;
420 
421  /* What to skip before effectively reading a packet. */
422  int skip_to_keyframe;
424 
425  /* File has a CUES element, but we defer parsing until it is needed. */
427 
428  /* Level1 elements and whether they were read yet */
430  int num_level1_elems;
431 
433 
434  int is_webm;
435 
436  /* WebM DASH Manifest live flag */
437  int is_live;
438 
439  /* Bandwidth value for WebM DASH Manifest */
440  int bandwidth;
442 
443 #define CHILD_OF(parent) { .def = { .n = parent } }
444 
445 // The following forward declarations need their size because
446 // a tentative definition with internal linkage must not be an
447 // incomplete type (6.7.2 in C90, 6.9.2 in C99).
448 // Removing the sizes breaks MSVC.
455 
456 static EbmlSyntax ebml_header[] = {
457  { EBML_ID_EBMLREADVERSION, EBML_UINT, 0, 0, offsetof(Ebml, version), { .u = EBML_VERSION } },
458  { EBML_ID_EBMLMAXSIZELENGTH, EBML_UINT, 0, 0, offsetof(Ebml, max_size), { .u = 8 } },
459  { EBML_ID_EBMLMAXIDLENGTH, EBML_UINT, 0, 0, offsetof(Ebml, id_length), { .u = 4 } },
460  { EBML_ID_DOCTYPE, EBML_STR, 0, 0, offsetof(Ebml, doctype), { .s = "(none)" } },
461  { EBML_ID_DOCTYPEREADVERSION, EBML_UINT, 0, 0, offsetof(Ebml, doctype_version), { .u = 1 } },
465 };
466 
468  { EBML_ID_HEADER, EBML_NEST, 0, 0, 0, { .n = ebml_header } },
470  { 0 }
471 };
472 
473 static EbmlSyntax matroska_info[] = {
474  { MATROSKA_ID_TIMECODESCALE, EBML_UINT, 0, 0, offsetof(MatroskaDemuxContext, time_scale), { .u = 1000000 } },
476  { MATROSKA_ID_TITLE, EBML_UTF8, 0, 0, offsetof(MatroskaDemuxContext, title) },
478  { MATROSKA_ID_MUXINGAPP, EBML_UTF8, 0, 0, offsetof(MatroskaDemuxContext, muxingapp) },
479  { MATROSKA_ID_DATEUTC, EBML_BIN, 0, 0, offsetof(MatroskaDemuxContext, date_utc) },
482 };
483 
491  { MATROSKA_ID_VIDEOCOLOR_WHITEX, EBML_FLOAT, 0, 0, offsetof(MatroskaMasteringMeta, white_x) },
492  { MATROSKA_ID_VIDEOCOLOR_WHITEY, EBML_FLOAT, 0, 0, offsetof(MatroskaMasteringMeta, white_y) },
493  { MATROSKA_ID_VIDEOCOLOR_LUMINANCEMIN, EBML_FLOAT, 1, 0, offsetof(MatroskaMasteringMeta, min_luminance) },
494  { MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX, EBML_FLOAT, 0, 0, offsetof(MatroskaMasteringMeta, max_luminance) },
496 };
497 
499  { MATROSKA_ID_VIDEOCOLORMATRIXCOEFF, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, matrix_coefficients), { .u = AVCOL_SPC_UNSPECIFIED } },
500  { MATROSKA_ID_VIDEOCOLORBITSPERCHANNEL, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, bits_per_channel), { .u = 0 } },
501  { MATROSKA_ID_VIDEOCOLORCHROMASUBHORZ, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, chroma_sub_horz) },
502  { MATROSKA_ID_VIDEOCOLORCHROMASUBVERT, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, chroma_sub_vert) },
503  { MATROSKA_ID_VIDEOCOLORCBSUBHORZ, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, cb_sub_horz) },
504  { MATROSKA_ID_VIDEOCOLORCBSUBVERT, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, cb_sub_vert) },
511  { MATROSKA_ID_VIDEOCOLORMAXFALL, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideoColor, max_fall) },
514 };
515 
519  { MATROSKA_ID_VIDEOPROJECTIONPOSEYAW, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackVideoProjection, yaw), { .f = 0.0 } },
520  { MATROSKA_ID_VIDEOPROJECTIONPOSEPITCH, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackVideoProjection, pitch), { .f = 0.0 } },
521  { MATROSKA_ID_VIDEOPROJECTIONPOSEROLL, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackVideoProjection, roll), { .f = 0.0 } },
523 };
524 
525 static EbmlSyntax matroska_track_video[] = {
526  { MATROSKA_ID_VIDEOFRAMERATE, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackVideo, frame_rate) },
527  { MATROSKA_ID_VIDEODISPLAYWIDTH, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, display_width), { .u=-1 } },
528  { MATROSKA_ID_VIDEODISPLAYHEIGHT, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, display_height), { .u=-1 } },
529  { MATROSKA_ID_VIDEOPIXELWIDTH, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_width) },
530  { MATROSKA_ID_VIDEOPIXELHEIGHT, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_height) },
531  { MATROSKA_ID_VIDEOCOLORSPACE, EBML_BIN, 0, 0, offsetof(MatroskaTrackVideo, color_space) },
532  { MATROSKA_ID_VIDEOALPHAMODE, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, alpha_mode), { .u = 0 } },
535  { MATROSKA_ID_VIDEOPIXELCROPB, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_cropb), {.u = 0 } },
536  { MATROSKA_ID_VIDEOPIXELCROPT, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_cropt), {.u = 0 } },
537  { MATROSKA_ID_VIDEOPIXELCROPL, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_cropl), {.u = 0 } },
538  { MATROSKA_ID_VIDEOPIXELCROPR, EBML_UINT, 0, 0, offsetof(MatroskaTrackVideo, pixel_cropr), {.u = 0 } },
545 };
546 
547 static EbmlSyntax matroska_track_audio[] = {
548  { MATROSKA_ID_AUDIOSAMPLINGFREQ, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackAudio, samplerate), { .f = 8000.0 } },
549  { MATROSKA_ID_AUDIOOUTSAMPLINGFREQ, EBML_FLOAT, 0, 0, offsetof(MatroskaTrackAudio, out_samplerate) },
551  { MATROSKA_ID_AUDIOCHANNELS, EBML_UINT, 0, 0, offsetof(MatroskaTrackAudio, channels), { .u = 1 } },
553 };
554 
559 };
560 
562  { MATROSKA_ID_ENCODINGENCALGO, EBML_UINT, 0, 0, offsetof(MatroskaTrackEncryption,algo), {.u = 0} },
570 };
572  { MATROSKA_ID_ENCODINGSCOPE, EBML_UINT, 0, 0, offsetof(MatroskaTrackEncoding, scope), { .u = 1 } },
573  { MATROSKA_ID_ENCODINGTYPE, EBML_UINT, 0, 0, offsetof(MatroskaTrackEncoding, type), { .u = 0 } },
578 };
579 
583 };
584 
585 static EbmlSyntax matroska_track_plane[] = {
589 };
590 
592  { MATROSKA_ID_TRACKPLANE, EBML_NEST, 0, sizeof(MatroskaTrackPlane), offsetof(MatroskaTrackOperation,combine_planes), {.n = matroska_track_plane} },
594 };
595 
599 };
600 
607 };
608 
609 static EbmlSyntax matroska_track[] = {
610  { MATROSKA_ID_TRACKNUMBER, EBML_UINT, 0, 0, offsetof(MatroskaTrack, num) },
611  { MATROSKA_ID_TRACKNAME, EBML_UTF8, 0, 0, offsetof(MatroskaTrack, name) },
612  { MATROSKA_ID_TRACKUID, EBML_UINT, 0, 0, offsetof(MatroskaTrack, uid) },
613  { MATROSKA_ID_TRACKTYPE, EBML_UINT, 0, 0, offsetof(MatroskaTrack, type) },
614  { MATROSKA_ID_CODECID, EBML_STR, 0, 0, offsetof(MatroskaTrack, codec_id) },
615  { MATROSKA_ID_CODECPRIVATE, EBML_BIN, 0, 0, offsetof(MatroskaTrack, codec_priv) },
616  { MATROSKA_ID_CODECDELAY, EBML_UINT, 0, 0, offsetof(MatroskaTrack, codec_delay), { .u = 0 } },
617  { MATROSKA_ID_TRACKLANGUAGE, EBML_STR, 0, 0, offsetof(MatroskaTrack, language), { .s = "eng" } },
618  { MATROSKA_ID_TRACKDEFAULTDURATION, EBML_UINT, 0, 0, offsetof(MatroskaTrack, default_duration) },
619  { MATROSKA_ID_TRACKTIMECODESCALE, EBML_FLOAT, 0, 0, offsetof(MatroskaTrack, time_scale), { .f = 1.0 } },
620  { MATROSKA_ID_TRACKFLAGCOMMENTARY, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_comment), { .u = 0 } },
621  { MATROSKA_ID_TRACKFLAGDEFAULT, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_default), { .u = 1 } },
622  { MATROSKA_ID_TRACKFLAGFORCED, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_forced), { .u = 0 } },
623  { MATROSKA_ID_TRACKFLAGHEARINGIMPAIRED, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_hearingimpaired), { .u = 0 } },
624  { MATROSKA_ID_TRACKFLAGVISUALIMPAIRED, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_visualimpaired), { .u = 0 } },
625  { MATROSKA_ID_TRACKFLAGTEXTDESCRIPTIONS, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_textdescriptions), { .u = 0 } },
626  { MATROSKA_ID_TRACKFLAGORIGINAL, EBML_UINT, 1, 0, offsetof(MatroskaTrack, flag_original), {.u = 0 } },
628  { MATROSKA_ID_TRACKAUDIO, EBML_NEST, 0, 0, offsetof(MatroskaTrack, audio), { .n = matroska_track_audio } },
629  { MATROSKA_ID_TRACKOPERATION, EBML_NEST, 0, 0, offsetof(MatroskaTrack, operation), { .n = matroska_track_operation } },
631  { MATROSKA_ID_TRACKMAXBLKADDID, EBML_UINT, 0, 0, offsetof(MatroskaTrack, max_block_additional_id), { .u = 0 } },
632  { MATROSKA_ID_TRACKBLKADDMAPPING, EBML_NEST, 0, sizeof(MatroskaBlockAdditionMapping), offsetof(MatroskaTrack, block_addition_mappings), { .n = matroska_block_addition_mapping } },
633  { MATROSKA_ID_SEEKPREROLL, EBML_UINT, 0, 0, offsetof(MatroskaTrack, seek_preroll), { .u = 0 } },
643 };
644 
645 static EbmlSyntax matroska_tracks[] = {
646  { MATROSKA_ID_TRACKENTRY, EBML_NEST, 0, sizeof(MatroskaTrack), offsetof(MatroskaDemuxContext, tracks), { .n = matroska_track } },
648 };
649 
650 static EbmlSyntax matroska_attachment[] = {
651  { MATROSKA_ID_FILEUID, EBML_UINT, 0, 0, offsetof(MatroskaAttachment, uid) },
652  { MATROSKA_ID_FILENAME, EBML_UTF8, 0, 0, offsetof(MatroskaAttachment, filename) },
653  { MATROSKA_ID_FILEMIMETYPE, EBML_STR, 0, 0, offsetof(MatroskaAttachment, mime) },
654  { MATROSKA_ID_FILEDATA, EBML_BIN, 0, 0, offsetof(MatroskaAttachment, bin) },
657 };
658 
659 static EbmlSyntax matroska_attachments[] = {
660  { MATROSKA_ID_ATTACHEDFILE, EBML_NEST, 0, sizeof(MatroskaAttachment), offsetof(MatroskaDemuxContext, attachments), { .n = matroska_attachment } },
662 };
663 
665  { MATROSKA_ID_CHAPSTRING, EBML_UTF8, 0, 0, offsetof(MatroskaChapter, title) },
669 };
670 
672  { MATROSKA_ID_CHAPTERTIMESTART, EBML_UINT, 0, 0, offsetof(MatroskaChapter, start), { .u = AV_NOPTS_VALUE } },
673  { MATROSKA_ID_CHAPTERTIMEEND, EBML_UINT, 0, 0, offsetof(MatroskaChapter, end), { .u = AV_NOPTS_VALUE } },
674  { MATROSKA_ID_CHAPTERUID, EBML_UINT, 0, 0, offsetof(MatroskaChapter, uid) },
681 };
682 
683 static EbmlSyntax matroska_chapter[] = {
684  { MATROSKA_ID_CHAPTERATOM, EBML_NEST, 0, sizeof(MatroskaChapter), offsetof(MatroskaDemuxContext, chapters), { .n = matroska_chapter_entry } },
690 };
691 
692 static EbmlSyntax matroska_chapters[] = {
693  { MATROSKA_ID_EDITIONENTRY, EBML_NEST, 0, 0, 0, { .n = matroska_chapter } },
695 };
696 
697 static EbmlSyntax matroska_index_pos[] = {
698  { MATROSKA_ID_CUETRACK, EBML_UINT, 0, 0, offsetof(MatroskaIndexPos, track) },
704 };
705 
706 static EbmlSyntax matroska_index_entry[] = {
707  { MATROSKA_ID_CUETIME, EBML_UINT, 0, 0, offsetof(MatroskaIndex, time) },
710 };
711 
712 static EbmlSyntax matroska_index[] = {
715 };
716 
717 static EbmlSyntax matroska_simpletag[] = {
718  { MATROSKA_ID_TAGNAME, EBML_UTF8, 0, 0, offsetof(MatroskaTag, name) },
719  { MATROSKA_ID_TAGSTRING, EBML_UTF8, 0, 0, offsetof(MatroskaTag, string) },
720  { MATROSKA_ID_TAGLANG, EBML_STR, 0, 0, offsetof(MatroskaTag, lang), { .s = "und" } },
721  { MATROSKA_ID_TAGDEFAULT, EBML_UINT, 0, 0, offsetof(MatroskaTag, def) },
722  { MATROSKA_ID_TAGDEFAULT_BUG, EBML_UINT, 0, 0, offsetof(MatroskaTag, def) },
723  { MATROSKA_ID_SIMPLETAG, EBML_NEST, 0, sizeof(MatroskaTag), offsetof(MatroskaTag, sub), { .n = matroska_simpletag } },
725 };
726 
727 static EbmlSyntax matroska_tagtargets[] = {
729  { MATROSKA_ID_TAGTARGETS_TYPEVALUE, EBML_UINT, 0, 0, offsetof(MatroskaTagTarget, typevalue), { .u = 50 } },
730  { MATROSKA_ID_TAGTARGETS_TRACKUID, EBML_UINT, 0, 0, offsetof(MatroskaTagTarget, trackuid), { .u = 0 } },
731  { MATROSKA_ID_TAGTARGETS_CHAPTERUID, EBML_UINT, 0, 0, offsetof(MatroskaTagTarget, chapteruid), { .u = 0 } },
732  { MATROSKA_ID_TAGTARGETS_ATTACHUID, EBML_UINT, 0, 0, offsetof(MatroskaTagTarget, attachuid), { .u = 0 } },
734 };
735 
736 static EbmlSyntax matroska_tag[] = {
737  { MATROSKA_ID_SIMPLETAG, EBML_NEST, 0, sizeof(MatroskaTag), offsetof(MatroskaTags, tag), { .n = matroska_simpletag } },
738  { MATROSKA_ID_TAGTARGETS, EBML_NEST, 0, 0, offsetof(MatroskaTags, target), { .n = matroska_tagtargets } },
740 };
741 
742 static EbmlSyntax matroska_tags[] = {
743  { MATROSKA_ID_TAG, EBML_NEST, 0, sizeof(MatroskaTags), offsetof(MatroskaDemuxContext, tags), { .n = matroska_tag } },
745 };
746 
748  { MATROSKA_ID_SEEKID, EBML_UINT, 0, 0, offsetof(MatroskaSeekhead, id) },
749  { MATROSKA_ID_SEEKPOSITION, EBML_UINT, 0, 0, offsetof(MatroskaSeekhead, pos), { .u = -1 } },
751 };
752 
753 static EbmlSyntax matroska_seekhead[] = {
754  { MATROSKA_ID_SEEKENTRY, EBML_NEST, 0, sizeof(MatroskaSeekhead), offsetof(MatroskaDemuxContext, seekhead), { .n = matroska_seekhead_entry } },
756 };
757 
758 static EbmlSyntax matroska_segment[] = {
760  { MATROSKA_ID_INFO, EBML_LEVEL1, 0, 0, 0, { .n = matroska_info } },
761  { MATROSKA_ID_TRACKS, EBML_LEVEL1, 0, 0, 0, { .n = matroska_tracks } },
763  { MATROSKA_ID_CHAPTERS, EBML_LEVEL1, 0, 0, 0, { .n = matroska_chapters } },
764  { MATROSKA_ID_CUES, EBML_LEVEL1, 0, 0, 0, { .n = matroska_index } },
765  { MATROSKA_ID_TAGS, EBML_LEVEL1, 0, 0, 0, { .n = matroska_tags } },
766  { MATROSKA_ID_SEEKHEAD, EBML_LEVEL1, 0, 0, 0, { .n = matroska_seekhead } },
767  { 0 } /* We don't want to go back to level 0, so don't add the parent. */
768 };
769 
770 static EbmlSyntax matroska_segments[] = {
771  { MATROSKA_ID_SEGMENT, EBML_NEST, 0, 0, 0, { .n = matroska_segment } },
772  { 0 }
773 };
774 
775 static EbmlSyntax matroska_blockmore[] = {
776  { MATROSKA_ID_BLOCKADDID, EBML_UINT, 0, 0, offsetof(MatroskaBlockMore,additional_id), { .u = MATROSKA_BLOCK_ADD_ID_OPAQUE } },
777  { MATROSKA_ID_BLOCKADDITIONAL, EBML_BIN, 0, 0, offsetof(MatroskaBlockMore,additional) },
779 };
780 
782  { MATROSKA_ID_BLOCKMORE, EBML_NEST, 0, sizeof(MatroskaBlockMore), offsetof(MatroskaBlock, blockmore), { .n = matroska_blockmore } },
784 };
785 
786 static EbmlSyntax matroska_blockgroup[] = {
787  { MATROSKA_ID_BLOCK, EBML_BIN, 0, 0, offsetof(MatroskaBlock, bin) },
790  { MATROSKA_ID_DISCARDPADDING, EBML_SINT, 0, 0, offsetof(MatroskaBlock, discard_padding) },
791  { MATROSKA_ID_BLOCKREFERENCE, EBML_SINT, 1, 0, offsetof(MatroskaBlock, reference) },
793  { 1, EBML_UINT, 0, 0, offsetof(MatroskaBlock, non_simple), { .u = 1 } },
795 };
796 
797 // The following array contains SimpleBlock and BlockGroup twice
798 // in order to reuse the other values for matroska_cluster_enter.
800  { MATROSKA_ID_SIMPLEBLOCK, EBML_BIN, 0, 0, offsetof(MatroskaBlock, bin) },
801  { MATROSKA_ID_BLOCKGROUP, EBML_NEST, 0, 0, 0, { .n = matroska_blockgroup } },
802  { MATROSKA_ID_CLUSTERTIMECODE, EBML_UINT, 0, 0, offsetof(MatroskaCluster, timecode) },
808 };
809 
811  { MATROSKA_ID_CLUSTER, EBML_NEST, 0, 0, 0, { .n = &matroska_cluster_parsing[2] } },
812  { 0 }
813 };
814 #undef CHILD_OF
815 
816 static const CodecMime mkv_image_mime_tags[] = {
817  {"image/gif" , AV_CODEC_ID_GIF},
818  {"image/jpeg" , AV_CODEC_ID_MJPEG},
819  {"image/png" , AV_CODEC_ID_PNG},
820  {"image/tiff" , AV_CODEC_ID_TIFF},
821 
822  {"" , AV_CODEC_ID_NONE}
823 };
824 
825 static const CodecMime mkv_mime_tags[] = {
826  {"application/x-truetype-font", AV_CODEC_ID_TTF},
827  {"application/x-font" , AV_CODEC_ID_TTF},
828  {"application/vnd.ms-opentype", AV_CODEC_ID_OTF},
829  {"binary" , AV_CODEC_ID_BIN_DATA},
830 
831  {"" , AV_CODEC_ID_NONE}
832 };
833 
835  "left",
836  "right",
837  "background",
838 };
839 
840 static const char *const matroska_doctypes[] = { "matroska", "webm" };
841 
842 /*
843  * This function prepares the status for parsing of level 1 elements.
844  */
845 static int matroska_reset_status(MatroskaDemuxContext *matroska,
846  uint32_t id, int64_t position)
847 {
848  int64_t err = 0;
849  if (position >= 0) {
850  err = avio_seek(matroska->ctx->pb, position, SEEK_SET);
851  if (err > 0)
852  err = 0;
853  } else
854  position = avio_tell(matroska->ctx->pb);
855 
856  matroska->current_id = id;
857  matroska->num_levels = 1;
858  matroska->unknown_count = 0;
859  matroska->resync_pos = position;
860  if (id)
861  matroska->resync_pos -= (av_log2(id) + 7) / 8;
862 
863  return err;
864 }
865 
866 static int matroska_resync(MatroskaDemuxContext *matroska, int64_t last_pos)
867 {
868  AVIOContext *pb = matroska->ctx->pb;
869  uint32_t id;
870 
871  /* Try to seek to the last position to resync from. If this doesn't work,
872  * we resync from the earliest position available: The start of the buffer. */
873  if (last_pos < avio_tell(pb) && avio_seek(pb, last_pos + 1, SEEK_SET) < 0) {
874  av_log(matroska->ctx, AV_LOG_WARNING,
875  "Seek to desired resync point failed. Seeking to "
876  "earliest point available instead.\n");
877  avio_seek(pb, FFMAX(avio_tell(pb) + (pb->buffer - pb->buf_ptr),
878  last_pos + 1), SEEK_SET);
879  }
880 
881  id = avio_rb32(pb);
882 
883  // try to find a toplevel element
884  while (!avio_feof(pb)) {
885  if (id == MATROSKA_ID_INFO || id == MATROSKA_ID_TRACKS ||
886  id == MATROSKA_ID_CUES || id == MATROSKA_ID_TAGS ||
888  id == MATROSKA_ID_CLUSTER || id == MATROSKA_ID_CHAPTERS) {
889  /* Prepare the context for parsing of a level 1 element. */
890  matroska_reset_status(matroska, id, -1);
891  /* Given that we are here means that an error has occurred,
892  * so treat the segment as unknown length in order not to
893  * discard valid data that happens to be beyond the designated
894  * end of the segment. */
895  matroska->levels[0].length = EBML_UNKNOWN_LENGTH;
896  return 0;
897  }
898  id = (id << 8) | avio_r8(pb);
899  }
900 
901  matroska->done = 1;
902  return pb->error ? pb->error : AVERROR_EOF;
903 }
904 
905 /*
906  * Read: an "EBML number", which is defined as a variable-length
907  * array of bytes. The first byte indicates the length by giving a
908  * number of 0-bits followed by a one. The position of the first
909  * "one" bit inside the first byte indicates the length of this
910  * number.
911  * Returns: number of bytes read, < 0 on error
912  */
913 static int ebml_read_num(MatroskaDemuxContext *matroska, AVIOContext *pb,
914  int max_size, uint64_t *number, int eof_forbidden)
915 {
916  int read, n = 1;
917  uint64_t total;
918  int64_t pos;
919 
920  /* The first byte tells us the length in bytes - except when it is zero. */
921  total = avio_r8(pb);
922  if (pb->eof_reached)
923  goto err;
924 
925  /* get the length of the EBML number */
926  read = 8 - ff_log2_tab[total];
927 
928  if (!total || read > max_size) {
929  pos = avio_tell(pb) - 1;
930  if (!total) {
931  av_log(matroska->ctx, AV_LOG_ERROR,
932  "0x00 at pos %"PRId64" (0x%"PRIx64") invalid as first byte "
933  "of an EBML number\n", pos, pos);
934  } else {
935  av_log(matroska->ctx, AV_LOG_ERROR,
936  "Length %d indicated by an EBML number's first byte 0x%02x "
937  "at pos %"PRId64" (0x%"PRIx64") exceeds max length %d.\n",
938  read, (uint8_t) total, pos, pos, max_size);
939  }
940  return AVERROR_INVALIDDATA;
941  }
942 
943  /* read out length */
944  total ^= 1 << ff_log2_tab[total];
945  while (n++ < read)
946  total = (total << 8) | avio_r8(pb);
947 
948  if (pb->eof_reached) {
949  eof_forbidden = 1;
950  goto err;
951  }
952 
953  *number = total;
954 
955  return read;
956 
957 err:
958  pos = avio_tell(pb);
959  if (pb->error) {
960  av_log(matroska->ctx, AV_LOG_ERROR,
961  "Read error at pos. %"PRIu64" (0x%"PRIx64")\n",
962  pos, pos);
963  return pb->error;
964  }
965  if (eof_forbidden) {
966  av_log(matroska->ctx, AV_LOG_ERROR, "File ended prematurely "
967  "at pos. %"PRIu64" (0x%"PRIx64")\n", pos, pos);
968  return AVERROR(EIO);
969  }
970  return AVERROR_EOF;
971 }
972 
973 /**
974  * Read a EBML length value.
975  * This needs special handling for the "unknown length" case which has multiple
976  * encodings.
977  */
978 static int ebml_read_length(MatroskaDemuxContext *matroska, AVIOContext *pb,
979  uint64_t *number)
980 {
981  int res = ebml_read_num(matroska, pb, 8, number, 1);
982  if (res > 0 && *number + 1 == 1ULL << (7 * res))
983  *number = EBML_UNKNOWN_LENGTH;
984  return res;
985 }
986 
987 /*
988  * Read the next element as an unsigned int.
989  * Returns NEEDS_CHECKING unless size == 0.
990  */
991 static int ebml_read_uint(AVIOContext *pb, int size,
992  uint64_t default_value, uint64_t *num)
993 {
994  int n = 0;
995 
996  if (size == 0) {
997  *num = default_value;
998  return 0;
999  }
1000  /* big-endian ordering; build up number */
1001  *num = 0;
1002  while (n++ < size)
1003  *num = (*num << 8) | avio_r8(pb);
1004 
1005  return NEEDS_CHECKING;
1007 
1008 /*
1009  * Read the next element as a signed int.
1010  * Returns NEEDS_CHECKING unless size == 0.
1011  */
1012 static int ebml_read_sint(AVIOContext *pb, int size,
1013  int64_t default_value, int64_t *num)
1014 {
1015  int n = 1;
1016 
1017  if (size == 0) {
1018  *num = default_value;
1019  return 0;
1020  } else {
1021  *num = sign_extend(avio_r8(pb), 8);
1022 
1023  /* big-endian ordering; build up number */
1024  while (n++ < size)
1025  *num = ((uint64_t)*num << 8) | avio_r8(pb);
1026  }
1027 
1028  return NEEDS_CHECKING;
1030 
1031 /*
1032  * Read the next element as a float.
1033  * Returns 0 if size == 0, NEEDS_CHECKING or < 0 on obvious failure.
1034  */
1035 static int ebml_read_float(AVIOContext *pb, int size,
1036  double default_value, double *num)
1037 {
1038  if (size == 0) {
1039  *num = default_value;
1040  return 0;
1041  } else if (size == 4) {
1042  *num = av_int2float(avio_rb32(pb));
1043  } else if (size == 8) {
1044  *num = av_int2double(avio_rb64(pb));
1045  } else
1046  return AVERROR_INVALIDDATA;
1047 
1048  return NEEDS_CHECKING;
1050 
1051 /*
1052  * Read the next element as an ASCII string.
1053  * 0 is success, < 0 or NEEDS_CHECKING is failure.
1054  */
1055 static int ebml_read_ascii(AVIOContext *pb, int size,
1056  const char *default_value, char **str)
1057 {
1058  char *res;
1059  int ret;
1060 
1061  if (size == 0 && default_value) {
1062  res = av_strdup(default_value);
1063  if (!res)
1064  return AVERROR(ENOMEM);
1065  } else {
1066  /* EBML strings are usually not 0-terminated, so we allocate one
1067  * byte more, read the string and NUL-terminate it ourselves. */
1068  if (!(res = av_malloc(size + 1)))
1069  return AVERROR(ENOMEM);
1070  if ((ret = avio_read(pb, (uint8_t *) res, size)) != size) {
1071  av_free(res);
1072  return ret < 0 ? ret : NEEDS_CHECKING;
1073  }
1074  (res)[size] = '\0';
1075  }
1076  av_free(*str);
1077  *str = res;
1078 
1079  return 0;
1081 
1082 /*
1083  * Read the next element as binary data.
1084  * 0 is success, < 0 or NEEDS_CHECKING is failure.
1085  */
1086 static int ebml_read_binary(AVIOContext *pb, int length,
1087  int64_t pos, EbmlBin *bin)
1088 {
1089  int ret;
1090 
1092  if (ret < 0)
1093  return ret;
1094  memset(bin->buf->data + length, 0, AV_INPUT_BUFFER_PADDING_SIZE);
1095 
1096  bin->data = bin->buf->data;
1097  bin->size = length;
1098  bin->pos = pos;
1099  if ((ret = avio_read(pb, bin->data, length)) != length) {
1100  av_buffer_unref(&bin->buf);
1101  bin->data = NULL;
1102  bin->size = 0;
1103  return ret < 0 ? ret : NEEDS_CHECKING;
1104  }
1105 
1106  return 0;
1107 }
1109 /*
1110  * Read the next element, but only the header. The contents
1111  * are supposed to be sub-elements which can be read separately.
1112  * 0 is success, < 0 is failure.
1113  */
1114 static int ebml_read_master(MatroskaDemuxContext *matroska,
1115  uint64_t length, int64_t pos)
1116 {
1118 
1119  if (matroska->num_levels >= EBML_MAX_DEPTH) {
1120  av_log(matroska->ctx, AV_LOG_ERROR,
1121  "File moves beyond max. allowed depth (%d)\n", EBML_MAX_DEPTH);
1122  return AVERROR(ENOSYS);
1123  }
1124 
1125  level = &matroska->levels[matroska->num_levels++];
1126  level->start = pos;
1127  level->length = length;
1128 
1129  return 0;
1131 
1132 /*
1133  * Read a signed "EBML number"
1134  * Return: number of bytes processed, < 0 on error
1135  */
1136 static int matroska_ebmlnum_sint(MatroskaDemuxContext *matroska,
1137  AVIOContext *pb, int64_t *num)
1138 {
1139  uint64_t unum;
1140  int res;
1141 
1142  /* read as unsigned number first */
1143  if ((res = ebml_read_num(matroska, pb, 8, &unum, 1)) < 0)
1144  return res;
1145 
1146  /* make signed (weird way) */
1147  *num = unum - ((1LL << (7 * res - 1)) - 1);
1148 
1149  return res;
1150 }
1151 
1152 static int ebml_parse(MatroskaDemuxContext *matroska,
1153  EbmlSyntax *syntax, void *data);
1154 
1155 static EbmlSyntax *ebml_parse_id(EbmlSyntax *syntax, uint32_t id)
1156 {
1157  int i;
1158 
1159  // Whoever touches this should be aware of the duplication
1160  // existing in matroska_cluster_parsing.
1161  for (i = 0; syntax[i].id; i++)
1162  if (id == syntax[i].id)
1163  break;
1164 
1165  return &syntax[i];
1166 }
1167 
1168 static int ebml_parse_nest(MatroskaDemuxContext *matroska, EbmlSyntax *syntax,
1169  void *data)
1170 {
1171  int res;
1172 
1173  if (data) {
1174  for (int i = 0; syntax[i].id; i++) {
1175  void *dst = (char *)data + syntax[i].data_offset;
1176  switch (syntax[i].type) {
1177  case EBML_UINT:
1178  *(uint64_t *)dst = syntax[i].def.u;
1179  break;
1180  case EBML_SINT:
1181  *(int64_t *) dst = syntax[i].def.i;
1182  break;
1183  case EBML_FLOAT:
1184  *(double *) dst = syntax[i].def.f;
1185  break;
1186  case EBML_STR:
1187  case EBML_UTF8:
1188  // the default may be NULL
1189  if (syntax[i].def.s) {
1190  *(char**)dst = av_strdup(syntax[i].def.s);
1191  if (!*(char**)dst)
1192  return AVERROR(ENOMEM);
1193  }
1194  break;
1195  }
1196  }
1197 
1198  if (!matroska->levels[matroska->num_levels - 1].length) {
1199  matroska->num_levels--;
1200  return 0;
1201  }
1202  }
1203 
1204  do {
1205  res = ebml_parse(matroska, syntax, data);
1206  } while (!res);
1207 
1208  return res == LEVEL_ENDED ? 0 : res;
1209 }
1210 
1211 static int is_ebml_id_valid(uint32_t id)
1212 {
1213  // Due to endian nonsense in Matroska, the highest byte with any bits set
1214  // will contain the leading length bit. This bit in turn identifies the
1215  // total byte length of the element by its position within the byte.
1216  unsigned int bits = av_log2(id);
1217  return id && (bits + 7) / 8 == (8 - bits % 8);
1219 
1220 /*
1221  * Allocate and return the entry for the level1 element with the given ID. If
1222  * an entry already exists, return the existing entry.
1223  */
1225  uint32_t id, int64_t pos)
1226 {
1227  int i;
1228  MatroskaLevel1Element *elem;
1229 
1230  if (!is_ebml_id_valid(id))
1231  return NULL;
1232 
1233  // Some files link to all clusters; useless.
1234  if (id == MATROSKA_ID_CLUSTER)
1235  return NULL;
1236 
1237  // There can be multiple SeekHeads and Tags.
1238  for (i = 0; i < matroska->num_level1_elems; i++) {
1239  if (matroska->level1_elems[i].id == id) {
1240  if (matroska->level1_elems[i].pos == pos ||
1241  id != MATROSKA_ID_SEEKHEAD && id != MATROSKA_ID_TAGS)
1242  return &matroska->level1_elems[i];
1243  }
1244  }
1245 
1246  // Only a completely broken file would have more elements.
1247  if (matroska->num_level1_elems >= FF_ARRAY_ELEMS(matroska->level1_elems)) {
1248  av_log(matroska->ctx, AV_LOG_ERROR, "Too many level1 elements.\n");
1249  return NULL;
1250  }
1251 
1252  elem = &matroska->level1_elems[matroska->num_level1_elems++];
1253  *elem = (MatroskaLevel1Element){.id = id};
1254 
1255  return elem;
1256 }
1257 
1258 static int ebml_parse(MatroskaDemuxContext *matroska,
1259  EbmlSyntax *syntax, void *data)
1260 {
1261  static const uint64_t max_lengths[EBML_TYPE_COUNT] = {
1262  // Forbid unknown-length EBML_NONE elements.
1264  [EBML_UINT] = 8,
1265  [EBML_SINT] = 8,
1266  [EBML_FLOAT] = 8,
1267  // max. 16 MB for strings
1268  [EBML_STR] = 0x1000000,
1269  [EBML_UTF8] = 0x1000000,
1270  // max. 256 MB for binary data
1271  [EBML_BIN] = 0x10000000,
1272  // no limits for anything else
1273  };
1274  AVIOContext *pb = matroska->ctx->pb;
1275  uint32_t id;
1276  uint64_t length;
1277  int64_t pos = avio_tell(pb), pos_alt;
1278  int res, update_pos = 1, level_check;
1279  MatroskaLevel1Element *level1_elem;
1280  MatroskaLevel *level = matroska->num_levels ? &matroska->levels[matroska->num_levels - 1] : NULL;
1281 
1282  if (!matroska->current_id) {
1283  uint64_t id;
1284  res = ebml_read_num(matroska, pb, 4, &id, 0);
1285  if (res < 0) {
1286  if (pb->eof_reached && res == AVERROR_EOF) {
1287  if (matroska->is_live)
1288  // in live mode, finish parsing if EOF is reached.
1289  return 1;
1290  if (level && pos == avio_tell(pb)) {
1291  if (level->length == EBML_UNKNOWN_LENGTH) {
1292  // Unknown-length levels automatically end at EOF.
1293  matroska->num_levels--;
1294  return LEVEL_ENDED;
1295  } else {
1296  av_log(matroska->ctx, AV_LOG_ERROR, "File ended prematurely "
1297  "at pos. %"PRIu64" (0x%"PRIx64")\n", pos, pos);
1298  }
1299  }
1300  }
1301  return res;
1302  }
1303  matroska->current_id = id | 1 << 7 * res;
1304  pos_alt = pos + res;
1305  } else {
1306  pos_alt = pos;
1307  pos -= (av_log2(matroska->current_id) + 7) / 8;
1308  }
1309 
1310  id = matroska->current_id;
1311 
1312  syntax = ebml_parse_id(syntax, id);
1313  if (!syntax->id && id != EBML_ID_VOID && id != EBML_ID_CRC32) {
1314  if (level && level->length == EBML_UNKNOWN_LENGTH) {
1315  // Unknown-length levels end when an element from an upper level
1316  // in the hierarchy is encountered.
1317  while (syntax->def.n) {
1318  syntax = ebml_parse_id(syntax->def.n, id);
1319  if (syntax->id) {
1320  matroska->num_levels--;
1321  return LEVEL_ENDED;
1322  }
1323  // We have not encountered a known element; syntax is a sentinel.
1324  av_assert1(syntax->type == EBML_NONE);
1325  };
1326  }
1327 
1328  av_log(matroska->ctx, AV_LOG_DEBUG, "Unknown entry 0x%"PRIX32" at pos. "
1329  "%"PRId64"\n", id, pos);
1330  update_pos = 0; /* Don't update resync_pos as an error might have happened. */
1331  }
1332 
1333  if (data) {
1334  data = (char *) data + syntax->data_offset;
1335  if (syntax->list_elem_size) {
1336  EbmlList *list = data;
1337  void *newelem;
1338 
1339  if ((unsigned)list->nb_elem + 1 >= UINT_MAX / syntax->list_elem_size)
1340  return AVERROR(ENOMEM);
1341  newelem = av_fast_realloc(list->elem,
1342  &list->alloc_elem_size,
1343  (list->nb_elem + 1) * syntax->list_elem_size);
1344  if (!newelem)
1345  return AVERROR(ENOMEM);
1346  list->elem = newelem;
1347  data = (char *) list->elem + list->nb_elem * syntax->list_elem_size;
1348  memset(data, 0, syntax->list_elem_size);
1349  list->nb_elem++;
1350  }
1351  }
1352 
1353  if (syntax->type != EBML_STOP) {
1354  matroska->current_id = 0;
1355  if ((res = ebml_read_length(matroska, pb, &length)) < 0)
1356  return res;
1357 
1358  pos_alt += res;
1359 
1360  if (matroska->num_levels > 0) {
1361  if (length != EBML_UNKNOWN_LENGTH &&
1362  level->length != EBML_UNKNOWN_LENGTH) {
1363  uint64_t elem_end = pos_alt + length,
1364  level_end = level->start + level->length;
1365 
1366  if (elem_end < level_end) {
1367  level_check = 0;
1368  } else if (elem_end == level_end) {
1369  level_check = LEVEL_ENDED;
1370  } else {
1371  av_log(matroska->ctx, AV_LOG_ERROR,
1372  "Element at 0x%"PRIx64" ending at 0x%"PRIx64" exceeds "
1373  "containing master element ending at 0x%"PRIx64"\n",
1374  pos, elem_end, level_end);
1375  return AVERROR_INVALIDDATA;
1376  }
1377  } else if (length != EBML_UNKNOWN_LENGTH) {
1378  level_check = 0;
1379  } else if (level->length != EBML_UNKNOWN_LENGTH) {
1380  av_log(matroska->ctx, AV_LOG_ERROR, "Unknown-sized element "
1381  "at 0x%"PRIx64" inside parent with finite size\n", pos);
1382  return AVERROR_INVALIDDATA;
1383  } else {
1384  level_check = 0;
1385  if (id != MATROSKA_ID_CLUSTER && (syntax->type == EBML_LEVEL1
1386  || syntax->type == EBML_NEST)) {
1387  // According to the current specifications only clusters and
1388  // segments are allowed to be unknown-length. We also accept
1389  // other unknown-length master elements.
1390  av_log(matroska->ctx, AV_LOG_WARNING,
1391  "Found unknown-length element 0x%"PRIX32" other than "
1392  "a cluster at 0x%"PRIx64". Spec-incompliant, but "
1393  "parsing will nevertheless be attempted.\n", id, pos);
1394  update_pos = -1;
1395  }
1396  }
1397  } else
1398  level_check = 0;
1399 
1400  if (max_lengths[syntax->type] && length > max_lengths[syntax->type]) {
1401  if (length != EBML_UNKNOWN_LENGTH) {
1402  av_log(matroska->ctx, AV_LOG_ERROR,
1403  "Invalid length 0x%"PRIx64" > 0x%"PRIx64" for element "
1404  "with ID 0x%"PRIX32" at 0x%"PRIx64"\n",
1405  length, max_lengths[syntax->type], id, pos);
1406  } else if (syntax->type != EBML_NONE) {
1407  av_log(matroska->ctx, AV_LOG_ERROR,
1408  "Element with ID 0x%"PRIX32" at pos. 0x%"PRIx64" has "
1409  "unknown length, yet the length of an element of its "
1410  "type must be known.\n", id, pos);
1411  } else {
1412  av_log(matroska->ctx, AV_LOG_ERROR,
1413  "Found unknown-length element with ID 0x%"PRIX32" at "
1414  "pos. 0x%"PRIx64" for which no syntax for parsing is "
1415  "available.\n", id, pos);
1416  }
1417  return AVERROR_INVALIDDATA;
1418  }
1419 
1420  if (!(pb->seekable & AVIO_SEEKABLE_NORMAL)) {
1421  // Loosing sync will likely manifest itself as encountering unknown
1422  // elements which are not reliably distinguishable from elements
1423  // belonging to future extensions of the format.
1424  // We use a heuristic to detect such situations: If the current
1425  // element is not expected at the current syntax level and there
1426  // were only a few unknown elements in a row, then the element is
1427  // skipped or considered defective based upon the length of the
1428  // current element (i.e. how much would be skipped); if there were
1429  // more than a few skipped elements in a row and skipping the current
1430  // element would lead us more than SKIP_THRESHOLD away from the last
1431  // known good position, then it is inferred that an error occurred.
1432  // The dependency on the number of unknown elements in a row exists
1433  // because the distance to the last known good position is
1434  // automatically big if the last parsed element was big.
1435  // In both cases, each unknown element is considered equivalent to
1436  // UNKNOWN_EQUIV of skipped bytes for the check.
1437  // The whole check is only done for non-seekable output, because
1438  // in this situation skipped data can't simply be rechecked later.
1439  // This is especially important when using unkown length elements
1440  // as the check for whether a child exceeds its containing master
1441  // element is not effective in this situation.
1442  if (update_pos) {
1443  matroska->unknown_count = 0;
1444  } else {
1445  int64_t dist = length + UNKNOWN_EQUIV * matroska->unknown_count++;
1446 
1447  if (matroska->unknown_count > 3)
1448  dist += pos_alt - matroska->resync_pos;
1449 
1450  if (dist > SKIP_THRESHOLD) {
1451  av_log(matroska->ctx, AV_LOG_ERROR,
1452  "Unknown element %"PRIX32" at pos. 0x%"PRIx64" with "
1453  "length 0x%"PRIx64" considered as invalid data. Last "
1454  "known good position 0x%"PRIx64", %d unknown elements"
1455  " in a row\n", id, pos, length, matroska->resync_pos,
1456  matroska->unknown_count);
1457  return AVERROR_INVALIDDATA;
1458  }
1459  }
1460  }
1461 
1462  if (update_pos > 0) {
1463  // We have found an element that is allowed at this place
1464  // in the hierarchy and it passed all checks, so treat the beginning
1465  // of the element as the "last known good" position.
1466  matroska->resync_pos = pos;
1467  }
1468 
1469  if (!data && length != EBML_UNKNOWN_LENGTH)
1470  goto skip;
1471  }
1472 
1473  switch (syntax->type) {
1474  case EBML_UINT:
1475  res = ebml_read_uint(pb, length, syntax->def.u, data);
1476  break;
1477  case EBML_SINT:
1478  res = ebml_read_sint(pb, length, syntax->def.i, data);
1479  break;
1480  case EBML_FLOAT:
1481  res = ebml_read_float(pb, length, syntax->def.f, data);
1482  break;
1483  case EBML_STR:
1484  case EBML_UTF8:
1485  res = ebml_read_ascii(pb, length, syntax->def.s, data);
1486  break;
1487  case EBML_BIN:
1488  res = ebml_read_binary(pb, length, pos_alt, data);
1489  break;
1490  case EBML_LEVEL1:
1491  case EBML_NEST:
1492  if ((res = ebml_read_master(matroska, length, pos_alt)) < 0)
1493  return res;
1494  if (id == MATROSKA_ID_SEGMENT)
1495  matroska->segment_start = pos_alt;
1496  if (id == MATROSKA_ID_CUES)
1497  matroska->cues_parsing_deferred = 0;
1498  if (syntax->type == EBML_LEVEL1 &&
1499  (level1_elem = matroska_find_level1_elem(matroska, syntax->id, pos))) {
1500  if (!level1_elem->pos) {
1501  // Zero is not a valid position for a level 1 element.
1502  level1_elem->pos = pos;
1503  } else if (level1_elem->pos != pos)
1504  av_log(matroska->ctx, AV_LOG_ERROR, "Duplicate element\n");
1505  level1_elem->parsed = 1;
1506  }
1507  if (res = ebml_parse_nest(matroska, syntax->def.n, data))
1508  return res;
1509  break;
1510  case EBML_STOP:
1511  return 1;
1512  skip:
1513  default:
1514  if (length) {
1515  int64_t res2;
1516  if (ffio_limit(pb, length) != length) {
1517  // ffio_limit emits its own error message,
1518  // so we don't have to.
1519  return AVERROR(EIO);
1520  }
1521  if ((res2 = avio_skip(pb, length - 1)) >= 0) {
1522  // avio_skip might take us past EOF. We check for this
1523  // by skipping only length - 1 bytes, reading a byte and
1524  // checking the error flags. This is done in order to check
1525  // that the element has been properly skipped even when
1526  // no filesize (that ffio_limit relies on) is available.
1527  avio_r8(pb);
1528  res = NEEDS_CHECKING;
1529  } else
1530  res = res2;
1531  } else
1532  res = 0;
1533  }
1534  if (res) {
1535  if (res == NEEDS_CHECKING) {
1536  if (pb->eof_reached) {
1537  if (pb->error)
1538  res = pb->error;
1539  else
1540  res = AVERROR_EOF;
1541  } else
1542  goto level_check;
1543  }
1544 
1545  if (res == AVERROR_INVALIDDATA)
1546  av_log(matroska->ctx, AV_LOG_ERROR, "Invalid element\n");
1547  else if (res == AVERROR(EIO))
1548  av_log(matroska->ctx, AV_LOG_ERROR, "Read error\n");
1549  else if (res == AVERROR_EOF) {
1550  av_log(matroska->ctx, AV_LOG_ERROR, "File ended prematurely\n");
1551  res = AVERROR(EIO);
1552  }
1553 
1554  return res;
1555  }
1556 
1557 level_check:
1558  if (syntax->is_counted && data) {
1559  CountedElement *elem = data;
1560  if (elem->count != UINT_MAX)
1561  elem->count++;
1562  }
1563 
1564  if (level_check == LEVEL_ENDED && matroska->num_levels) {
1565  level = &matroska->levels[matroska->num_levels - 1];
1566  pos = avio_tell(pb);
1567 
1568  // Given that pos >= level->start no check for
1569  // level->length != EBML_UNKNOWN_LENGTH is necessary.
1570  while (matroska->num_levels && pos == level->start + level->length) {
1571  matroska->num_levels--;
1572  level--;
1573  }
1574  }
1575 
1576  return level_check;
1577 }
1578 
1579 static void ebml_free(EbmlSyntax *syntax, void *data)
1580 {
1581  int i, j;
1582  for (i = 0; syntax[i].id; i++) {
1583  void *data_off = (char *) data + syntax[i].data_offset;
1584  switch (syntax[i].type) {
1585  case EBML_STR:
1586  case EBML_UTF8:
1587  av_freep(data_off);
1588  break;
1589  case EBML_BIN:
1590  av_buffer_unref(&((EbmlBin *) data_off)->buf);
1591  break;
1592  case EBML_LEVEL1:
1593  case EBML_NEST:
1594  if (syntax[i].list_elem_size) {
1595  EbmlList *list = data_off;
1596  char *ptr = list->elem;
1597  for (j = 0; j < list->nb_elem;
1598  j++, ptr += syntax[i].list_elem_size)
1599  ebml_free(syntax[i].def.n, ptr);
1600  av_freep(&list->elem);
1601  list->nb_elem = 0;
1602  list->alloc_elem_size = 0;
1603  } else
1604  ebml_free(syntax[i].def.n, data_off);
1605  default:
1606  break;
1607  }
1608  }
1609 }
1610 
1611 /*
1612  * Autodetecting...
1613  */
1614 static int matroska_probe(const AVProbeData *p)
1615 {
1616  uint64_t total = 0;
1617  int len_mask = 0x80, size = 1, n = 1, i;
1618 
1619  /* EBML header? */
1620  if (AV_RB32(p->buf) != EBML_ID_HEADER)
1621  return 0;
1622 
1623  /* length of header */
1624  total = p->buf[4];
1625  while (size <= 8 && !(total & len_mask)) {
1626  size++;
1627  len_mask >>= 1;
1628  }
1629  if (size > 8)
1630  return 0;
1631  total &= (len_mask - 1);
1632  while (n < size)
1633  total = (total << 8) | p->buf[4 + n++];
1634 
1635  if (total + 1 == 1ULL << (7 * size)){
1636  /* Unknown-length header - simply parse the whole buffer. */
1637  total = p->buf_size - 4 - size;
1638  } else {
1639  /* Does the probe data contain the whole header? */
1640  if (p->buf_size < 4 + size + total)
1641  return 0;
1642  }
1643 
1644  /* The header should contain a known document type. For now,
1645  * we don't parse the whole header but simply check for the
1646  * availability of that array of characters inside the header.
1647  * Not fully fool-proof, but good enough. */
1648  for (i = 0; i < FF_ARRAY_ELEMS(matroska_doctypes); i++) {
1649  size_t probelen = strlen(matroska_doctypes[i]);
1650  if (total < probelen)
1651  continue;
1652  for (n = 4 + size; n <= 4 + size + total - probelen; n++)
1653  if (!memcmp(p->buf + n, matroska_doctypes[i], probelen))
1654  return AVPROBE_SCORE_MAX;
1655  }
1656 
1657  // probably valid EBML header but no recognized doctype
1658  return AVPROBE_SCORE_EXTENSION;
1659 }
1660 
1662  uint64_t num)
1663 {
1664  MatroskaTrack *tracks = matroska->tracks.elem;
1665  int i;
1666 
1667  for (i = 0; i < matroska->tracks.nb_elem; i++)
1668  if (tracks[i].num == num)
1669  return &tracks[i];
1670 
1671  av_log(matroska->ctx, AV_LOG_ERROR, "Invalid track number %"PRIu64"\n", num);
1672  return NULL;
1673 }
1674 
1675 static int matroska_decode_buffer(uint8_t **buf, int *buf_size,
1676  MatroskaTrack *track)
1677 {
1678  MatroskaTrackEncoding *encodings = track->encodings.elem;
1679  uint8_t *data = *buf;
1680  int isize = *buf_size;
1681  uint8_t *pkt_data = NULL;
1682  uint8_t av_unused *newpktdata;
1683  int pkt_size = isize;
1684  int result = 0;
1685  int olen;
1686 
1687  if (pkt_size >= 10000000U)
1688  return AVERROR_INVALIDDATA;
1689 
1690  switch (encodings[0].compression.algo) {
1692  {
1693  int header_size = encodings[0].compression.settings.size;
1694  uint8_t *header = encodings[0].compression.settings.data;
1695 
1696  if (header_size && !header) {
1697  av_log(NULL, AV_LOG_ERROR, "Compression size but no data in headerstrip\n");
1698  return -1;
1699  }
1700 
1701  if (!header_size)
1702  return 0;
1703 
1704  pkt_size = isize + header_size;
1705  pkt_data = av_malloc(pkt_size + AV_INPUT_BUFFER_PADDING_SIZE);
1706  if (!pkt_data)
1707  return AVERROR(ENOMEM);
1708 
1709  memcpy(pkt_data, header, header_size);
1710  memcpy(pkt_data + header_size, data, isize);
1711  break;
1712  }
1714  do {
1715  int insize = isize;
1716  olen = pkt_size *= 3;
1717  newpktdata = av_realloc(pkt_data, pkt_size + AV_LZO_OUTPUT_PADDING
1719  if (!newpktdata) {
1720  result = AVERROR(ENOMEM);
1721  goto failed;
1722  }
1723  pkt_data = newpktdata;
1724  result = av_lzo1x_decode(pkt_data, &olen, data, &insize);
1725  } while (result == AV_LZO_OUTPUT_FULL && pkt_size < 10000000);
1726  if (result) {
1728  goto failed;
1729  }
1730  pkt_size -= olen;
1731  break;
1732 #if CONFIG_ZLIB
1734  {
1735  z_stream zstream = { 0 };
1736  if (!pkt_size || inflateInit(&zstream) != Z_OK)
1737  return -1;
1738  zstream.next_in = data;
1739  zstream.avail_in = isize;
1740  do {
1741  pkt_size *= 3;
1742  newpktdata = av_realloc(pkt_data, pkt_size + AV_INPUT_BUFFER_PADDING_SIZE);
1743  if (!newpktdata) {
1744  inflateEnd(&zstream);
1745  result = AVERROR(ENOMEM);
1746  goto failed;
1747  }
1748  pkt_data = newpktdata;
1749  zstream.avail_out = pkt_size - zstream.total_out;
1750  zstream.next_out = pkt_data + zstream.total_out;
1751  result = inflate(&zstream, Z_NO_FLUSH);
1752  } while (result == Z_OK && pkt_size < 10000000);
1753  pkt_size = zstream.total_out;
1754  inflateEnd(&zstream);
1755  if (result != Z_STREAM_END) {
1756  if (result == Z_MEM_ERROR)
1757  result = AVERROR(ENOMEM);
1758  else
1760  goto failed;
1761  }
1762  break;
1763  }
1764 #endif
1765 #if CONFIG_BZLIB
1767  {
1768  bz_stream bzstream = { 0 };
1769  if (!pkt_size || BZ2_bzDecompressInit(&bzstream, 0, 0) != BZ_OK)
1770  return -1;
1771  bzstream.next_in = data;
1772  bzstream.avail_in = isize;
1773  do {
1774  pkt_size *= 3;
1775  newpktdata = av_realloc(pkt_data, pkt_size + AV_INPUT_BUFFER_PADDING_SIZE);
1776  if (!newpktdata) {
1777  BZ2_bzDecompressEnd(&bzstream);
1778  result = AVERROR(ENOMEM);
1779  goto failed;
1780  }
1781  pkt_data = newpktdata;
1782  bzstream.avail_out = pkt_size - bzstream.total_out_lo32;
1783  bzstream.next_out = pkt_data + bzstream.total_out_lo32;
1784  result = BZ2_bzDecompress(&bzstream);
1785  } while (result == BZ_OK && pkt_size < 10000000);
1786  pkt_size = bzstream.total_out_lo32;
1787  BZ2_bzDecompressEnd(&bzstream);
1788  if (result != BZ_STREAM_END) {
1789  if (result == BZ_MEM_ERROR)
1790  result = AVERROR(ENOMEM);
1791  else
1793  goto failed;
1794  }
1795  break;
1796  }
1797 #endif
1798  default:
1799  return AVERROR_INVALIDDATA;
1800  }
1801 
1802  memset(pkt_data + pkt_size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
1803 
1804  *buf = pkt_data;
1805  *buf_size = pkt_size;
1806  return 0;
1808 failed:
1809  av_free(pkt_data);
1810  return result;
1811 }
1812 
1814  AVDictionary **metadata, char *prefix)
1815 {
1816  MatroskaTag *tags = list->elem;
1817  char key[1024];
1818  int i;
1819 
1820  for (i = 0; i < list->nb_elem; i++) {
1821  const char *lang = tags[i].lang &&
1822  strcmp(tags[i].lang, "und") ? tags[i].lang : NULL;
1823 
1824  if (!tags[i].name) {
1825  av_log(s, AV_LOG_WARNING, "Skipping invalid tag with no TagName.\n");
1826  continue;
1827  }
1828  if (prefix)
1829  snprintf(key, sizeof(key), "%s/%s", prefix, tags[i].name);
1830  else
1831  av_strlcpy(key, tags[i].name, sizeof(key));
1832  if (tags[i].def || !lang) {
1833  av_dict_set(metadata, key, tags[i].string, 0);
1834  if (tags[i].sub.nb_elem)
1835  matroska_convert_tag(s, &tags[i].sub, metadata, key);
1836  }
1837  if (lang) {
1838  av_strlcat(key, "-", sizeof(key));
1839  av_strlcat(key, lang, sizeof(key));
1840  av_dict_set(metadata, key, tags[i].string, 0);
1841  if (tags[i].sub.nb_elem)
1842  matroska_convert_tag(s, &tags[i].sub, metadata, key);
1843  }
1844  }
1846 }
1847 
1849 {
1850  MatroskaDemuxContext *matroska = s->priv_data;
1851  MatroskaTags *tags = matroska->tags.elem;
1852  int i, j;
1853 
1854  for (i = 0; i < matroska->tags.nb_elem; i++) {
1855  if (tags[i].target.attachuid) {
1856  MatroskaAttachment *attachment = matroska->attachments.elem;
1857  int found = 0;
1858  for (j = 0; j < matroska->attachments.nb_elem; j++) {
1859  if (attachment[j].uid == tags[i].target.attachuid &&
1860  attachment[j].stream) {
1861  matroska_convert_tag(s, &tags[i].tag,
1862  &attachment[j].stream->metadata, NULL);
1863  found = 1;
1864  }
1865  }
1866  if (!found) {
1868  "The tags at index %d refer to a "
1869  "non-existent attachment %"PRId64".\n",
1870  i, tags[i].target.attachuid);
1871  }
1872  } else if (tags[i].target.chapteruid) {
1873  MatroskaChapter *chapter = matroska->chapters.elem;
1874  int found = 0;
1875  for (j = 0; j < matroska->chapters.nb_elem; j++) {
1876  if (chapter[j].uid == tags[i].target.chapteruid &&
1877  chapter[j].chapter) {
1878  matroska_convert_tag(s, &tags[i].tag,
1879  &chapter[j].chapter->metadata, NULL);
1880  found = 1;
1881  }
1882  }
1883  if (!found) {
1885  "The tags at index %d refer to a non-existent chapter "
1886  "%"PRId64".\n",
1887  i, tags[i].target.chapteruid);
1888  }
1889  } else if (tags[i].target.trackuid) {
1890  MatroskaTrack *track = matroska->tracks.elem;
1891  int found = 0;
1892  for (j = 0; j < matroska->tracks.nb_elem; j++) {
1893  if (track[j].uid == tags[i].target.trackuid &&
1894  track[j].stream) {
1895  matroska_convert_tag(s, &tags[i].tag,
1896  &track[j].stream->metadata, NULL);
1897  found = 1;
1898  }
1899  }
1900  if (!found) {
1902  "The tags at index %d refer to a non-existent track "
1903  "%"PRId64".\n",
1904  i, tags[i].target.trackuid);
1905  }
1906  } else {
1907  matroska_convert_tag(s, &tags[i].tag, &s->metadata,
1908  tags[i].target.type);
1909  }
1910  }
1911 }
1912 
1914  int64_t pos)
1915 {
1916  uint32_t saved_id = matroska->current_id;
1917  int64_t before_pos = avio_tell(matroska->ctx->pb);
1918  int ret = 0;
1919  int ret2;
1920 
1921  /* seek */
1922  if (avio_seek(matroska->ctx->pb, pos, SEEK_SET) == pos) {
1923  /* We don't want to lose our seekhead level, so we add
1924  * a dummy. This is a crude hack. */
1925  if (matroska->num_levels == EBML_MAX_DEPTH) {
1926  av_log(matroska->ctx, AV_LOG_INFO,
1927  "Max EBML element depth (%d) reached, "
1928  "cannot parse further.\n", EBML_MAX_DEPTH);
1930  } else {
1931  matroska->levels[matroska->num_levels] = (MatroskaLevel) { 0, EBML_UNKNOWN_LENGTH };
1932  matroska->num_levels++;
1933  matroska->current_id = 0;
1934 
1935  ret = ebml_parse(matroska, matroska_segment, matroska);
1936  if (ret == LEVEL_ENDED) {
1937  /* This can only happen if the seek brought us beyond EOF. */
1938  ret = AVERROR_EOF;
1939  }
1940  }
1941  }
1942  /* Seek back - notice that in all instances where this is used
1943  * it is safe to set the level to 1. */
1944  ret2 = matroska_reset_status(matroska, saved_id, before_pos);
1945  if (ret >= 0)
1946  ret = ret2;
1947 
1948  return ret;
1949 }
1950 
1951 static void matroska_execute_seekhead(MatroskaDemuxContext *matroska)
1952 {
1953  EbmlList *seekhead_list = &matroska->seekhead;
1954  int i;
1955 
1956  // we should not do any seeking in the streaming case
1957  if (!(matroska->ctx->pb->seekable & AVIO_SEEKABLE_NORMAL))
1958  return;
1959 
1960  for (i = 0; i < seekhead_list->nb_elem; i++) {
1961  MatroskaSeekhead *seekheads = seekhead_list->elem;
1962  uint32_t id = seekheads[i].id;
1963  int64_t pos = seekheads[i].pos + matroska->segment_start;
1964  MatroskaLevel1Element *elem;
1965 
1966  if (id != seekheads[i].id || pos < matroska->segment_start)
1967  continue;
1968 
1969  elem = matroska_find_level1_elem(matroska, id, pos);
1970  if (!elem || elem->parsed)
1971  continue;
1972 
1973  elem->pos = pos;
1974 
1975  // defer cues parsing until we actually need cue data.
1976  if (id == MATROSKA_ID_CUES)
1977  continue;
1978 
1979  if (matroska_parse_seekhead_entry(matroska, pos) < 0) {
1980  // mark index as broken
1981  matroska->cues_parsing_deferred = -1;
1982  break;
1983  }
1984 
1985  elem->parsed = 1;
1986  }
1987 }
1988 
1989 static void matroska_add_index_entries(MatroskaDemuxContext *matroska)
1990 {
1991  EbmlList *index_list;
1993  uint64_t index_scale = 1;
1994  int i, j;
1995 
1996  if (matroska->ctx->flags & AVFMT_FLAG_IGNIDX)
1997  return;
1998 
1999  index_list = &matroska->index;
2000  index = index_list->elem;
2001  if (index_list->nb_elem < 2)
2002  return;
2003  if (index[1].time > 1E14 / matroska->time_scale) {
2004  av_log(matroska->ctx, AV_LOG_WARNING, "Dropping apparently-broken index.\n");
2005  return;
2006  }
2007  for (i = 0; i < index_list->nb_elem; i++) {
2008  EbmlList *pos_list = &index[i].pos;
2009  MatroskaIndexPos *pos = pos_list->elem;
2010  for (j = 0; j < pos_list->nb_elem; j++) {
2011  MatroskaTrack *track = matroska_find_track_by_num(matroska,
2012  pos[j].track);
2013  if (track && track->stream)
2014  av_add_index_entry(track->stream,
2015  pos[j].pos + matroska->segment_start,
2016  index[i].time / index_scale, 0, 0,
2018  }
2019  }
2020 }
2021 
2022 static void matroska_parse_cues(MatroskaDemuxContext *matroska) {
2023  int i;
2024 
2025  if (matroska->ctx->flags & AVFMT_FLAG_IGNIDX)
2026  return;
2027 
2028  for (i = 0; i < matroska->num_level1_elems; i++) {
2029  MatroskaLevel1Element *elem = &matroska->level1_elems[i];
2030  if (elem->id == MATROSKA_ID_CUES && !elem->parsed) {
2031  if (matroska_parse_seekhead_entry(matroska, elem->pos) < 0)
2032  matroska->cues_parsing_deferred = -1;
2033  elem->parsed = 1;
2034  break;
2035  }
2036  }
2037 
2038  matroska_add_index_entries(matroska);
2039 }
2040 
2042  unsigned nb_encodings,
2043  MatroskaTrack *track,
2044  char **key_id_base64, void *logctx)
2045 {
2046  if (nb_encodings > 1) {
2047  av_log(logctx, AV_LOG_ERROR,
2048  "Multiple combined encodings not supported\n");
2049  return 0;
2050  }
2051  if (!nb_encodings)
2052  return 0;
2053  if (encodings->type) {
2054  if (encodings->encryption.key_id.size > 0) {
2055  /* Save the encryption key id to be stored later
2056  * as a metadata tag. */
2057  const int b64_size = AV_BASE64_SIZE(encodings->encryption.key_id.size);
2058  *key_id_base64 = av_malloc(b64_size);
2059  if (!*key_id_base64)
2060  return AVERROR(ENOMEM);
2061 
2062  av_base64_encode(*key_id_base64, b64_size,
2063  encodings->encryption.key_id.data,
2064  encodings->encryption.key_id.size);
2065  } else {
2066  encodings->scope = 0;
2067  av_log(logctx, AV_LOG_ERROR, "Unsupported encoding type\n");
2068  }
2069  } else if (
2070 #if CONFIG_ZLIB
2072 #endif
2073 #if CONFIG_BZLIB
2075 #endif
2078  encodings->scope = 0;
2079  av_log(logctx, AV_LOG_ERROR, "Unsupported encoding type\n");
2080  } else if (track->codec_priv.size && encodings[0].scope & 2) {
2081  uint8_t *codec_priv = track->codec_priv.data;
2082  int ret = matroska_decode_buffer(&track->codec_priv.data,
2083  &track->codec_priv.size,
2084  track);
2085  if (ret < 0) {
2086  track->codec_priv.data = NULL;
2087  track->codec_priv.size = 0;
2088  av_log(logctx, AV_LOG_ERROR,
2089  "Failed to decode codec private data\n");
2090  }
2091 
2092  if (codec_priv != track->codec_priv.data) {
2093  av_buffer_unref(&track->codec_priv.buf);
2094  if (track->codec_priv.data) {
2095  track->codec_priv.buf = av_buffer_create(track->codec_priv.data,
2097  NULL, NULL, 0);
2098  if (!track->codec_priv.buf) {
2099  av_freep(&track->codec_priv.data);
2100  track->codec_priv.size = 0;
2101  return AVERROR(ENOMEM);
2102  }
2103  }
2104  }
2105  }
2106  track->needs_decoding = !encodings->type &&
2107  encodings->scope & 1 &&
2108  (encodings->compression.algo !=
2110  encodings->compression.settings.size);
2111 
2112  return 0;
2113 }
2114 
2115 static int matroska_aac_profile(char *codec_id)
2116 {
2117  static const char *const aac_profiles[] = { "MAIN", "LC", "SSR" };
2118  int profile;
2119 
2121  if (strstr(codec_id, aac_profiles[profile]))
2122  break;
2123  return profile + 1;
2124 }
2125 
2126 static int matroska_aac_sri(int samplerate)
2127 {
2128  int sri;
2129 
2130  for (sri = 0; sri < FF_ARRAY_ELEMS(ff_mpeg4audio_sample_rates); sri++)
2131  if (ff_mpeg4audio_sample_rates[sri] == samplerate)
2132  break;
2133  return sri;
2134 }
2135 
2136 static void matroska_metadata_creation_time(AVDictionary **metadata, int64_t date_utc)
2137 {
2138  /* Convert to seconds and adjust by number of seconds between 2001-01-01 and Epoch */
2139  ff_dict_set_timestamp(metadata, "creation_time", date_utc / 1000 + 978307200000000LL);
2140 }
2141 
2143  MatroskaTrack *track,
2144  int *offset)
2145 {
2146  AVStream *st = track->stream;
2147  uint8_t *p = track->codec_priv.data;
2148  int size = track->codec_priv.size;
2149 
2150  if (size < 8 + FLAC_STREAMINFO_SIZE || p[4] & 0x7f) {
2151  av_log(s, AV_LOG_WARNING, "Invalid FLAC private data\n");
2152  track->codec_priv.size = 0;
2153  return 0;
2154  }
2155  *offset = 8;
2156  track->codec_priv.size = 8 + FLAC_STREAMINFO_SIZE;
2157 
2158  p += track->codec_priv.size;
2159  size -= track->codec_priv.size;
2160 
2161  /* parse the remaining metadata blocks if present */
2162  while (size >= 4) {
2163  int block_last, block_type, block_size;
2164 
2165  flac_parse_block_header(p, &block_last, &block_type, &block_size);
2166 
2167  p += 4;
2168  size -= 4;
2169  if (block_size > size)
2170  return 0;
2171 
2172  /* check for the channel mask */
2173  if (block_type == FLAC_METADATA_TYPE_VORBIS_COMMENT) {
2174  AVDictionary *dict = NULL;
2175  AVDictionaryEntry *chmask;
2176 
2177  ff_vorbis_comment(s, &dict, p, block_size, 0);
2178  chmask = av_dict_get(dict, "WAVEFORMATEXTENSIBLE_CHANNEL_MASK", NULL, 0);
2179  if (chmask) {
2180  uint64_t mask = strtol(chmask->value, NULL, 0);
2181  if (!mask || mask & ~0x3ffffULL) {
2183  "Invalid value of WAVEFORMATEXTENSIBLE_CHANNEL_MASK\n");
2184  } else
2186  }
2187  av_dict_free(&dict);
2188  }
2189 
2190  p += block_size;
2191  size -= block_size;
2192  }
2193 
2194  return 0;
2195 }
2196 
2197 static int mkv_field_order(const MatroskaDemuxContext *matroska, uint64_t field_order)
2198 {
2199  int minor, micro, bttb = 0;
2200 
2201  /* workaround a bug in our Matroska muxer, introduced in version 57.36 alongside
2202  * this function, and fixed in 57.52 */
2203  if (matroska->muxingapp && sscanf(matroska->muxingapp, "Lavf57.%d.%d", &minor, &micro) == 2)
2204  bttb = (minor >= 36 && minor <= 51 && micro >= 100);
2205 
2206  switch (field_order) {
2208  return AV_FIELD_PROGRESSIVE;
2210  return AV_FIELD_UNKNOWN;
2212  return AV_FIELD_TT;
2214  return AV_FIELD_BB;
2216  return bttb ? AV_FIELD_TB : AV_FIELD_BT;
2218  return bttb ? AV_FIELD_BT : AV_FIELD_TB;
2219  default:
2220  return AV_FIELD_UNKNOWN;
2221  }
2222 }
2223 
2224 static void mkv_stereo_mode_display_mul(int stereo_mode,
2225  int *h_width, int *h_height)
2226 {
2227  switch (stereo_mode) {
2233  break;
2238  *h_width = 2;
2239  break;
2244  *h_height = 2;
2245  break;
2246  }
2247 }
2248 
2249 static int mkv_stereo3d_conv(AVStream *st, MatroskaVideoStereoModeType stereo_mode)
2250 {
2251  static const struct {
2252  char type;
2253  char flags;
2254  } stereo_mode_conv [] = {
2255 #define STEREO_MODE_CONV(STEREOMODETYPE, STEREO3DTYPE, FLAGS, WDIV, HDIV, WEBM) \
2256  [(STEREOMODETYPE)] = { .type = (STEREO3DTYPE), .flags = (FLAGS) },
2257 #define NOTHING(STEREOMODETYPE, WDIV, HDIV, WEBM)
2259  };
2260  AVStereo3D *stereo;
2261  size_t size;
2262 
2263  stereo = av_stereo3d_alloc_size(&size);
2264  if (!stereo)
2265  return AVERROR(ENOMEM);
2266 
2267  stereo->type = stereo_mode_conv[stereo_mode].type;
2268  stereo->flags = stereo_mode_conv[stereo_mode].flags;
2269 
2271  AV_PKT_DATA_STEREO3D, stereo, size, 0)) {
2272  av_freep(&stereo);
2273  return AVERROR(ENOMEM);
2274  }
2275 
2276  return 0;
2277 }
2278 
2279 static int mkv_parse_video_color(AVStream *st, const MatroskaTrack *track) {
2280  const MatroskaTrackVideoColor *color = track->video.color.elem;
2281  const MatroskaMasteringMeta *mastering_meta;
2282  int has_mastering_primaries, has_mastering_luminance;
2283 
2284  if (!track->video.color.nb_elem)
2285  return 0;
2286 
2287  mastering_meta = &color->mastering_meta;
2288  // Mastering primaries are CIE 1931 coords, and must be > 0.
2289  has_mastering_primaries =
2290  mastering_meta->r_x > 0 && mastering_meta->r_y > 0 &&
2291  mastering_meta->g_x > 0 && mastering_meta->g_y > 0 &&
2292  mastering_meta->b_x > 0 && mastering_meta->b_y > 0 &&
2293  mastering_meta->white_x > 0 && mastering_meta->white_y > 0;
2294  has_mastering_luminance = mastering_meta->max_luminance >
2295  mastering_meta->min_luminance.el.f &&
2296  mastering_meta->min_luminance.el.f >= 0 &&
2297  mastering_meta->min_luminance.count;
2298 
2299  if (color->matrix_coefficients != AVCOL_SPC_RESERVED)
2300  st->codecpar->color_space = color->matrix_coefficients;
2301  if (color->primaries != AVCOL_PRI_RESERVED &&
2302  color->primaries != AVCOL_PRI_RESERVED0)
2303  st->codecpar->color_primaries = color->primaries;
2304  if (color->transfer_characteristics != AVCOL_TRC_RESERVED &&
2305  color->transfer_characteristics != AVCOL_TRC_RESERVED0)
2306  st->codecpar->color_trc = color->transfer_characteristics;
2307  if (color->range != AVCOL_RANGE_UNSPECIFIED &&
2308  color->range <= AVCOL_RANGE_JPEG)
2309  st->codecpar->color_range = color->range;
2310  if (color->chroma_siting_horz != MATROSKA_COLOUR_CHROMASITINGHORZ_UNDETERMINED &&
2311  color->chroma_siting_vert != MATROSKA_COLOUR_CHROMASITINGVERT_UNDETERMINED &&
2312  color->chroma_siting_horz < MATROSKA_COLOUR_CHROMASITINGHORZ_NB &&
2313  color->chroma_siting_vert < MATROSKA_COLOUR_CHROMASITINGVERT_NB) {
2314  st->codecpar->chroma_location =
2315  av_chroma_location_pos_to_enum((color->chroma_siting_horz - 1) << 7,
2316  (color->chroma_siting_vert - 1) << 7);
2317  }
2318  if (color->max_cll && color->max_fall) {
2319  size_t size = 0;
2321  if (!metadata)
2322  return AVERROR(ENOMEM);
2324  AV_PKT_DATA_CONTENT_LIGHT_LEVEL, metadata, size, 0)) {
2325  av_freep(&metadata);
2326  return AVERROR(ENOMEM);
2327  }
2328  metadata->MaxCLL = color->max_cll;
2329  metadata->MaxFALL = color->max_fall;
2330  }
2331 
2332  if (has_mastering_primaries || has_mastering_luminance) {
2333  size_t size = 0;
2335  if (!metadata)
2336  return AVERROR(ENOMEM);
2339  av_freep(&metadata);
2340  return AVERROR(ENOMEM);
2341  }
2342  if (has_mastering_primaries) {
2343  metadata->display_primaries[0][0] = av_d2q(mastering_meta->r_x, INT_MAX);
2344  metadata->display_primaries[0][1] = av_d2q(mastering_meta->r_y, INT_MAX);
2345  metadata->display_primaries[1][0] = av_d2q(mastering_meta->g_x, INT_MAX);
2346  metadata->display_primaries[1][1] = av_d2q(mastering_meta->g_y, INT_MAX);
2347  metadata->display_primaries[2][0] = av_d2q(mastering_meta->b_x, INT_MAX);
2348  metadata->display_primaries[2][1] = av_d2q(mastering_meta->b_y, INT_MAX);
2349  metadata->white_point[0] = av_d2q(mastering_meta->white_x, INT_MAX);
2350  metadata->white_point[1] = av_d2q(mastering_meta->white_y, INT_MAX);
2351  metadata->has_primaries = 1;
2352  }
2353  if (has_mastering_luminance) {
2354  metadata->max_luminance = av_d2q(mastering_meta->max_luminance, INT_MAX);
2355  metadata->min_luminance = av_d2q(mastering_meta->min_luminance.el.f, INT_MAX);
2356  metadata->has_luminance = 1;
2357  }
2358  }
2359  return 0;
2360 }
2361 
2362 static int mkv_create_display_matrix(AVStream *st,
2363  const MatroskaTrackVideoProjection *proj,
2364  void *logctx)
2365 {
2366  AVPacketSideData *sd;
2367  double pitch = proj->pitch, yaw = proj->yaw, roll = proj->roll;
2368  int32_t *matrix;
2369  int hflip;
2370 
2371  if (pitch == 0.0 && yaw == 0.0 && roll == 0.0)
2372  return 0;
2373 
2374  /* Note: The following constants are exactly representable
2375  * as floating-point numbers. */
2376  if (pitch != 0.0 || (yaw != 0.0 && yaw != 180.0 && yaw != -180.0) ||
2377  isnan(roll)) {
2378  av_log(logctx, AV_LOG_WARNING, "Ignoring non-2D rectangular "
2379  "projection in stream %u (yaw %f, pitch %f, roll %f)\n",
2380  st->index, yaw, pitch, roll);
2381  return 0;
2382  }
2386  9 * sizeof(*matrix), 0);
2387  if (!sd)
2388  return AVERROR(ENOMEM);
2389  matrix = (int32_t*)sd->data;
2390 
2391  hflip = yaw != 0.0;
2392  /* ProjectionPoseRoll is in the counter-clockwise direction
2393  * whereas av_display_rotation_set() expects its argument
2394  * to be oriented clockwise, so we need to negate roll.
2395  * Furthermore, if hflip is set, we need to negate it again
2396  * to account for the fact that the Matroska specifications
2397  * require the yaw rotation to be applied first. */
2398  av_display_rotation_set(matrix, roll * (2 * hflip - 1));
2399  av_display_matrix_flip(matrix, hflip, 0);
2400 
2401  return 0;
2402 }
2403 
2404 static int mkv_parse_video_projection(AVStream *st, const MatroskaTrack *track,
2405  void *logctx)
2406 {
2407  AVSphericalMapping *spherical;
2408  const MatroskaTrackVideoProjection *mkv_projection = &track->video.projection;
2409  const uint8_t *priv_data = mkv_projection->private.data;
2410  enum AVSphericalProjection projection;
2411  size_t spherical_size;
2412  uint32_t l = 0, t = 0, r = 0, b = 0;
2413  uint32_t padding = 0;
2414 
2415  if (mkv_projection->private.size && priv_data[0] != 0) {
2416  av_log(logctx, AV_LOG_WARNING, "Unknown spherical metadata\n");
2417  return 0;
2418  }
2419 
2420  switch (track->video.projection.type) {
2422  return mkv_create_display_matrix(st, mkv_projection, logctx);
2424  if (track->video.projection.private.size == 20) {
2425  t = AV_RB32(priv_data + 4);
2426  b = AV_RB32(priv_data + 8);
2427  l = AV_RB32(priv_data + 12);
2428  r = AV_RB32(priv_data + 16);
2429 
2430  if (b >= UINT_MAX - t || r >= UINT_MAX - l) {
2431  av_log(logctx, AV_LOG_ERROR,
2432  "Invalid bounding rectangle coordinates "
2433  "%"PRIu32",%"PRIu32",%"PRIu32",%"PRIu32"\n",
2434  l, t, r, b);
2435  return AVERROR_INVALIDDATA;
2436  }
2437  } else if (track->video.projection.private.size != 0) {
2438  av_log(logctx, AV_LOG_ERROR, "Unknown spherical metadata\n");
2439  return AVERROR_INVALIDDATA;
2440  }
2441 
2442  if (l || t || r || b)
2443  projection = AV_SPHERICAL_EQUIRECTANGULAR_TILE;
2444  else
2445  projection = AV_SPHERICAL_EQUIRECTANGULAR;
2446  break;
2448  if (track->video.projection.private.size < 4) {
2449  av_log(logctx, AV_LOG_ERROR, "Missing projection private properties\n");
2450  return AVERROR_INVALIDDATA;
2451  } else if (track->video.projection.private.size == 12) {
2452  uint32_t layout = AV_RB32(priv_data + 4);
2453  if (layout) {
2454  av_log(logctx, AV_LOG_WARNING,
2455  "Unknown spherical cubemap layout %"PRIu32"\n", layout);
2456  return 0;
2457  }
2458  projection = AV_SPHERICAL_CUBEMAP;
2459  padding = AV_RB32(priv_data + 8);
2460  } else {
2461  av_log(logctx, AV_LOG_ERROR, "Unknown spherical metadata\n");
2462  return AVERROR_INVALIDDATA;
2463  }
2464  break;
2465  default:
2466  av_log(logctx, AV_LOG_WARNING,
2467  "Unknown spherical metadata type %"PRIu64"\n",
2468  track->video.projection.type);
2469  return 0;
2470  }
2471 
2472  spherical = av_spherical_alloc(&spherical_size);
2473  if (!spherical)
2474  return AVERROR(ENOMEM);
2475 
2476  spherical->projection = projection;
2477 
2478  spherical->yaw = (int32_t) (track->video.projection.yaw * (1 << 16));
2479  spherical->pitch = (int32_t) (track->video.projection.pitch * (1 << 16));
2480  spherical->roll = (int32_t) (track->video.projection.roll * (1 << 16));
2481 
2482  spherical->padding = padding;
2483 
2484  spherical->bound_left = l;
2485  spherical->bound_top = t;
2486  spherical->bound_right = r;
2487  spherical->bound_bottom = b;
2488 
2490  AV_PKT_DATA_SPHERICAL, spherical, spherical_size, 0)) {
2491  av_freep(&spherical);
2492  return AVERROR(ENOMEM);
2493  }
2494 
2495  return 0;
2496 }
2497 
2499  EbmlBin *bin)
2500 {
2501  return ff_isom_parse_dvcc_dvvc(s, st, bin->data, bin->size);
2502 }
2503 
2505 {
2506  const EbmlList *mappings_list = &track->block_addition_mappings;
2507  MatroskaBlockAdditionMapping *mappings = mappings_list->elem;
2508  int ret;
2509 
2510  for (int i = 0; i < mappings_list->nb_elem; i++) {
2511  MatroskaBlockAdditionMapping *mapping = &mappings[i];
2512  uint64_t type = mapping->type;
2513 
2514  switch (mapping->type) {
2517  "Explicit block Addition Mapping type \"Use BlockAddIDValue\", value %"PRIu64","
2518  " name \"%s\" found.\n", mapping->value, mapping->name ? mapping->name : "");
2520  // fall-through
2523  if (mapping->value != type) {
2524  int strict = s->strict_std_compliance >= FF_COMPLIANCE_STRICT;
2525  av_log(s, strict ? AV_LOG_ERROR : AV_LOG_WARNING,
2526  "Invalid Block Addition Value 0x%"PRIx64" for Block Addition Mapping Type "
2527  "0x%"PRIx64", name \"%s\"\n", mapping->value, mapping->type,
2528  mapping->name ? mapping->name : "");
2529  if (strict)
2530  return AVERROR_INVALIDDATA;
2531  }
2532  break;
2535  if ((ret = mkv_parse_dvcc_dvvc(s, st, track, &mapping->extradata)) < 0)
2536  return ret;
2537 
2538  break;
2539  default:
2541  "Unknown Block Addition Mapping type 0x%"PRIx64", value %"PRIu64", name \"%s\"\n",
2542  mapping->type, mapping->value, mapping->name ? mapping->name : "");
2543  if (mapping->value < 2) {
2544  int strict = s->strict_std_compliance >= FF_COMPLIANCE_STRICT;
2545  av_log(s, strict ? AV_LOG_ERROR : AV_LOG_WARNING,
2546  "Invalid Block Addition value 0x%"PRIu64" for unknown Block Addition Mapping "
2547  "type %"PRIx64", name \"%s\"\n", mapping->value, mapping->type,
2548  mapping->name ? mapping->name : "");
2549  if (strict)
2550  return AVERROR_INVALIDDATA;
2551  }
2552  break;
2553  }
2554  }
2555 
2556  return 0;
2557 }
2558 
2559 static int get_qt_codec(MatroskaTrack *track, uint32_t *fourcc, enum AVCodecID *codec_id)
2560 {
2561  const AVCodecTag *codec_tags;
2562 
2563  codec_tags = track->type == MATROSKA_TRACK_TYPE_VIDEO ?
2565 
2566  /* Normalize noncompliant private data that starts with the fourcc
2567  * by expanding/shifting the data by 4 bytes and storing the data
2568  * size at the start. */
2569  if (ff_codec_get_id(codec_tags, AV_RL32(track->codec_priv.data))) {
2570  int ret = av_buffer_realloc(&track->codec_priv.buf,
2572  if (ret < 0)
2573  return ret;
2574 
2575  track->codec_priv.data = track->codec_priv.buf->data;
2576  memmove(track->codec_priv.data + 4, track->codec_priv.data, track->codec_priv.size);
2577  track->codec_priv.size += 4;
2578  AV_WB32(track->codec_priv.data, track->codec_priv.size);
2579  }
2580 
2581  *fourcc = AV_RL32(track->codec_priv.data + 4);
2582  *codec_id = ff_codec_get_id(codec_tags, *fourcc);
2583 
2584  return 0;
2586 
2587 /* An enum with potential return values of the functions for parsing a track.
2588  * Apart from that all these functions can also indicate ordinary errors via
2589  * negative return values. */
2590 enum {
2591  SKIP_TRACK = 1,
2592 };
2593 
2594 #define AAC_MAX_EXTRADATA_SIZE 5
2595 #define TTA_EXTRADATA_SIZE 22
2596 #define WAVPACK_EXTRADATA_SIZE 2
2597 /* Performs the codec-specific part of parsing an audio track. */
2598 static int mka_parse_audio_codec(MatroskaTrack *track, AVCodecParameters *par,
2599  const MatroskaDemuxContext *matroska,
2600  AVFormatContext *s, int *extradata_offset)
2601 {
2602  uint8_t extradata[FFMAX3(AAC_MAX_EXTRADATA_SIZE,
2605  int extradata_size = 0; // > 0 means that the extradata buffer is used
2606  int ret;
2607 
2608  if (!strcmp(track->codec_id, "A_MS/ACM") &&
2609  track->codec_priv.size >= 14) {
2610  FFIOContext b;
2612  track->codec_priv.size);
2613  ret = ff_get_wav_header(s, &b.pub, par,
2614  track->codec_priv.size, 0);
2615  if (ret < 0)
2616  return ret;
2617  *extradata_offset = FFMIN(track->codec_priv.size, 18);
2618  return 0;
2619  } else if (!strcmp(track->codec_id, "A_QUICKTIME") &&
2620  /* Normally 36, but allow noncompliant private data */
2621  track->codec_priv.size >= 32) {
2622  enum AVCodecID codec_id;
2623  uint32_t fourcc;
2624  uint16_t sample_size;
2625 
2626  ret = get_qt_codec(track, &fourcc, &codec_id);
2627  if (ret < 0)
2628  return ret;
2629  sample_size = AV_RB16(track->codec_priv.data + 26);
2630  if (fourcc == 0) {
2631  if (sample_size == 8) {
2632  fourcc = MKTAG('r','a','w',' ');
2634  } else if (sample_size == 16) {
2635  fourcc = MKTAG('t','w','o','s');
2637  }
2638  }
2639  if ((fourcc == MKTAG('t','w','o','s') ||
2640  fourcc == MKTAG('s','o','w','t')) && sample_size == 8)
2642  par->codec_id = codec_id;
2643  par->codec_tag = fourcc;
2644  return 0;
2645  }
2646 
2647  switch (par->codec_id) {
2648  case AV_CODEC_ID_PCM_S16BE:
2649  switch (track->audio.bitdepth) {
2650  case 8:
2652  break;
2653  case 24:
2655  break;
2656  case 32:
2658  break;
2659  }
2660  break;
2661  case AV_CODEC_ID_PCM_S16LE:
2662  switch (track->audio.bitdepth) {
2663  case 8:
2665  break;
2666  case 24:
2668  break;
2669  case 32:
2671  break;
2672  }
2673  break;
2674  case AV_CODEC_ID_PCM_F32LE:
2675  if (track->audio.bitdepth == 64)
2677  break;
2678  case AV_CODEC_ID_AAC:
2679  if (!track->codec_priv.size) {
2680  int profile = matroska_aac_profile(track->codec_id);
2681  int sri = matroska_aac_sri(track->audio.samplerate);
2682 
2683  extradata[0] = (profile << 3) | ((sri & 0x0E) >> 1);
2684  extradata[1] = ((sri & 0x01) << 7) | (track->audio.channels << 3);
2685  if (strstr(track->codec_id, "SBR")) {
2686  sri = matroska_aac_sri(track->audio.out_samplerate);
2687  extradata[2] = 0x56;
2688  extradata[3] = 0xE5;
2689  extradata[4] = 0x80 | (sri << 3);
2690  extradata_size = 5;
2691  } else
2692  extradata_size = 2;
2693  }
2694  break;
2695  case AV_CODEC_ID_ALAC:
2696  if (track->codec_priv.size && track->codec_priv.size < INT_MAX - 12 - AV_INPUT_BUFFER_PADDING_SIZE) {
2697  /* Only ALAC's magic cookie is stored in Matroska's track headers.
2698  * Create the "atom size", "tag", and "tag version" fields the
2699  * decoder expects manually. */
2700  ret = ff_alloc_extradata(par, 12 + track->codec_priv.size);
2701  if (ret < 0)
2702  return ret;
2703  AV_WB32(par->extradata, par->extradata_size);
2704  AV_WB32(&par->extradata[4], MKBETAG('a', 'l', 'a', 'c'));
2705  AV_WB32(&par->extradata[8], 0);
2706  memcpy(&par->extradata[12], track->codec_priv.data,
2707  track->codec_priv.size);
2708  }
2709  break;
2710  case AV_CODEC_ID_TTA:
2711  {
2712  uint8_t *ptr;
2713  if (track->audio.channels > UINT16_MAX ||
2714  track->audio.bitdepth > UINT16_MAX) {
2715  av_log(matroska->ctx, AV_LOG_WARNING,
2716  "Too large audio channel number %"PRIu64
2717  " or bitdepth %"PRIu64". Skipping track.\n",
2718  track->audio.channels, track->audio.bitdepth);
2719  if (matroska->ctx->error_recognition & AV_EF_EXPLODE)
2720  return AVERROR_INVALIDDATA;
2721  else
2722  return SKIP_TRACK;
2723  }
2724  if (track->audio.out_samplerate < 0 || track->audio.out_samplerate > INT_MAX)
2725  return AVERROR_INVALIDDATA;
2726  extradata_size = TTA_EXTRADATA_SIZE;
2727  ptr = extradata;
2728  bytestream_put_be32(&ptr, AV_RB32("TTA1"));
2729  bytestream_put_le16(&ptr, 1);
2730  bytestream_put_le16(&ptr, track->audio.channels);
2731  bytestream_put_le16(&ptr, track->audio.bitdepth);
2732  bytestream_put_le32(&ptr, track->audio.out_samplerate);
2733  bytestream_put_le32(&ptr, av_rescale(matroska->duration * matroska->time_scale,
2734  track->audio.out_samplerate,
2735  AV_TIME_BASE * 1000));
2736  break;
2737  }
2738  case AV_CODEC_ID_RA_144:
2739  track->audio.out_samplerate = 8000;
2740  track->audio.channels = 1;
2741  break;
2742  case AV_CODEC_ID_RA_288:
2743  case AV_CODEC_ID_COOK:
2744  case AV_CODEC_ID_ATRAC3:
2745  case AV_CODEC_ID_SIPR:
2746  {
2747  const uint8_t *ptr = track->codec_priv.data;
2748  int flavor;
2749 
2750  if (!track->codec_priv.size)
2751  break;
2752 
2753  if (track->codec_priv.size < 46)
2754  return AVERROR_INVALIDDATA;
2755  ptr += 22;
2756  flavor = bytestream_get_be16(&ptr);
2757  track->audio.coded_framesize = bytestream_get_be32(&ptr);
2758  ptr += 12;
2759  track->audio.sub_packet_h = bytestream_get_be16(&ptr);
2760  track->audio.frame_size = bytestream_get_be16(&ptr);
2761  track->audio.sub_packet_size = bytestream_get_be16(&ptr);
2762  if (track->audio.coded_framesize <= 0 ||
2763  track->audio.sub_packet_h <= 0 ||
2764  track->audio.frame_size <= 0)
2765  return AVERROR_INVALIDDATA;
2766 
2767  if (par->codec_id == AV_CODEC_ID_RA_288) {
2768  if (track->audio.sub_packet_h & 1 || 2 * track->audio.frame_size
2769  != (int64_t)track->audio.sub_packet_h * track->audio.coded_framesize)
2770  return AVERROR_INVALIDDATA;
2771  par->block_align = track->audio.coded_framesize;
2772  track->codec_priv.size = 0;
2773  } else {
2774  if (par->codec_id == AV_CODEC_ID_SIPR) {
2775  static const int sipr_bit_rate[4] = { 6504, 8496, 5000, 16000 };
2776  if (flavor > 3)
2777  return AVERROR_INVALIDDATA;
2778  track->audio.sub_packet_size = ff_sipr_subpk_size[flavor];
2779  par->bit_rate = sipr_bit_rate[flavor];
2780  } else if (track->audio.sub_packet_size <= 0 ||
2781  track->audio.frame_size % track->audio.sub_packet_size)
2782  return AVERROR_INVALIDDATA;
2783  par->block_align = track->audio.sub_packet_size;
2784  *extradata_offset = 78;
2785  }
2786  track->audio.buf = av_malloc_array(track->audio.sub_packet_h,
2787  track->audio.frame_size);
2788  if (!track->audio.buf)
2789  return AVERROR(ENOMEM);
2790  break;
2791  }
2792  case AV_CODEC_ID_ATRAC1:
2793  /* ATRAC1 uses a constant frame size.
2794  * Typical ATRAC1 streams are either mono or stereo.
2795  * At most, ATRAC1 was used to store 8 channels of audio. */
2796  if (track->audio.channels > 8)
2797  return AVERROR_INVALIDDATA;
2798  par->block_align = track->audio.channels * 212;
2799  break;
2800  case AV_CODEC_ID_FLAC:
2801  if (track->codec_priv.size) {
2802  ret = matroska_parse_flac(s, track, extradata_offset);
2803  if (ret < 0)
2804  return ret;
2805  }
2806  break;
2807  case AV_CODEC_ID_WAVPACK:
2808  if (track->codec_priv.size < 2) {
2809  av_log(matroska->ctx, AV_LOG_INFO, "Assuming WavPack version 4.10 "
2810  "in absence of valid CodecPrivate.\n");
2811  extradata_size = WAVPACK_EXTRADATA_SIZE;
2812  AV_WL16(extradata, 0x410);
2813  }
2814  break;
2815  }
2816 
2817  if (extradata_size > 0) {
2818  ret = ff_alloc_extradata(par, extradata_size);
2819  if (ret < 0)
2820  return ret;
2821  memcpy(par->extradata, extradata, extradata_size);
2822  }
2823 
2824  return 0;
2825 }
2826 
2827 /* Performs the generic part of parsing an audio track. */
2828 static int mka_parse_audio(MatroskaTrack *track, AVStream *st,
2829  AVCodecParameters *par,
2830  const MatroskaDemuxContext *matroska,
2831  AVFormatContext *s, int *extradata_offset)
2832 {
2833  FFStream *const sti = ffstream(st);
2834  int ret;
2835 
2836  ret = mka_parse_audio_codec(track, par, matroska,
2837  s, extradata_offset);
2838  if (ret)
2839  return ret;
2840 
2842  par->sample_rate = track->audio.out_samplerate;
2843  // channel layout may be already set by codec private checks above
2844  if (!av_channel_layout_check(&par->ch_layout)) {
2846  par->ch_layout.nb_channels = track->audio.channels;
2847  }
2848  if (!par->bits_per_coded_sample)
2849  par->bits_per_coded_sample = track->audio.bitdepth;
2850  if (par->codec_id == AV_CODEC_ID_MP3 ||
2851  par->codec_id == AV_CODEC_ID_MLP ||
2852  par->codec_id == AV_CODEC_ID_TRUEHD)
2854  else if (par->codec_id != AV_CODEC_ID_AAC)
2856  if (track->codec_delay > 0) {
2858  (AVRational){1, 1000000000},
2859  (AVRational){1, par->codec_id == AV_CODEC_ID_OPUS ?
2860  48000 : par->sample_rate});
2861  }
2862  if (track->seek_preroll > 0) {
2863  par->seek_preroll = av_rescale_q(track->seek_preroll,
2864  (AVRational){1, 1000000000},
2865  (AVRational){1, par->sample_rate});
2866  }
2867 
2868  return 0;
2869 }
2870 
2871 /* Performs the codec-specific part of parsing a video track. */
2872 static int mkv_parse_video_codec(MatroskaTrack *track, AVCodecParameters *par,
2873  const MatroskaDemuxContext *matroska,
2874  int *extradata_offset)
2875 {
2876  if (!strcmp(track->codec_id, "V_MS/VFW/FOURCC") &&
2877  track->codec_priv.size >= 40) {
2878  track->ms_compat = 1;
2879  par->bits_per_coded_sample = AV_RL16(track->codec_priv.data + 14);
2880  par->codec_tag = AV_RL32(track->codec_priv.data + 16);
2882  par->codec_tag);
2883  if (!par->codec_id)
2885  par->codec_tag);
2886  *extradata_offset = 40;
2887  return 0;
2888  } else if (!strcmp(track->codec_id, "V_QUICKTIME") &&
2889  track->codec_priv.size >= 21) {
2890  enum AVCodecID codec_id;
2891  uint32_t fourcc;
2892  int ret = get_qt_codec(track, &fourcc, &codec_id);
2893  if (ret < 0)
2894  return ret;
2895  if (codec_id == AV_CODEC_ID_NONE && AV_RL32(track->codec_priv.data+4) == AV_RL32("SMI ")) {
2896  fourcc = MKTAG('S','V','Q','3');
2898  }
2899  par->codec_id = codec_id;
2900  if (codec_id == AV_CODEC_ID_NONE)
2901  av_log(matroska->ctx, AV_LOG_ERROR,
2902  "mov FourCC not found %s.\n", av_fourcc2str(fourcc));
2903  if (track->codec_priv.size >= 86) {
2904  FFIOContext b;
2905  unsigned bit_depth = AV_RB16(track->codec_priv.data + 82);
2907  track->codec_priv.size);
2908  if (ff_get_qtpalette(codec_id, &b.pub, track->palette)) {
2909  bit_depth &= 0x1F;
2910  track->has_palette = 1;
2911  }
2913  }
2914  par->codec_tag = fourcc;
2915  return 0;
2916  }
2917 
2918  switch (par->codec_id) {
2919  case AV_CODEC_ID_RV10:
2920  case AV_CODEC_ID_RV20:
2921  case AV_CODEC_ID_RV30:
2922  case AV_CODEC_ID_RV40:
2923  *extradata_offset = 26;
2924  break;
2925  case AV_CODEC_ID_PRORES:
2926  if (track->codec_priv.size == 4)
2927  par->codec_tag = AV_RL32(track->codec_priv.data);
2928  break;
2929  case AV_CODEC_ID_VP9:
2930  /* we don't need any value stored in CodecPrivate.
2931  * make sure that it's not exported as extradata. */
2932  track->codec_priv.size = 0;
2933  break;
2934  }
2935 
2936  return 0;
2937 }
2938 
2939 /* Performs the generic part of parsing a video track. */
2940 static int mkv_parse_video(MatroskaTrack *track, AVStream *st,
2941  AVCodecParameters *par,
2942  const MatroskaDemuxContext *matroska,
2943  int *extradata_offset)
2944 {
2945  FFStream *const sti = ffstream(st);
2947  int display_width_mul = 1;
2948  int display_height_mul = 1;
2949  int ret;
2950 
2951  if (track->video.color_space.size == 4)
2952  par->codec_tag = AV_RL32(track->video.color_space.data);
2953 
2954  ret = mkv_parse_video_codec(track, par, matroska,
2955  extradata_offset);
2956  if (ret < 0)
2957  return ret;
2958 
2960  par->width = track->video.pixel_width;
2961  par->height = track->video.pixel_height;
2962 
2964  par->field_order = mkv_field_order(matroska, track->video.field_order);
2967 
2970  &display_width_mul, &display_height_mul);
2971 
2973  if (track->video.display_width && track->video.display_height &&
2974  track->video.display_width != -1 && track->video.display_height != -1 &&
2975  track->video.cropped_height < INT64_MAX / track->video.display_width / display_width_mul &&
2976  track->video.cropped_width < INT64_MAX / track->video.display_height / display_height_mul)
2978  &st->sample_aspect_ratio.den,
2979  track->video.cropped_height * track->video.display_width * display_width_mul,
2980  track->video.cropped_width * track->video.display_height * display_height_mul,
2981  INT_MAX);
2982  }
2983  if (track->video.cropped_width != track->video.pixel_width ||
2984  track->video.cropped_height != track->video.pixel_height) {
2985  uint8_t *cropping;
2989  sizeof(uint32_t) * 4, 0);
2990  if (!sd)
2991  return AVERROR(ENOMEM);
2992 
2993  cropping = sd->data;
2994  bytestream_put_le32(&cropping, track->video.pixel_cropt);
2995  bytestream_put_le32(&cropping, track->video.pixel_cropb);
2996  bytestream_put_le32(&cropping, track->video.pixel_cropl);
2997  bytestream_put_le32(&cropping, track->video.pixel_cropr);
2998  }
2999  if (par->codec_id != AV_CODEC_ID_HEVC)
3001 
3002  if (track->default_duration) {
3003  int div = track->default_duration <= INT64_MAX ? 1 : 2;
3005  1000000000 / div, track->default_duration / div, 30000);
3006 #if FF_API_R_FRAME_RATE
3007  if ( st->avg_frame_rate.num < st->avg_frame_rate.den * 1000LL
3008  && st->avg_frame_rate.num > st->avg_frame_rate.den * 5LL)
3009  st->r_frame_rate = st->avg_frame_rate;
3010 #endif
3011  }
3012 
3013  /* export stereo mode flag as metadata tag */
3015  av_dict_set(&st->metadata, "stereo_mode", ff_matroska_video_stereo_mode[track->video.stereo_mode], 0);
3016 
3017  /* export alpha mode flag as metadata tag */
3018  if (track->video.alpha_mode)
3019  av_dict_set_int(&st->metadata, "alpha_mode", 1, 0);
3020 
3021  /* if we have virtual track, mark the real tracks */
3023  for (int j = 0; j < track->operation.combine_planes.nb_elem; j++) {
3024  MatroskaTrack *tracks = matroska->tracks.elem;
3025  char buf[32];
3027  continue;
3028  snprintf(buf, sizeof(buf), "%s_%d",
3030  for (int k = 0; k < matroska->tracks.nb_elem; k++)
3031  if (planes[j].uid == tracks[k].uid && tracks[k].stream) {
3032  av_dict_set(&tracks[k].stream->metadata,
3033  "stereo_mode", buf, 0);
3034  break;
3035  }
3036  }
3037  // add stream level stereo3d side data if it is a supported format
3041  int ret = mkv_stereo3d_conv(st, track->video.stereo_mode);
3042  if (ret < 0)
3043  return ret;
3044  }
3045 
3046  ret = mkv_parse_video_color(st, track);
3047  if (ret < 0)
3048  return ret;
3049  ret = mkv_parse_video_projection(st, track, matroska->ctx);
3050  if (ret < 0)
3051  return ret;
3052 
3053  return 0;
3054 }
3055 
3056 /* Performs the codec-specific part of parsing a subtitle track. */
3057 static int mkv_parse_subtitle_codec(MatroskaTrack *track, AVStream *st,
3058  AVCodecParameters *par,
3059  const MatroskaDemuxContext *matroska)
3060 {
3061  switch (par->codec_id) {
3063  if (track->codec_priv.size == 3) {
3064  int component_tag = track->codec_priv.data[0];
3065  int data_component_id = AV_RB16(track->codec_priv.data + 1);
3066 
3067  switch (data_component_id) {
3068  case 0x0008:
3069  // [0x30..0x37] are component tags utilized for
3070  // non-mobile captioning service ("profile A").
3071  if (component_tag >= 0x30 && component_tag <= 0x37) {
3073  }
3074  break;
3075  case 0x0012:
3076  // component tag 0x87 signifies a mobile/partial reception
3077  // (1seg) captioning service ("profile C").
3078  if (component_tag == 0x87) {
3080  }
3081  break;
3082  default:
3083  break;
3084  }
3085 
3086  if (par->profile == AV_PROFILE_UNKNOWN)
3087  av_log(matroska->ctx, AV_LOG_WARNING,
3088  "Unknown ARIB caption profile utilized: %02x / %04x\n",
3089  component_tag, data_component_id);
3090 
3091  track->codec_priv.size = 0;
3092  }
3093  break;
3094  case AV_CODEC_ID_WEBVTT:
3095  if (!strcmp(track->codec_id, "D_WEBVTT/CAPTIONS")) {
3097  } else if (!strcmp(track->codec_id, "D_WEBVTT/DESCRIPTIONS")) {
3099  } else if (!strcmp(track->codec_id, "D_WEBVTT/METADATA")) {
3101  }
3102  break;
3103  }
3104 
3105  return 0;
3106 }
3107 
3109 {
3110  MatroskaDemuxContext *matroska = s->priv_data;
3111  MatroskaTrack *tracks = matroska->tracks.elem;
3112  int i, j, ret;
3113 
3114  for (i = 0; i < matroska->tracks.nb_elem; i++) {
3115  MatroskaTrack *track = &tracks[i];
3117  AVCodecParameters *par;
3119  int extradata_offset = 0;
3120  AVStream *st;
3121  char* key_id_base64 = NULL;
3122 
3123  /* Apply some sanity checks. */
3124  if (track->type != MATROSKA_TRACK_TYPE_VIDEO &&
3125  track->type != MATROSKA_TRACK_TYPE_AUDIO &&
3126  track->type != MATROSKA_TRACK_TYPE_SUBTITLE &&
3127  track->type != MATROSKA_TRACK_TYPE_METADATA) {
3128  av_log(matroska->ctx, AV_LOG_INFO,
3129  "Unknown or unsupported track type %"PRIu64"\n",
3130  track->type);
3131  continue;
3132  }
3133  if (!track->codec_id)
3134  continue;
3135 
3136  if ( track->type == MATROSKA_TRACK_TYPE_AUDIO && track->codec_id[0] != 'A'
3137  || track->type == MATROSKA_TRACK_TYPE_VIDEO && track->codec_id[0] != 'V'
3138  || track->type == MATROSKA_TRACK_TYPE_SUBTITLE && track->codec_id[0] != 'D' && track->codec_id[0] != 'S'
3139  || track->type == MATROSKA_TRACK_TYPE_METADATA && track->codec_id[0] != 'D' && track->codec_id[0] != 'S'
3140  ) {
3141  av_log(matroska->ctx, AV_LOG_INFO, "Inconsistent track type\n");
3142  continue;
3143  }
3144 
3145  if (track->audio.samplerate < 0 || track->audio.samplerate > INT_MAX ||
3146  isnan(track->audio.samplerate)) {
3147  av_log(matroska->ctx, AV_LOG_WARNING,
3148  "Invalid sample rate %f, defaulting to 8000 instead.\n",
3149  track->audio.samplerate);
3150  track->audio.samplerate = 8000;
3151  }
3152 
3153  if (track->type == MATROSKA_TRACK_TYPE_VIDEO) {
3154  if (!track->default_duration && track->video.frame_rate > 0) {
3155  double default_duration = 1000000000 / track->video.frame_rate;
3156  if (default_duration > UINT64_MAX || default_duration < 0) {
3157  av_log(matroska->ctx, AV_LOG_WARNING,
3158  "Invalid frame rate %e. Cannot calculate default duration.\n",
3159  track->video.frame_rate);
3160  } else {
3161  track->default_duration = default_duration;
3162  }
3163  }
3164  if (track->video.pixel_cropl >= INT_MAX - track->video.pixel_cropr ||
3165  track->video.pixel_cropt >= INT_MAX - track->video.pixel_cropb ||
3166  (track->video.pixel_cropl + track->video.pixel_cropr) >= track->video.pixel_width ||
3167  (track->video.pixel_cropt + track->video.pixel_cropb) >= track->video.pixel_height)
3168  return AVERROR_INVALIDDATA;
3169  track->video.cropped_width = track->video.pixel_width -
3170  track->video.pixel_cropl - track->video.pixel_cropr;
3171  track->video.cropped_height = track->video.pixel_height -
3172  track->video.pixel_cropt - track->video.pixel_cropb;
3174  if (track->video.display_width == -1)
3175  track->video.display_width = track->video.cropped_width;
3176  if (track->video.display_height == -1)
3177  track->video.display_height = track->video.cropped_height;
3178  }
3179  } else if (track->type == MATROSKA_TRACK_TYPE_AUDIO) {
3180  if (!track->audio.out_samplerate)
3181  track->audio.out_samplerate = track->audio.samplerate;
3182  }
3184  track->encodings.nb_elem,
3185  track, &key_id_base64, matroska->ctx);
3186  if (ret < 0)
3187  return ret;
3188 
3189  for (j = 0; ff_mkv_codec_tags[j].id != AV_CODEC_ID_NONE; j++) {
3190  if (av_strstart(track->codec_id, ff_mkv_codec_tags[j].str, NULL)) {
3192  break;
3193  }
3194  }
3195 
3196  st = track->stream = avformat_new_stream(s, NULL);
3197  if (!st) {
3198  av_free(key_id_base64);
3199  return AVERROR(ENOMEM);
3200  }
3201  par = st->codecpar;
3202 
3203  par->codec_id = codec_id;
3204 
3205  if (track->flag_default)
3207  if (track->flag_forced)
3209  if (track->flag_comment)
3211  if (track->flag_hearingimpaired)
3213  if (track->flag_visualimpaired)
3215  if (track->flag_original.count > 0)
3218 
3219  if (key_id_base64) {
3220  /* export encryption key id as base64 metadata tag */
3221  av_dict_set(&st->metadata, "enc_key_id", key_id_base64,
3223  }
3224 
3225  if (strcmp(track->language, "und"))
3226  av_dict_set(&st->metadata, "language", track->language, 0);
3227  av_dict_set(&st->metadata, "title", track->name, 0);
3228 
3229  if (track->time_scale < 0.01) {
3230  av_log(matroska->ctx, AV_LOG_WARNING,
3231  "Track TimestampScale too small %f, assuming 1.0.\n",
3232  track->time_scale);
3233  track->time_scale = 1.0;
3234  }
3235 
3236  if (matroska->time_scale * track->time_scale > UINT_MAX)
3237  return AVERROR_INVALIDDATA;
3238 
3239  avpriv_set_pts_info(st, 64, matroska->time_scale * track->time_scale,
3240  1000 * 1000 * 1000); /* 64 bit pts in ns */
3241 
3242  /* convert the delay from ns to the track timebase */
3244  (AVRational){ 1, 1000000000 },
3245  st->time_base);
3246 
3247  type = track->type;
3248  if (par->codec_id == AV_CODEC_ID_WEBVTT)
3250  switch (type) {
3252  ret = mka_parse_audio(track, st, par, matroska,
3253  s, &extradata_offset);
3254  if (ret < 0)
3255  return ret;
3256  if (ret == SKIP_TRACK)
3257  continue;
3258  break;
3260  ret = mkv_parse_video(track, st, par, matroska, &extradata_offset);
3261  if (ret < 0)
3262  return ret;
3263  break;
3265  ret = mkv_parse_subtitle_codec(track, st, par, matroska);
3266  if (ret < 0)
3267  return ret;
3269 
3270  if (track->flag_textdescriptions)
3272  break;
3273  }
3274 
3275  if (par->codec_id == AV_CODEC_ID_NONE)
3276  av_log(matroska->ctx, AV_LOG_INFO,
3277  "Unknown/unsupported AVCodecID %s.\n", track->codec_id);
3278 
3279  if (!par->extradata && track->codec_priv.size > extradata_offset) {
3280  const uint8_t *src = track->codec_priv.data + extradata_offset;
3281  unsigned extra_size = track->codec_priv.size - extradata_offset;
3282  ret = ff_alloc_extradata(par, extra_size);
3283  if (ret < 0)
3284  return ret;
3285  memcpy(par->extradata, src, extra_size);
3286  }
3287 
3288  ret = mkv_parse_block_addition_mappings(s, st, track);
3289  if (ret < 0)
3290  return ret;
3291  }
3292 
3293  return 0;
3294 }
3295 
3297 {
3298  FFFormatContext *const si = ffformatcontext(s);
3299  MatroskaDemuxContext *matroska = s->priv_data;
3300  EbmlList *attachments_list = &matroska->attachments;
3301  EbmlList *chapters_list = &matroska->chapters;
3302  MatroskaAttachment *attachments;
3303  MatroskaChapter *chapters;
3304  uint64_t max_start = 0;
3305  int64_t pos;
3306  Ebml ebml = { 0 };
3307  int i, j, res;
3308 
3309  matroska->ctx = s;
3310  matroska->cues_parsing_deferred = 1;
3311 
3312  /* First read the EBML header. */
3313  if (ebml_parse(matroska, ebml_syntax, &ebml) || !ebml.doctype) {
3314  av_log(matroska->ctx, AV_LOG_ERROR, "EBML header parsing failed\n");
3315  ebml_free(ebml_syntax, &ebml);
3316  return AVERROR_INVALIDDATA;
3317  }
3318  if (ebml.version > EBML_VERSION ||
3319  ebml.max_size > sizeof(uint64_t) ||
3320  ebml.id_length > sizeof(uint32_t) ||
3321  ebml.doctype_version > 3) {
3323  "EBML version %"PRIu64", doctype %s, doc version %"PRIu64,
3324  ebml.version, ebml.doctype, ebml.doctype_version);
3325  ebml_free(ebml_syntax, &ebml);
3326  return AVERROR_PATCHWELCOME;
3327  } else if (ebml.doctype_version == 3) {
3328  av_log(matroska->ctx, AV_LOG_WARNING,
3329  "EBML header using unsupported features\n"
3330  "(EBML version %"PRIu64", doctype %s, doc version %"PRIu64")\n",
3331  ebml.version, ebml.doctype, ebml.doctype_version);
3332  }
3333  for (i = 0; i < FF_ARRAY_ELEMS(matroska_doctypes); i++)
3334  if (!strcmp(ebml.doctype, matroska_doctypes[i]))
3335  break;
3337  av_log(s, AV_LOG_WARNING, "Unknown EBML doctype '%s'\n", ebml.doctype);
3338  if (matroska->ctx->error_recognition & AV_EF_EXPLODE) {
3339  ebml_free(ebml_syntax, &ebml);
3340  return AVERROR_INVALIDDATA;
3341  }
3342  }
3343  matroska->is_webm = !strcmp(ebml.doctype, "webm");
3344 
3345  ebml_free(ebml_syntax, &ebml);
3346 
3347  matroska->pkt = si->parse_pkt;
3348 
3349  /* The next thing is a segment. */
3350  pos = avio_tell(matroska->ctx->pb);
3351  res = ebml_parse(matroska, matroska_segments, matroska);
3352  // Try resyncing until we find an EBML_STOP type element.
3353  while (res != 1) {
3354  res = matroska_resync(matroska, pos);
3355  if (res < 0)
3356  return res;
3357  pos = avio_tell(matroska->ctx->pb);
3358  res = ebml_parse(matroska, matroska_segment, matroska);
3359  if (res == AVERROR(EIO)) // EOF is translated to EIO, this exists the loop on EOF
3360  return res;
3361  }
3362  /* Set data_offset as it might be needed later by seek_frame_generic. */
3363  if (matroska->current_id == MATROSKA_ID_CLUSTER)
3364  si->data_offset = avio_tell(matroska->ctx->pb) - 4;
3365  matroska_execute_seekhead(matroska);
3366 
3367  if (!matroska->time_scale)
3368  matroska->time_scale = 1000000;
3369  if (isnan(matroska->duration))
3370  matroska->duration = 0;
3371  if (matroska->duration)
3372  matroska->ctx->duration = matroska->duration * matroska->time_scale *
3373  1000 / AV_TIME_BASE;
3374  av_dict_set(&s->metadata, "title", matroska->title, 0);
3375  av_dict_set(&s->metadata, "encoder", matroska->muxingapp, 0);
3376 
3377  if (matroska->date_utc.size == 8)
3378  matroska_metadata_creation_time(&s->metadata, AV_RB64(matroska->date_utc.data));
3379 
3380  res = matroska_parse_tracks(s);
3381  if (res < 0)
3382  return res;
3383 
3384  attachments = attachments_list->elem;
3385  for (j = 0; j < attachments_list->nb_elem; j++) {
3386  if (!(attachments[j].filename && attachments[j].mime &&
3387  attachments[j].bin.data && attachments[j].bin.size > 0)) {
3388  av_log(matroska->ctx, AV_LOG_ERROR, "incomplete attachment\n");
3389  } else {
3391  if (!st)
3392  break;
3393  av_dict_set(&st->metadata, "filename", attachments[j].filename, 0);
3394  av_dict_set(&st->metadata, "mimetype", attachments[j].mime, 0);
3395  if (attachments[j].description)
3396  av_dict_set(&st->metadata, "title", attachments[j].description, 0);
3398 
3399  for (i = 0; mkv_image_mime_tags[i].id != AV_CODEC_ID_NONE; i++) {
3400  if (av_strstart(attachments[j].mime, mkv_image_mime_tags[i].str, NULL)) {
3402  break;
3403  }
3404  }
3405 
3406  attachments[j].stream = st;
3407 
3408  if (st->codecpar->codec_id != AV_CODEC_ID_NONE) {
3409  res = ff_add_attached_pic(s, st, NULL, &attachments[j].bin.buf, 0);
3410  if (res < 0)
3411  return res;
3412  } else {
3414  if (ff_alloc_extradata(st->codecpar, attachments[j].bin.size))
3415  break;
3416  memcpy(st->codecpar->extradata, attachments[j].bin.data,
3417  attachments[j].bin.size);
3418 
3419  for (i = 0; mkv_mime_tags[i].id != AV_CODEC_ID_NONE; i++) {
3420  if (av_strstart(attachments[j].mime, mkv_mime_tags[i].str, NULL)) {
3422  break;
3423  }
3424  }
3425  }
3426  }
3427  }
3428 
3429  chapters = chapters_list->elem;
3430  for (i = 0; i < chapters_list->nb_elem; i++)
3431  if (chapters[i].start != AV_NOPTS_VALUE && chapters[i].uid &&
3432  (max_start == 0 || chapters[i].start > max_start)) {
3433  chapters[i].chapter =
3434  avpriv_new_chapter(s, chapters[i].uid,
3435  (AVRational) { 1, 1000000000 },
3436  chapters[i].start, chapters[i].end,
3437  chapters[i].title);
3438  max_start = chapters[i].start;
3439  }
3440 
3441  matroska_add_index_entries(matroska);
3442 
3444 
3445  return 0;
3447 
3448 /*
3449  * Put one packet in an application-supplied AVPacket struct.
3450  * Returns 0 on success or -1 on failure.
3451  */
3452 static int matroska_deliver_packet(MatroskaDemuxContext *matroska,
3453  AVPacket *pkt)
3454 {
3455  if (matroska->queue.head) {
3456  MatroskaTrack *tracks = matroska->tracks.elem;
3457  MatroskaTrack *track;
3458 
3459  avpriv_packet_list_get(&matroska->queue, pkt);
3460  track = &tracks[pkt->stream_index];
3461  if (track->has_palette) {
3463  if (!pal) {
3464  av_log(matroska->ctx, AV_LOG_ERROR, "Cannot append palette to packet\n");
3465  } else {
3466  memcpy(pal, track->palette, AVPALETTE_SIZE);
3467  }
3468  track->has_palette = 0;
3469  }
3470  return 0;
3471  }
3472 
3473  return -1;
3474 }
3475 
3476 /*
3477  * Free all packets in our internal queue.
3478  */
3479 static void matroska_clear_queue(MatroskaDemuxContext *matroska)
3480 {
3481  avpriv_packet_list_free(&matroska->queue);
3482 }
3483 
3484 static int matroska_parse_laces(MatroskaDemuxContext *matroska, uint8_t **buf,
3485  int size, int type, AVIOContext *pb,
3486  uint32_t lace_size[256], int *laces)
3487 {
3488  int n;
3489  uint8_t *data = *buf;
3490 
3491  if (!type) {
3492  *laces = 1;
3493  lace_size[0] = size;
3494  return 0;
3495  }
3496 
3497  if (size <= 0)
3498  return AVERROR_INVALIDDATA;
3499 
3500  *laces = *data + 1;
3501  data += 1;
3502  size -= 1;
3503 
3504  switch (type) {
3505  case 0x1: /* Xiph lacing */
3506  {
3507  uint8_t temp;
3508  uint32_t total = 0;
3509  for (n = 0; n < *laces - 1; n++) {
3510  lace_size[n] = 0;
3511 
3512  do {
3513  if (size <= total)
3514  return AVERROR_INVALIDDATA;
3515  temp = *data;
3516  total += temp;
3517  lace_size[n] += temp;
3518  data += 1;
3519  size -= 1;
3520  } while (temp == 0xff);
3521  }
3522  if (size < total)
3523  return AVERROR_INVALIDDATA;
3524 
3525  lace_size[n] = size - total;
3526  break;
3527  }
3528 
3529  case 0x2: /* fixed-size lacing */
3530  if (size % (*laces))
3531  return AVERROR_INVALIDDATA;
3532  for (n = 0; n < *laces; n++)
3533  lace_size[n] = size / *laces;
3534  break;
3535 
3536  case 0x3: /* EBML lacing */
3537  {
3538  uint64_t num;
3539  uint64_t total;
3540  int offset;
3541 
3542  avio_skip(pb, 4);
3543 
3544  n = ebml_read_num(matroska, pb, 8, &num, 1);
3545  if (n < 0)
3546  return n;
3547  if (num > INT_MAX)
3548  return AVERROR_INVALIDDATA;
3549 
3550  total = lace_size[0] = num;
3551  offset = n;
3552  for (n = 1; n < *laces - 1; n++) {
3553  int64_t snum;
3554  int r;
3555  r = matroska_ebmlnum_sint(matroska, pb, &snum);
3556  if (r < 0)
3557  return r;
3558  if (lace_size[n - 1] + snum > (uint64_t)INT_MAX)
3559  return AVERROR_INVALIDDATA;
3560 
3561  lace_size[n] = lace_size[n - 1] + snum;
3562  total += lace_size[n];
3563  offset += r;
3564  }
3565  data += offset;
3566  size -= offset;
3567  if (size < total)
3568  return AVERROR_INVALIDDATA;
3569 
3570  lace_size[*laces - 1] = size - total;
3571  break;
3572  }
3573  }
3575  *buf = data;
3576 
3577  return 0;
3578 }
3579 
3580 static int matroska_parse_rm_audio(MatroskaDemuxContext *matroska,
3581  MatroskaTrack *track, AVStream *st,
3582  uint8_t *data, int size, uint64_t timecode,
3583  int64_t pos)
3584 {
3585  const int a = st->codecpar->block_align;
3586  const int sps = track->audio.sub_packet_size;
3587  const int cfs = track->audio.coded_framesize;
3588  const int h = track->audio.sub_packet_h;
3589  const int w = track->audio.frame_size;
3590  int y = track->audio.sub_packet_cnt;
3591  int x;
3592 
3593  if (!track->audio.pkt_cnt) {
3594  if (track->audio.sub_packet_cnt == 0)
3595  track->audio.buf_timecode = timecode;
3596  if (st->codecpar->codec_id == AV_CODEC_ID_RA_288) {
3597  if (size < cfs * h / 2) {
3598  av_log(matroska->ctx, AV_LOG_ERROR,
3599  "Corrupt int4 RM-style audio packet size\n");
3600  return AVERROR_INVALIDDATA;
3601  }
3602  for (x = 0; x < h / 2; x++)
3603  memcpy(track->audio.buf + x * 2 * w + y * cfs,
3604  data + x * cfs, cfs);
3605  } else if (st->codecpar->codec_id == AV_CODEC_ID_SIPR) {
3606  if (size < w) {
3607  av_log(matroska->ctx, AV_LOG_ERROR,
3608  "Corrupt sipr RM-style audio packet size\n");
3609  return AVERROR_INVALIDDATA;
3610  }
3611  memcpy(track->audio.buf + y * w, data, w);
3612  } else {
3613  if (size < w) {
3614  av_log(matroska->ctx, AV_LOG_ERROR,
3615  "Corrupt generic RM-style audio packet size\n");
3616  return AVERROR_INVALIDDATA;
3617  }
3618  for (x = 0; x < w / sps; x++)
3619  memcpy(track->audio.buf +
3620  sps * (h * x + ((h + 1) / 2) * (y & 1) + (y >> 1)),
3621  data + x * sps, sps);
3622  }
3623 
3624  if (++track->audio.sub_packet_cnt >= h) {
3625  if (st->codecpar->codec_id == AV_CODEC_ID_SIPR)
3626  ff_rm_reorder_sipr_data(track->audio.buf, h, w);
3627  track->audio.sub_packet_cnt = 0;
3628  track->audio.pkt_cnt = h * w / a;
3629  }
3630  }
3631 
3632  while (track->audio.pkt_cnt) {
3633  int ret;
3634  AVPacket *pkt = matroska->pkt;
3635 
3636  ret = av_new_packet(pkt, a);
3637  if (ret < 0) {
3638  return ret;
3639  }
3640  memcpy(pkt->data,
3641  track->audio.buf + a * (h * w / a - track->audio.pkt_cnt--),
3642  a);
3643  pkt->pts = track->audio.buf_timecode;
3645  pkt->pos = pos;
3646  pkt->stream_index = st->index;
3647  ret = avpriv_packet_list_put(&matroska->queue, pkt, NULL, 0);
3648  if (ret < 0) {
3650  return AVERROR(ENOMEM);
3651  }
3652  }
3653 
3654  return 0;
3655 }
3656 
3657 /* reconstruct full wavpack blocks from mangled matroska ones */
3658 static int matroska_parse_wavpack(MatroskaTrack *track,
3659  uint8_t **data, int *size)
3660 {
3661  uint8_t *dst = NULL;
3662  uint8_t *src = *data;
3663  int dstlen = 0;
3664  int srclen = *size;
3665  uint32_t samples;
3666  uint16_t ver;
3667  int ret, offset = 0;
3668 
3669  if (srclen < 12)
3670  return AVERROR_INVALIDDATA;
3671 
3672  av_assert1(track->stream->codecpar->extradata_size >= 2);
3673  ver = AV_RL16(track->stream->codecpar->extradata);
3674 
3675  samples = AV_RL32(src);
3676  src += 4;
3677  srclen -= 4;
3678 
3679  while (srclen >= 8) {
3680  int multiblock;
3681  uint32_t blocksize;
3682  uint8_t *tmp;
3683 
3684  uint32_t flags = AV_RL32(src);
3685  uint32_t crc = AV_RL32(src + 4);
3686  src += 8;
3687  srclen -= 8;
3688 
3689  multiblock = (flags & 0x1800) != 0x1800;
3690  if (multiblock) {
3691  if (srclen < 4) {
3693  goto fail;
3694  }
3695  blocksize = AV_RL32(src);
3696  src += 4;
3697  srclen -= 4;
3698  } else
3699  blocksize = srclen;
3700 
3701  if (blocksize > srclen) {
3703  goto fail;
3704  }
3705 
3706  tmp = av_realloc(dst, dstlen + blocksize + 32 + AV_INPUT_BUFFER_PADDING_SIZE);
3707  if (!tmp) {
3708  ret = AVERROR(ENOMEM);
3709  goto fail;
3710  }
3711  dst = tmp;
3712  dstlen += blocksize + 32;
3713 
3714  AV_WL32(dst + offset, MKTAG('w', 'v', 'p', 'k')); // tag
3715  AV_WL32(dst + offset + 4, blocksize + 24); // blocksize - 8
3716  AV_WL16(dst + offset + 8, ver); // version
3717  AV_WL16(dst + offset + 10, 0); // track/index_no
3718  AV_WL32(dst + offset + 12, 0); // total samples
3719  AV_WL32(dst + offset + 16, 0); // block index
3720  AV_WL32(dst + offset + 20, samples); // number of samples
3721  AV_WL32(dst + offset + 24, flags); // flags
3722  AV_WL32(dst + offset + 28, crc); // crc
3723  memcpy(dst + offset + 32, src, blocksize); // block data
3724 
3725  src += blocksize;
3726  srclen -= blocksize;
3727  offset += blocksize + 32;
3728  }
3729 
3730  memset(dst + dstlen, 0, AV_INPUT_BUFFER_PADDING_SIZE);
3731 
3732  *data = dst;
3733  *size = dstlen;
3734 
3735  return 0;
3737 fail:
3738  av_freep(&dst);
3739  return ret;
3740 }
3741 
3742 static int matroska_parse_prores(MatroskaTrack *track,
3743  uint8_t **data, int *size)
3744 {
3745  uint8_t *dst;
3746  int dstlen = *size + 8;
3747 
3749  if (!dst)
3750  return AVERROR(ENOMEM);
3751 
3752  AV_WB32(dst, dstlen);
3753  AV_WB32(dst + 4, MKBETAG('i', 'c', 'p', 'f'));
3754  memcpy(dst + 8, *data, dstlen - 8);
3755  memset(dst + dstlen, 0, AV_INPUT_BUFFER_PADDING_SIZE);
3756 
3757  *data = dst;
3758  *size = dstlen;
3759 
3760  return 0;
3761 }
3762 
3763 static int matroska_parse_webvtt(MatroskaDemuxContext *matroska,
3764  MatroskaTrack *track,
3765  AVStream *st,
3766  uint8_t *data, int data_len,
3767  uint64_t timecode,
3768  uint64_t duration,
3769  int64_t pos)
3770 {
3771  AVPacket *pkt = matroska->pkt;
3772  uint8_t *id, *settings, *text, *buf;
3773  int id_len, settings_len, text_len;
3774  uint8_t *p, *q;
3775  int err;
3776 
3777  if (data_len <= 0)
3778  return AVERROR_INVALIDDATA;
3779 
3780  p = data;
3781  q = data + data_len;
3782 
3783  id = p;
3784  id_len = -1;
3785  while (p < q) {
3786  if (*p == '\r' || *p == '\n') {
3787  id_len = p - id;
3788  if (*p == '\r')
3789  p++;
3790  break;
3791  }
3792  p++;
3793  }
3794 
3795  if (p >= q || *p != '\n')
3796  return AVERROR_INVALIDDATA;
3797  p++;
3798 
3799  settings = p;
3800  settings_len = -1;
3801  while (p < q) {
3802  if (*p == '\r' || *p == '\n') {
3803  settings_len = p - settings;
3804  if (*p == '\r')
3805  p++;
3806  break;
3807  }
3808  p++;
3809  }
3810 
3811  if (p >= q || *p != '\n')
3812  return AVERROR_INVALIDDATA;
3813  p++;
3814 
3815  text = p;
3816  text_len = q - p;
3817  while (text_len > 0) {
3818  const int len = text_len - 1;
3819  const uint8_t c = p[len];
3820  if (c != '\r' && c != '\n')
3821  break;
3822  text_len = len;
3823  }
3824 
3825  if (text_len <= 0)
3826  return AVERROR_INVALIDDATA;
3827 
3828  err = av_new_packet(pkt, text_len);
3829  if (err < 0) {
3830  return err;
3831  }
3832 
3833  memcpy(pkt->data, text, text_len);
3834 
3835  if (id_len > 0) {
3838  id_len);
3839  if (!buf) {
3841  return AVERROR(ENOMEM);
3842  }
3843  memcpy(buf, id, id_len);
3844  }
3845 
3846  if (settings_len > 0) {
3849  settings_len);
3850  if (!buf) {
3852  return AVERROR(ENOMEM);
3853  }
3854  memcpy(buf, settings, settings_len);
3855  }
3856 
3857  // Do we need this for subtitles?
3858  // pkt->flags = AV_PKT_FLAG_KEY;
3859 
3860  pkt->stream_index = st->index;
3861  pkt->pts = timecode;
3862 
3863  // Do we need this for subtitles?
3864  // pkt->dts = timecode;
3865 
3866  pkt->duration = duration;
3867  pkt->pos = pos;
3868 
3869  err = avpriv_packet_list_put(&matroska->queue, pkt, NULL, 0);
3870  if (err < 0) {
3872  return AVERROR(ENOMEM);
3873  }
3874 
3875  return 0;
3876 }
3877 
3879  MatroskaTrack *track, AVPacket *pkt,
3880  const uint8_t *data, int size, uint64_t id)
3881 {
3882  const EbmlList *mappings_list = &track->block_addition_mappings;
3883  MatroskaBlockAdditionMapping *mappings = mappings_list->elem, *mapping = NULL;
3884  uint8_t *side_data;
3885  int res;
3886 
3887  if (!matroska->is_webm && track->max_block_additional_id && id > track->max_block_additional_id) {
3888  int strict = matroska->ctx->strict_std_compliance >= FF_COMPLIANCE_STRICT;
3889  av_log(matroska->ctx, strict ? AV_LOG_ERROR : AV_LOG_WARNING,
3890  "BlockAddID %"PRIu64" is higher than the reported MaxBlockAdditionID %"PRIu64" "
3891  "for Track with TrackNumber %"PRIu64"\n", id, track->max_block_additional_id,
3892  track->num);
3893  if (strict)
3894  return AVERROR_INVALIDDATA;
3895  }
3896 
3897  for (int i = 0; i < mappings_list->nb_elem; i++) {
3898  if (id != mappings[i].value)
3899  continue;
3900  mapping = &mappings[i];
3901  break;
3902  }
3903 
3904  if (id != 1 && !matroska->is_webm && !mapping) {
3905  av_log(matroska->ctx, AV_LOG_WARNING, "BlockAddID %"PRIu64" has no mapping. Skipping\n", id);
3906  return 0;
3907  }
3908 
3909  if (mapping && mapping->type)
3910  id = mapping->type;
3911 
3912  switch (id) {
3914  GetByteContext bc;
3915  int country_code, provider_code;
3916  int provider_oriented_code, application_identifier;
3917  size_t hdrplus_size;
3918  AVDynamicHDRPlus *hdrplus;
3919 
3920  if (size < 6)
3921  break; //ignore
3922 
3923  bytestream2_init(&bc, data, size);
3924 
3925  /* ITU-T T.35 metadata */
3926  country_code = bytestream2_get_byteu(&bc);
3927  provider_code = bytestream2_get_be16u(&bc);
3928 
3929  if (country_code != ITU_T_T35_COUNTRY_CODE_US ||
3930  provider_code != ITU_T_T35_PROVIDER_CODE_SMTPE)
3931  break; // ignore
3932 
3933  provider_oriented_code = bytestream2_get_be16u(&bc);
3934  application_identifier = bytestream2_get_byteu(&bc);
3935 
3936  if (provider_oriented_code != 1 || application_identifier != 4)
3937  break; // ignore
3938 
3939  hdrplus = av_dynamic_hdr_plus_alloc(&hdrplus_size);
3940  if (!hdrplus)
3941  return AVERROR(ENOMEM);
3942 
3943  if ((res = av_dynamic_hdr_plus_from_t35(hdrplus, bc.buffer,
3944  bytestream2_get_bytes_left(&bc))) < 0 ||
3946  (uint8_t *)hdrplus, hdrplus_size)) < 0) {
3947  av_free(hdrplus);
3948  return res;
3949  }
3950 
3951  return 0;
3952  }
3953  default:
3954  break;
3955  }
3956 
3958  size + (size_t)8);
3959  if (!side_data)
3960  return AVERROR(ENOMEM);
3961 
3962  AV_WB64(side_data, id);
3963  memcpy(side_data + 8, data, size);
3964 
3965  return 0;
3966 }
3967 
3968 static int matroska_parse_frame(MatroskaDemuxContext *matroska,
3969  MatroskaTrack *track, AVStream *st,
3970  AVBufferRef *buf, uint8_t *data, int pkt_size,
3971  uint64_t timecode, uint64_t lace_duration,
3972  int64_t pos, int is_keyframe,
3973  MatroskaBlockMore *blockmore, int nb_blockmore,
3974  int64_t discard_padding)
3975 {
3976  uint8_t *pkt_data = data;
3977  int res = 0;
3978  AVPacket *pkt = matroska->pkt;
3979 
3980  if (st->codecpar->codec_id == AV_CODEC_ID_WAVPACK) {
3981  res = matroska_parse_wavpack(track, &pkt_data, &pkt_size);
3982  if (res < 0) {
3983  av_log(matroska->ctx, AV_LOG_ERROR,
3984  "Error parsing a wavpack block.\n");
3985  goto fail;
3986  }
3987  if (!buf)
3988  av_freep(&data);
3989  buf = NULL;
3990  }
3991 
3992  if (st->codecpar->codec_id == AV_CODEC_ID_PRORES &&
3993  AV_RB32(pkt_data + 4) != MKBETAG('i', 'c', 'p', 'f')) {
3994  res = matroska_parse_prores(track, &pkt_data, &pkt_size);
3995  if (res < 0) {
3996  av_log(matroska->ctx, AV_LOG_ERROR,
3997  "Error parsing a prores block.\n");
3998  goto fail;
3999  }
4000  if (!buf)
4001  av_freep(&data);
4002  buf = NULL;
4003  }
4004 
4005  if (!pkt_size && !nb_blockmore)
4006  goto no_output;
4007 
4008  if (!matroska->is_webm && nb_blockmore && !track->max_block_additional_id) {
4009  int strict = matroska->ctx->strict_std_compliance >= FF_COMPLIANCE_STRICT;
4010  av_log(matroska->ctx, strict ? AV_LOG_ERROR : AV_LOG_WARNING,
4011  "Unexpected BlockAdditions found in a Block from Track with TrackNumber %"PRIu64" "
4012  "where MaxBlockAdditionID is 0\n", track->num);
4013  if (strict) {
4014  res = AVERROR_INVALIDDATA;
4015  goto fail;
4016  }
4017  }
4018 
4019  if (!buf)
4020  pkt->buf = av_buffer_create(pkt_data, pkt_size + AV_INPUT_BUFFER_PADDING_SIZE,
4021  NULL, NULL, 0);
4022  else
4023  pkt->buf = av_buffer_ref(buf);
4024 
4025  if (!pkt->buf) {
4026  res = AVERROR(ENOMEM);
4027  goto fail;
4028  }
4029 
4030  pkt->data = pkt_data;
4031  pkt->size = pkt_size;
4032  pkt->flags = is_keyframe;
4033  pkt->stream_index = st->index;
4034 
4035  for (int i = 0; i < nb_blockmore; i++) {
4036  MatroskaBlockMore *more = &blockmore[i];
4037 
4038  if (!more->additional.size)
4039  continue;
4040 
4041  res = matroska_parse_block_additional(matroska, track, pkt, more->additional.data,
4042  more->additional.size, more->additional_id);
4043  if (res < 0) {
4045  return res;
4046  }
4047  }
4048 
4049  if (discard_padding) {
4050  uint8_t *side_data = av_packet_new_side_data(pkt,
4052  10);
4053  if (!side_data) {
4055  return AVERROR(ENOMEM);
4056  }
4057  discard_padding = av_rescale_q(discard_padding,
4058  (AVRational){1, 1000000000},
4059  (AVRational){1, st->codecpar->sample_rate});
4060  if (discard_padding > 0) {
4061  AV_WL32A(side_data + 4, discard_padding);
4062  } else {
4063  AV_WL32A(side_data, -discard_padding);
4064  }
4065  }
4066 
4067  if (track->ms_compat)
4068  pkt->dts = timecode;
4069  else
4070  pkt->pts = timecode;
4071  pkt->pos = pos;
4072  pkt->duration = lace_duration;
4073 
4074  res = avpriv_packet_list_put(&matroska->queue, pkt, NULL, 0);
4075  if (res < 0) {
4077  return AVERROR(ENOMEM);
4078  }
4079 
4080  return 0;
4081 
4082 no_output:
4084  if (!buf)
4085  av_free(pkt_data);
4086  return res;
4087 }
4088 
4089 static int matroska_parse_block(MatroskaDemuxContext *matroska, AVBufferRef *buf, uint8_t *data,
4090  int size, int64_t pos, uint64_t cluster_time,
4091  uint64_t block_duration, int is_keyframe,
4092  MatroskaBlockMore *blockmore, int nb_blockmore,
4093  int64_t cluster_pos, int64_t discard_padding)
4094 {
4095  uint64_t timecode = AV_NOPTS_VALUE;
4096  MatroskaTrack *track;
4097  FFIOContext pb;
4098  int res = 0;
4099  AVStream *st;
4100  int16_t block_time;
4101  uint32_t lace_size[256];
4102  int n, flags, laces = 0;
4103  uint64_t num;
4104  int trust_default_duration;
4105 
4106  av_assert1(buf);
4107 
4109 
4110  if ((n = ebml_read_num(matroska, &pb.pub, 8, &num, 1)) < 0)
4111  return n;
4112  data += n;
4113  size -= n;
4114 
4115  track = matroska_find_track_by_num(matroska, num);
4116  if (!track || size < 3)
4117  return AVERROR_INVALIDDATA;
4118 
4119  if (!(st = track->stream)) {
4120  av_log(matroska->ctx, AV_LOG_VERBOSE,
4121  "No stream associated to TrackNumber %"PRIu64". "
4122  "Ignoring Block with this TrackNumber.\n", num);
4123  return 0;
4124  }
4125 
4126  if (st->discard >= AVDISCARD_ALL)
4127  return res;
4128  if (block_duration > INT64_MAX)
4129  block_duration = INT64_MAX;
4130 
4131  block_time = sign_extend(AV_RB16(data), 16);
4132  data += 2;
4133  flags = *data++;
4134  size -= 3;
4135  if (is_keyframe == -1)
4136  is_keyframe = flags & 0x80 ? AV_PKT_FLAG_KEY : 0;
4137 
4138  if (cluster_time != (uint64_t) -1 &&
4139  (block_time >= 0 || cluster_time >= -block_time)) {
4140  uint64_t timecode_cluster_in_track_tb = (double) cluster_time / track->time_scale;
4141  timecode = timecode_cluster_in_track_tb + block_time - track->codec_delay_in_track_tb;
4142  if (track->type == MATROSKA_TRACK_TYPE_SUBTITLE &&
4143  timecode < track->end_timecode)
4144  is_keyframe = 0; /* overlapping subtitles are not key frame */
4145  if (is_keyframe) {
4146  ff_reduce_index(matroska->ctx, st->index);
4147  av_add_index_entry(st, cluster_pos, timecode, 0, 0,
4149  }
4150  }
4151 
4152  if (matroska->skip_to_keyframe &&
4153  track->type != MATROSKA_TRACK_TYPE_SUBTITLE) {
4154  // Compare signed timecodes. Timecode may be negative due to codec delay
4155  // offset. We don't support timestamps greater than int64_t anyway - see
4156  // AVPacket's pts.
4157  if ((int64_t)timecode < (int64_t)matroska->skip_to_timecode)
4158  return res;
4159  if (is_keyframe)
4160  matroska->skip_to_keyframe = 0;
4161  else if (!ffstream(st)->skip_to_keyframe) {
4162  av_log(matroska->ctx, AV_LOG_ERROR, "File is broken, keyframes not correctly marked!\n");
4163  matroska->skip_to_keyframe = 0;
4164  }
4165  }
4166 
4167  res = matroska_parse_laces(matroska, &data, size, (flags & 0x06) >> 1,
4168  &pb.pub, lace_size, &laces);
4169  if (res < 0) {
4170  av_log(matroska->ctx, AV_LOG_ERROR, "Error parsing frame sizes.\n");
4171  return res;
4172  }
4173 
4174  trust_default_duration = track->default_duration != 0;
4175  if (track->audio.samplerate == 8000 && trust_default_duration) {
4176  // If this is needed for more codecs, then add them here
4177  if (st->codecpar->codec_id == AV_CODEC_ID_AC3) {
4178  if (track->audio.samplerate != st->codecpar->sample_rate || !st->codecpar->frame_size)
4179  trust_default_duration = 0;
4180  }
4181  }
4182 
4183  if (!block_duration && trust_default_duration)
4184  block_duration = track->default_duration * laces / matroska->time_scale;
4185 
4186  if (cluster_time != (uint64_t)-1 && (block_time >= 0 || cluster_time >= -block_time))
4187  track->end_timecode =
4188  FFMAX(track->end_timecode, timecode + block_duration);
4189 
4190  for (n = 0; n < laces; n++) {
4191  int64_t lace_duration = block_duration*(n+1) / laces - block_duration*n / laces;
4192  uint8_t *out_data = data;
4193  int out_size = lace_size[n];
4194 
4195  if (track->needs_decoding) {
4196  res = matroska_decode_buffer(&out_data, &out_size, track);
4197  if (res < 0)
4198  return res;
4199  /* Given that we are here means that out_data is no longer
4200  * owned by buf, so set it to NULL. This depends upon
4201  * zero-length header removal compression being ignored. */
4202  av_assert1(out_data != data);
4203  buf = NULL;
4204  }
4205 
4206  if (track->audio.buf) {
4207  res = matroska_parse_rm_audio(matroska, track, st,
4208  out_data, out_size,
4209  timecode, pos);
4210  if (!buf)
4211  av_free(out_data);
4212  if (res)
4213  return res;
4214  } else if (st->codecpar->codec_id == AV_CODEC_ID_WEBVTT) {
4215  res = matroska_parse_webvtt(matroska, track, st,
4216  out_data, out_size,
4217  timecode, lace_duration,
4218  pos);
4219  if (!buf)
4220  av_free(out_data);
4221  if (res)
4222  return res;
4223  } else {
4224  res = matroska_parse_frame(matroska, track, st, buf, out_data,
4225  out_size, timecode, lace_duration,
4226  pos, is_keyframe,
4227  blockmore, nb_blockmore,
4228  discard_padding);
4229  if (res)
4230  return res;
4231  }
4232 
4233  if (timecode != AV_NOPTS_VALUE)
4234  timecode = lace_duration ? timecode + lace_duration : AV_NOPTS_VALUE;
4235  data += lace_size[n];
4236  }
4237 
4238  return 0;
4239 }
4240 
4241 static int matroska_parse_cluster(MatroskaDemuxContext *matroska)
4242 {
4243  MatroskaCluster *cluster = &matroska->current_cluster;
4244  MatroskaBlock *block = &cluster->block;
4245  int res;
4246 
4247  av_assert0(matroska->num_levels <= 2U);
4248 
4249  if (matroska->num_levels == 1) {
4250  res = ebml_parse(matroska, matroska_segment, NULL);
4251 
4252  if (res == 1) {
4253  /* Found a cluster: subtract the size of the ID already read. */
4254  cluster->pos = avio_tell(matroska->ctx->pb) - 4;
4255 
4256  res = ebml_parse(matroska, matroska_cluster_enter, cluster);
4257  if (res < 0)
4258  return res;
4259  }
4260  }
4261 
4262  if (matroska->num_levels == 2) {
4263  /* We are inside a cluster. */
4264  res = ebml_parse(matroska, matroska_cluster_parsing, cluster);
4265 
4266  if (res >= 0 && block->bin.size > 0) {
4267  int is_keyframe = block->non_simple ? block->reference.count == 0 : -1;
4268 
4269  res = matroska_parse_block(matroska, block->bin.buf, block->bin.data,
4270  block->bin.size, block->bin.pos,
4271  cluster->timecode, block->duration,
4272  is_keyframe, block->blockmore.elem,
4273  block->blockmore.nb_elem, cluster->pos,
4274  block->discard_padding);
4275  }
4276 
4278  memset(block, 0, sizeof(*block));
4279  } else if (!matroska->num_levels) {
4280  if (!avio_feof(matroska->ctx->pb)) {
4281  avio_r8(matroska->ctx->pb);
4282  if (!avio_feof(matroska->ctx->pb)) {
4283  av_log(matroska->ctx, AV_LOG_WARNING, "File extends beyond "
4284  "end of segment.\n");
4285  return AVERROR_INVALIDDATA;
4286  }
4287  }
4288  matroska->done = 1;
4289  return AVERROR_EOF;
4290  }
4291 
4292  return res;
4293 }
4294 
4296 {
4297  MatroskaDemuxContext *matroska = s->priv_data;
4298  int ret = 0;
4299 
4300  if (matroska->resync_pos == -1) {
4301  // This can only happen if generic seeking has been used.
4302  matroska->resync_pos = avio_tell(s->pb);
4303  }
4304 
4305  while (matroska_deliver_packet(matroska, pkt)) {
4306  if (matroska->done)
4307  return (ret < 0) ? ret : AVERROR_EOF;
4308  if (matroska_parse_cluster(matroska) < 0 && !matroska->done)
4309  ret = matroska_resync(matroska, matroska->resync_pos);
4310  }
4311 
4312  return 0;
4313 }
4314 
4315 static int matroska_read_seek(AVFormatContext *s, int stream_index,
4316  int64_t timestamp, int flags)
4317 {
4318  MatroskaDemuxContext *matroska = s->priv_data;
4319  MatroskaTrack *tracks = NULL;
4320  AVStream *st = s->streams[stream_index];
4321  FFStream *const sti = ffstream(st);
4322  int i, index;
4323 
4324  /* Parse the CUES now since we need the index data to seek. */
4325  if (matroska->cues_parsing_deferred > 0) {
4326  matroska->cues_parsing_deferred = 0;
4327  matroska_parse_cues(matroska);
4328  }
4329 
4330  if (!sti->nb_index_entries)
4331  goto err;
4332  timestamp = FFMAX(timestamp, sti->index_entries[0].timestamp);
4333 
4334  if ((index = av_index_search_timestamp(st, timestamp, flags)) < 0 ||
4335  index == sti->nb_index_entries - 1) {
4336  matroska_reset_status(matroska, 0, sti->index_entries[sti->nb_index_entries - 1].pos);
4337  while ((index = av_index_search_timestamp(st, timestamp, flags)) < 0 ||
4338  index == sti->nb_index_entries - 1) {
4339  matroska_clear_queue(matroska);
4340  if (matroska_parse_cluster(matroska) < 0)
4341  break;
4342  }
4343  }
4344 
4345  matroska_clear_queue(matroska);
4346  if (index < 0 || (matroska->cues_parsing_deferred < 0 &&
4347  index == sti->nb_index_entries - 1))
4348  goto err;
4349 
4350  tracks = matroska->tracks.elem;
4351  for (i = 0; i < matroska->tracks.nb_elem; i++) {
4352  tracks[i].audio.pkt_cnt = 0;
4353  tracks[i].audio.sub_packet_cnt = 0;
4354  tracks[i].audio.buf_timecode = AV_NOPTS_VALUE;
4355  tracks[i].end_timecode = 0;
4356  }
4357 
4358  /* We seek to a level 1 element, so set the appropriate status. */
4359  matroska_reset_status(matroska, 0, sti->index_entries[index].pos);
4360  if (flags & AVSEEK_FLAG_ANY) {
4361  sti->skip_to_keyframe = 0;
4362  matroska->skip_to_timecode = timestamp;
4363  } else {
4364  sti->skip_to_keyframe = 1;
4365  matroska->skip_to_timecode = sti->index_entries[index].timestamp;
4366  }
4367  matroska->skip_to_keyframe = 1;
4368  matroska->done = 0;
4370  return 0;
4371 err:
4372  // slightly hackish but allows proper fallback to
4373  // the generic seeking code.
4374  matroska_reset_status(matroska, 0, -1);
4375  matroska->resync_pos = -1;
4376  matroska_clear_queue(matroska);
4378  matroska->skip_to_keyframe = 0;
4379  matroska->done = 0;
4380  return -1;
4381 }
4382 
4384 {
4385  MatroskaDemuxContext *matroska = s->priv_data;
4386  MatroskaTrack *tracks = matroska->tracks.elem;
4387  int n;
4388 
4389  matroska_clear_queue(matroska);
4390 
4391  for (n = 0; n < matroska->tracks.nb_elem; n++)
4392  if (tracks[n].type == MATROSKA_TRACK_TYPE_AUDIO)
4393  av_freep(&tracks[n].audio.buf);
4394  ebml_free(matroska_segment, matroska);
4395 
4396  return 0;
4397 }
4398 
4399 #if CONFIG_WEBM_DASH_MANIFEST_DEMUXER
4400 typedef struct {
4401  int64_t start_time_ns;
4402  int64_t end_time_ns;
4403  int64_t start_offset;
4404  int64_t end_offset;
4405 } CueDesc;
4406 
4407 /* This function searches all the Cues and returns the CueDesc corresponding to
4408  * the timestamp ts. Returned CueDesc will be such that start_time_ns <= ts <
4409  * end_time_ns. All 4 fields will be set to -1 if ts >= file's duration or
4410  * if an error occurred.
4411  */
4412 static CueDesc get_cue_desc(AVFormatContext *s, int64_t ts, int64_t cues_start) {
4413  MatroskaDemuxContext *matroska = s->priv_data;
4414  FFStream *const sti = ffstream(s->streams[0]);
4415  AVIndexEntry *const index_entries = sti->index_entries;
4416  int nb_index_entries = sti->nb_index_entries;
4417  CueDesc cue_desc;
4418  int i;
4419 
4420  if (ts >= (int64_t)(matroska->duration * matroska->time_scale))
4421  return (CueDesc) {-1, -1, -1, -1};
4422  for (i = 1; i < nb_index_entries; i++) {
4423  if (index_entries[i - 1].timestamp * matroska->time_scale <= ts &&
4424  index_entries[i].timestamp * matroska->time_scale > ts) {
4425  break;
4426  }
4427  }
4428  --i;
4429  if (index_entries[i].timestamp > matroska->duration)
4430  return (CueDesc) {-1, -1, -1, -1};
4431  cue_desc.start_time_ns = index_entries[i].timestamp * matroska->time_scale;
4432  cue_desc.start_offset = index_entries[i].pos - matroska->segment_start;
4433  if (i != nb_index_entries - 1) {
4434  cue_desc.end_time_ns = index_entries[i + 1].timestamp * matroska->time_scale;
4435  cue_desc.end_offset = index_entries[i + 1].pos - matroska->segment_start;
4436  } else {
4437  cue_desc.end_time_ns = matroska->duration * matroska->time_scale;
4438  // FIXME: this needs special handling for files where Cues appear
4439  // before Clusters. the current logic assumes Cues appear after
4440  // Clusters.
4441  cue_desc.end_offset = cues_start - matroska->segment_start;
4442  }
4443  return cue_desc;
4444 }
4445 
4446 static int webm_clusters_start_with_keyframe(AVFormatContext *s)
4447 {
4448  MatroskaDemuxContext *matroska = s->priv_data;
4449  AVStream *const st = s->streams[0];
4450  FFStream *const sti = ffstream(st);
4451  uint32_t id = matroska->current_id;
4452  int64_t cluster_pos, before_pos;
4453  int index, rv = 1;
4454 
4455  if (sti->nb_index_entries <= 0)
4456  return 0;
4457 
4458  // seek to the first cluster using cues.
4459  index = av_index_search_timestamp(st, 0, 0);
4460  if (index < 0)
4461  return 0;
4462  cluster_pos = sti->index_entries[index].pos;
4463  before_pos = avio_tell(s->pb);
4464  while (1) {
4465  uint64_t cluster_id, cluster_length;
4466  int read;
4467  AVPacket *pkt;
4468  avio_seek(s->pb, cluster_pos, SEEK_SET);
4469  // read cluster id and length
4470  read = ebml_read_num(matroska, matroska->ctx->pb, 4, &cluster_id, 1);
4471  if (read < 0 || cluster_id != 0xF43B675) // done with all clusters
4472  break;
4473  read = ebml_read_length(matroska, matroska->ctx->pb, &cluster_length);
4474  if (read < 0)
4475  break;
4476 
4477  matroska_reset_status(matroska, 0, cluster_pos);
4478  matroska_clear_queue(matroska);
4479  if (matroska_parse_cluster(matroska) < 0 ||
4480  !matroska->queue.head) {
4481  break;
4482  }
4483  pkt = &matroska->queue.head->pkt;
4484  // 4 + read is the length of the cluster id and the cluster length field.
4485  cluster_pos += 4 + read + cluster_length;
4486  if (!(pkt->flags & AV_PKT_FLAG_KEY)) {
4487  rv = 0;
4488  break;
4489  }
4490  }
4491 
4492  /* Restore the status after matroska_read_header: */
4493  matroska_reset_status(matroska, id, before_pos);
4494 
4495  return rv;
4496 }
4497 
4498 static int buffer_size_after_time_downloaded(int64_t time_ns, double search_sec, int64_t bps,
4499  double min_buffer, double* buffer,
4500  double* sec_to_download, AVFormatContext *s,
4501  int64_t cues_start)
4502 {
4503  double nano_seconds_per_second = 1000000000.0;
4504  double time_sec = time_ns / nano_seconds_per_second;
4505  int rv = 0;
4506  int64_t time_to_search_ns = (int64_t)(search_sec * nano_seconds_per_second);
4507  int64_t end_time_ns = time_ns + time_to_search_ns;
4508  double sec_downloaded = 0.0;
4509  CueDesc desc_curr = get_cue_desc(s, time_ns, cues_start);
4510  if (desc_curr.start_time_ns == -1)
4511  return -1;
4512  *sec_to_download = 0.0;
4513 
4514  // Check for non cue start time.
4515  if (time_ns > desc_curr.start_time_ns) {
4516  int64_t cue_nano = desc_curr.end_time_ns - time_ns;
4517  double percent = (double)(cue_nano) / (desc_curr.end_time_ns - desc_curr.start_time_ns);
4518  double cueBytes = (desc_curr.end_offset - desc_curr.start_offset) * percent;
4519  double timeToDownload = (cueBytes * 8.0) / bps;
4520 
4521  sec_downloaded += (cue_nano / nano_seconds_per_second) - timeToDownload;
4522  *sec_to_download += timeToDownload;
4523 
4524  // Check if the search ends within the first cue.
4525  if (desc_curr.end_time_ns >= end_time_ns) {
4526  double desc_end_time_sec = desc_curr.end_time_ns / nano_seconds_per_second;
4527  double percent_to_sub = search_sec / (desc_end_time_sec - time_sec);
4528  sec_downloaded = percent_to_sub * sec_downloaded;
4529  *sec_to_download = percent_to_sub * *sec_to_download;
4530  }
4531 
4532  if ((sec_downloaded + *buffer) <= min_buffer) {
4533  return 1;
4534  }
4535 
4536  // Get the next Cue.
4537  desc_curr = get_cue_desc(s, desc_curr.end_time_ns, cues_start);
4538  }
4539 
4540  while (desc_curr.start_time_ns != -1) {
4541  int64_t desc_bytes = desc_curr.end_offset - desc_curr.start_offset;
4542  int64_t desc_ns = desc_curr.end_time_ns - desc_curr.start_time_ns;
4543  double desc_sec = desc_ns / nano_seconds_per_second;
4544  double bits = (desc_bytes * 8.0);
4545  double time_to_download = bits / bps;
4546 
4547  sec_downloaded += desc_sec - time_to_download;
4548  *sec_to_download += time_to_download;
4549 
4550  if (desc_curr.end_time_ns >= end_time_ns) {
4551  double desc_end_time_sec = desc_curr.end_time_ns / nano_seconds_per_second;
4552  double percent_to_sub = search_sec / (desc_end_time_sec - time_sec);
4553  sec_downloaded = percent_to_sub * sec_downloaded;
4554  *sec_to_download = percent_to_sub * *sec_to_download;
4555 
4556  if ((sec_downloaded + *buffer) <= min_buffer)
4557  rv = 1;
4558  break;
4559  }
4560 
4561  if ((sec_downloaded + *buffer) <= min_buffer) {
4562  rv = 1;
4563  break;
4564  }
4565 
4566  desc_curr = get_cue_desc(s, desc_curr.end_time_ns, cues_start);
4567  }
4568  *buffer = *buffer + sec_downloaded;
4569  return rv;
4570 }
4571 
4572 /* This function computes the bandwidth of the WebM file with the help of
4573  * buffer_size_after_time_downloaded() function. Both of these functions are
4574  * adapted from WebM Tools project and are adapted to work with FFmpeg's
4575  * Matroska parsing mechanism.
4576  *
4577  * Returns the bandwidth of the file on success; -1 on error.
4578  * */
4579 static int64_t webm_dash_manifest_compute_bandwidth(AVFormatContext *s, int64_t cues_start)
4580 {
4581  MatroskaDemuxContext *matroska = s->priv_data;
4582  AVStream *st = s->streams[0];
4583  FFStream *const sti = ffstream(st);
4584  double bandwidth = 0.0;
4585 
4586  for (int i = 0; i < sti->nb_index_entries; i++) {
4587  int64_t prebuffer_ns = 1000000000;
4588  int64_t time_ns = sti->index_entries[i].timestamp * matroska->time_scale;
4589  double nano_seconds_per_second = 1000000000.0;
4590  int64_t prebuffered_ns;
4591  double prebuffer_bytes = 0.0;
4592  int64_t temp_prebuffer_ns = prebuffer_ns;
4593  int64_t pre_bytes, pre_ns;
4594  double pre_sec, prebuffer, bits_per_second;
4595  CueDesc desc_beg = get_cue_desc(s, time_ns, cues_start);
4596  // Start with the first Cue.
4597  CueDesc desc_end = desc_beg;
4598 
4599  if (time_ns > INT64_MAX - prebuffer_ns)
4600  return -1;
4601  prebuffered_ns = time_ns + prebuffer_ns;
4602 
4603  // Figure out how much data we have downloaded for the prebuffer. This will
4604  // be used later to adjust the bits per sample to try.
4605  while (desc_end.start_time_ns != -1 && desc_end.end_time_ns < prebuffered_ns) {
4606  // Prebuffered the entire Cue.
4607  prebuffer_bytes += desc_end.end_offset - desc_end.start_offset;
4608  temp_prebuffer_ns -= desc_end.end_time_ns - desc_end.start_time_ns;
4609  desc_end = get_cue_desc(s, desc_end.end_time_ns, cues_start);
4610  }
4611  if (desc_end.start_time_ns == -1) {
4612  // The prebuffer is larger than the duration.
4613  if (matroska->duration * matroska->time_scale >= prebuffered_ns)
4614  return -1;
4615  bits_per_second = 0.0;
4616  } else {
4617  // The prebuffer ends in the last Cue. Estimate how much data was
4618  // prebuffered.
4619  pre_bytes = desc_end.end_offset - desc_end.start_offset;
4620  if (desc_end.end_time_ns <= desc_end.start_time_ns ||
4621  desc_end.end_time_ns - (uint64_t)desc_end.start_time_ns > INT64_MAX)
4622  return -1;
4623  pre_ns = desc_end.end_time_ns - desc_end.start_time_ns;
4624  pre_sec = pre_ns / nano_seconds_per_second;
4625  prebuffer_bytes +=
4626  pre_bytes * ((temp_prebuffer_ns / nano_seconds_per_second) / pre_sec);
4627 
4628  prebuffer = prebuffer_ns / nano_seconds_per_second;
4629 
4630  // Set this to 0.0 in case our prebuffer buffers the entire video.
4631  bits_per_second = 0.0;
4632  do {
4633  int64_t desc_bytes = desc_end.end_offset - desc_beg.start_offset;
4634  int64_t desc_ns = desc_end.end_time_ns - desc_beg.start_time_ns;
4635  double desc_sec, calc_bits_per_second, percent, mod_bits_per_second;
4636  if (desc_bytes <= 0 || desc_bytes > INT64_MAX/8)
4637  return -1;
4638 
4639  desc_sec = desc_ns / nano_seconds_per_second;
4640  calc_bits_per_second = (desc_bytes * 8) / desc_sec;
4641 
4642  // Drop the bps by the percentage of bytes buffered.
4643  percent = (desc_bytes - prebuffer_bytes) / desc_bytes;
4644  mod_bits_per_second = calc_bits_per_second * percent;
4645 
4646  if (prebuffer < desc_sec) {
4647  double search_sec =
4648  (double)(matroska->duration * matroska->time_scale) / nano_seconds_per_second;
4649 
4650  // Add 1 so the bits per second should be a little bit greater than file
4651  // datarate.
4652  int64_t bps = (int64_t)(mod_bits_per_second) + 1;
4653  const double min_buffer = 0.0;
4654  double buffer = prebuffer;
4655  double sec_to_download = 0.0;
4656 
4657  int rv = buffer_size_after_time_downloaded(prebuffered_ns, search_sec, bps,
4658  min_buffer, &buffer, &sec_to_download,
4659  s, cues_start);
4660  if (rv < 0) {
4661  return -1;
4662  } else if (rv == 0) {
4663  bits_per_second = (double)(bps);
4664  break;
4665  }
4666  }
4667 
4668  desc_end = get_cue_desc(s, desc_end.end_time_ns, cues_start);
4669  } while (desc_end.start_time_ns != -1);
4670  }
4671  if (bandwidth < bits_per_second) bandwidth = bits_per_second;
4672  }
4673  return (int64_t)bandwidth;
4674 }
4675 
4676 static int webm_dash_manifest_cues(AVFormatContext *s, int64_t init_range)
4677 {
4678  MatroskaDemuxContext *matroska = s->priv_data;
4679  EbmlList *seekhead_list = &matroska->seekhead;
4680  MatroskaSeekhead *seekhead = seekhead_list->elem;
4681  AVStream *const st = s->streams[0];
4682  FFStream *const sti = ffstream(st);
4683  AVBPrint bprint;
4684  char *buf;
4685  int64_t cues_start = -1, cues_end = -1, before_pos, bandwidth;
4686  int i;
4687  int ret;
4688 
4689  // determine cues start and end positions
4690  for (i = 0; i < seekhead_list->nb_elem; i++)
4691  if (seekhead[i].id == MATROSKA_ID_CUES)
4692  break;
4693 
4694  if (i >= seekhead_list->nb_elem) return -1;
4695 
4696  before_pos = avio_tell(matroska->ctx->pb);
4697  cues_start = seekhead[i].pos + matroska->segment_start;
4698  if (avio_seek(matroska->ctx->pb, cues_start, SEEK_SET) == cues_start) {
4699  // cues_end is computed as cues_start + cues_length + length of the
4700  // Cues element ID (i.e. 4) + EBML length of the Cues element.
4701  // cues_end is inclusive and the above sum is reduced by 1.
4702  uint64_t cues_length, cues_id;
4703  int bytes_read;
4704  bytes_read = ebml_read_num (matroska, matroska->ctx->pb, 4, &cues_id, 1);
4705  if (bytes_read < 0 || cues_id != (MATROSKA_ID_CUES & 0xfffffff))
4706  return bytes_read < 0 ? bytes_read : AVERROR_INVALIDDATA;
4707  bytes_read = ebml_read_length(matroska, matroska->ctx->pb, &cues_length);
4708  if (bytes_read < 0)
4709  return bytes_read;
4710  cues_end = cues_start + 4 + bytes_read + cues_length - 1;
4711  }
4712  avio_seek(matroska->ctx->pb, before_pos, SEEK_SET);
4713  if (cues_start == -1 || cues_end == -1) return -1;
4714 
4715  // parse the cues
4716  matroska_parse_cues(matroska);
4717 
4718  if (!sti->nb_index_entries)
4719  return AVERROR_INVALIDDATA;
4720 
4721  // cues start
4722  av_dict_set_int(&s->streams[0]->metadata, CUES_START, cues_start, 0);
4723 
4724  // cues end
4725  av_dict_set_int(&s->streams[0]->metadata, CUES_END, cues_end, 0);
4726 
4727  // if the file has cues at the start, fix up the init range so that
4728  // it does not include it
4729  if (cues_start <= init_range)
4730  av_dict_set_int(&s->streams[0]->metadata, INITIALIZATION_RANGE, cues_start - 1, 0);
4731 
4732  // bandwidth
4733  bandwidth = webm_dash_manifest_compute_bandwidth(s, cues_start);
4734  if (bandwidth < 0) return -1;
4735  av_dict_set_int(&s->streams[0]->metadata, BANDWIDTH, bandwidth, 0);
4736 
4737  // check if all clusters start with key frames
4738  av_dict_set_int(&s->streams[0]->metadata, CLUSTER_KEYFRAME, webm_clusters_start_with_keyframe(s), 0);
4739 
4740  // Store cue point timestamps as a comma separated list
4741  // for checking subsegment alignment in the muxer.
4743  for (int i = 0; i < sti->nb_index_entries; i++)
4744  av_bprintf(&bprint, "%" PRId64",", sti->index_entries[i].timestamp);
4745  if (!av_bprint_is_complete(&bprint)) {
4746  av_bprint_finalize(&bprint, NULL);
4747  return AVERROR(ENOMEM);
4748  }
4749  // Remove the trailing ','
4750  bprint.str[--bprint.len] = '\0';
4751  if ((ret = av_bprint_finalize(&bprint, &buf)) < 0)
4752  return ret;
4753  av_dict_set(&s->streams[0]->metadata, CUE_TIMESTAMPS,
4755 
4756  return 0;
4757 }
4758 
4759 static int webm_dash_manifest_read_header(AVFormatContext *s)
4760 {
4761  char *buf;
4762  int ret = matroska_read_header(s);
4763  int64_t init_range;
4764  MatroskaTrack *tracks;
4765  MatroskaDemuxContext *matroska = s->priv_data;
4766  if (ret) {
4767  av_log(s, AV_LOG_ERROR, "Failed to read file headers\n");
4768  return -1;
4769  }
4770  if (!matroska->tracks.nb_elem || !s->nb_streams) {
4771  av_log(s, AV_LOG_ERROR, "No track found\n");
4772  return AVERROR_INVALIDDATA;
4773  }
4774 
4775  if (!matroska->is_live) {
4776  buf = av_asprintf("%g", matroska->duration);
4777  if (!buf)
4778  return AVERROR(ENOMEM);
4779  av_dict_set(&s->streams[0]->metadata, DURATION,
4781 
4782  // initialization range
4783  // 5 is the offset of Cluster ID.
4784  init_range = avio_tell(s->pb) - 5;
4785  av_dict_set_int(&s->streams[0]->metadata, INITIALIZATION_RANGE, init_range, 0);
4786  }
4787 
4788  // basename of the file
4789  buf = strrchr(s->url, '/');
4790  av_dict_set(&s->streams[0]->metadata, FILENAME, buf ? ++buf : s->url, 0);
4791 
4792  // track number
4793  tracks = matroska->tracks.elem;
4794  av_dict_set_int(&s->streams[0]->metadata, TRACK_NUMBER, tracks[0].num, 0);
4795 
4796  // parse the cues and populate Cue related fields
4797  if (!matroska->is_live) {
4798  ret = webm_dash_manifest_cues(s, init_range);
4799  if (ret < 0) {
4800  av_log(s, AV_LOG_ERROR, "Error parsing Cues\n");
4801  return ret;
4802  }
4803  }
4804 
4805  // use the bandwidth from the command line if it was provided
4806  if (matroska->bandwidth > 0) {
4807  av_dict_set_int(&s->streams[0]->metadata, BANDWIDTH,
4808  matroska->bandwidth, 0);
4809  }
4810  return 0;
4811 }
4812 
4813 static int webm_dash_manifest_read_packet(AVFormatContext *s, AVPacket *pkt)
4814 {
4815  return AVERROR_EOF;
4816 }
4817 
4818 #define OFFSET(x) offsetof(MatroskaDemuxContext, x)
4819 static const AVOption options[] = {
4820  { "live", "flag indicating that the input is a live file that only has the headers.", OFFSET(is_live), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, AV_OPT_FLAG_DECODING_PARAM },
4821  { "bandwidth", "bandwidth of this stream to be specified in the DASH manifest.", OFFSET(bandwidth), AV_OPT_TYPE_INT, {.i64 = 0}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
4822  { NULL },
4823 };
4824 
4825 static const AVClass webm_dash_class = {
4826  .class_name = "WebM DASH Manifest demuxer",
4827  .item_name = av_default_item_name,
4828  .option = options,
4829  .version = LIBAVUTIL_VERSION_INT,
4830 };
4831 
4833  .p.name = "webm_dash_manifest",
4834  .p.long_name = NULL_IF_CONFIG_SMALL("WebM DASH Manifest"),
4835  .p.priv_class = &webm_dash_class,
4836  .priv_data_size = sizeof(MatroskaDemuxContext),
4837  .flags_internal = FF_INFMT_FLAG_INIT_CLEANUP,
4838  .read_header = webm_dash_manifest_read_header,
4839  .read_packet = webm_dash_manifest_read_packet,
4841 };
4842 #endif
4843 
4845  .p.name = "matroska,webm",
4846  .p.long_name = NULL_IF_CONFIG_SMALL("Matroska / WebM"),
4847  .p.extensions = "mkv,mk3d,mka,mks,webm",
4848  .p.mime_type = "audio/webm,audio/x-matroska,video/webm,video/x-matroska",
4849  .priv_data_size = sizeof(MatroskaDemuxContext),
4850  .flags_internal = FF_INFMT_FLAG_INIT_CLEANUP,
4856 };
AVCOL_PRI_RESERVED
@ AVCOL_PRI_RESERVED
Definition: pixfmt.h:623
MatroskaCluster::timecode
uint64_t timecode
Definition: matroskadec.c:370
MATROSKA_ID_ENCODINGENCRYPTION
#define MATROSKA_ID_ENCODINGENCRYPTION
Definition: matroska.h:183
MatroskaBlockAdditionMapping::type
uint64_t type
Definition: matroskadec.c:254
avpriv_new_chapter
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.
Definition: demux_utils.c:43
MatroskaDemuxContext::segment_start
int64_t segment_start
Definition: matroskadec.c:404
AV_CODEC_ID_PCM_S16LE
@ AV_CODEC_ID_PCM_S16LE
Definition: codec_id.h:335
flags
const SwsFlags flags[]
Definition: swscale.c:61
MATROSKA_ID_TAGTARGETS_ATTACHUID
#define MATROSKA_ID_TAGTARGETS_ATTACHUID
Definition: matroska.h:225
MatroskaDemuxContext::pkt
AVPacket * pkt
Definition: matroskadec.c:408
MATROSKA_ID_CHAPCOUNTRY
#define MATROSKA_ID_CHAPCOUNTRY
Definition: matroska.h:268
matroska_block_addition_mapping
static EbmlSyntax matroska_block_addition_mapping[5]
Definition: matroskadec.c:445
AVMasteringDisplayMetadata::has_primaries
int has_primaries
Flag indicating whether the display primaries (and white point) are set.
Definition: mastering_display_metadata.h:62
ebml_read_master
static int ebml_read_master(MatroskaDemuxContext *matroska, uint64_t length, int64_t pos)
Definition: matroskadec.c:1108
ebml_read_binary
static int ebml_read_binary(AVIOContext *pb, int length, int64_t pos, EbmlBin *bin)
Definition: matroskadec.c:1080
AV_PKT_DATA_DISPLAYMATRIX
@ AV_PKT_DATA_DISPLAYMATRIX
This side data contains a 3x3 transformation matrix describing an affine transformation that needs to...
Definition: packet.h:105
av_packet_unref
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
Definition: packet.c:430
MATROSKA_ID_VIDEODISPLAYUNIT
#define MATROSKA_ID_VIDEODISPLAYUNIT
Definition: matroska.h:125
mkv_image_mime_tags
static const CodecMime mkv_image_mime_tags[]
Definition: matroskadec.c:810
matroska_parse_laces
static int matroska_parse_laces(MatroskaDemuxContext *matroska, uint8_t **buf, int size, int type, AVIOContext *pb, uint32_t lace_size[256], int *laces)
Definition: matroskadec.c:3478
MATROSKA_ID_CODECPRIVATE
#define MATROSKA_ID_CODECPRIVATE
Definition: matroska.h:88
MATROSKA_ID_TRACKNUMBER
#define MATROSKA_ID_TRACKNUMBER
Definition: matroska.h:77
MatroskaTag
Definition: matroskadec.c:323
AVMEDIA_TYPE_SUBTITLE
@ AVMEDIA_TYPE_SUBTITLE
Definition: avutil.h:204
MATROSKA_ID_TRACKFLAGVISUALIMPAIRED
#define MATROSKA_ID_TRACKFLAGVISUALIMPAIRED
Definition: matroska.h:101
MATROSKA_VIDEO_STEREOMODE_TYPE_ROW_INTERLEAVED_RL
@ MATROSKA_VIDEO_STEREOMODE_TYPE_ROW_INTERLEAVED_RL
Definition: matroska.h:319
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:215
AV_BPRINT_SIZE_UNLIMITED
#define AV_BPRINT_SIZE_UNLIMITED
MATROSKA_ID_CHAPSTRING
#define MATROSKA_ID_CHAPSTRING
Definition: matroska.h:266
MATROSKA_BLOCK_ADD_ID_OPAQUE
#define MATROSKA_BLOCK_ADD_ID_OPAQUE
Definition: matroska.h:368
MATROSKA_ID_ENCODINGSIGHASHALGO
#define MATROSKA_ID_ENCODINGSIGHASHALGO
Definition: matroska.h:188
MatroskaTrack::codec_priv
EbmlBin codec_priv
Definition: matroskadec.c:264
MATROSKA_ID_TAGTARGETS
#define MATROSKA_ID_TAGTARGETS
Definition: matroska.h:220
AVMasteringDisplayMetadata::max_luminance
AVRational max_luminance
Max luminance of mastering display (cd/m^2).
Definition: mastering_display_metadata.h:57
AVSphericalProjection
AVSphericalProjection
Projection of the video surface(s) on a sphere.
Definition: spherical.h:47
AVCodecParameters::extradata
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
Definition: codec_par.h:69
EbmlSyntax::id
uint32_t id
Definition: matroskadec.c:113
name
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
Definition: writing_filters.txt:88
MATROSKA_ID_CLUSTERTIMECODE
#define MATROSKA_ID_CLUSTERTIMECODE
Definition: matroska.h:235
PacketList::head
PacketListEntry * head
Definition: packet_internal.h:34
level
uint8_t level
Definition: svq3.c:205
matroska_attachment
static EbmlSyntax matroska_attachment[]
Definition: matroskadec.c:644
AV_EF_EXPLODE
#define AV_EF_EXPLODE
abort decoding on minor error detection
Definition: defs.h:51
AV_CODEC_ID_AC3
@ AV_CODEC_ID_AC3
Definition: codec_id.h:451
ebml_header
static EbmlSyntax ebml_header[]
Definition: matroskadec.c:450
MatroskaDemuxContext::current_id
uint32_t current_id
Definition: matroskadec.c:387
MatroskaDemuxContext::bandwidth
int bandwidth
Definition: matroskadec.c:434
av_bprint_is_complete
static int av_bprint_is_complete(const AVBPrint *buf)
Test if the print buffer is complete (not truncated).
Definition: bprint.h:218
MATROSKA_ID_TITLE
#define MATROSKA_ID_TITLE
Definition: matroska.h:67
r
const char * r
Definition: vf_curves.c:127
AVERROR
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
uid
UID uid
Definition: mxfenc.c:2445
opt.h
matroska_parse_block_additional
static int matroska_parse_block_additional(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVPacket *pkt, const uint8_t *data, int size, uint64_t id)
Definition: matroskadec.c:3872
matroska_parse_tracks
static int matroska_parse_tracks(AVFormatContext *s)
Definition: matroskadec.c:3102
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:51
AVSphericalMapping::projection
enum AVSphericalProjection projection
Projection type.
Definition: spherical.h:98
MatroskaTrack::operation
MatroskaTrackOperation operation
Definition: matroskadec.c:278
AV_WL32
#define AV_WL32(p, v)
Definition: intreadwrite.h:422
AVSphericalMapping::bound_bottom
uint32_t bound_bottom
Distance from the bottom edge.
Definition: spherical.h:182
MATROSKA_ID_CODECDECODEALL
#define MATROSKA_ID_CODECDECODEALL
Definition: matroska.h:92
ff_rm_reorder_sipr_data
void ff_rm_reorder_sipr_data(uint8_t *buf, int sub_packet_h, int framesize)
Perform 4-bit block reordering for SIPR data.
Definition: rmsipr.c:41
MATROSKA_ID_VIDEOCOLORMASTERINGMETA
#define MATROSKA_ID_VIDEOCOLORMASTERINGMETA
Definition: matroska.h:149
MatroskaTrackVideo::pixel_cropt
uint64_t pixel_cropt
Definition: matroskadec.c:212
ebml_read_ascii
static int ebml_read_ascii(AVIOContext *pb, int size, const char *default_value, char **str)
Definition: matroskadec.c:1049
matroska_parse_block
static int matroska_parse_block(MatroskaDemuxContext *matroska, AVBufferRef *buf, uint8_t *data, int size, int64_t pos, uint64_t cluster_time, uint64_t block_duration, int is_keyframe, MatroskaBlockMore *blockmore, int nb_blockmore, int64_t cluster_pos, int64_t discard_padding)
Definition: matroskadec.c:4083
Ebml
Definition: matroskadec.c:140
EBML_BIN
@ EBML_BIN
Definition: matroskadec.c:95
MATROSKA_ID_CHAPTERFLAGENABLED
#define MATROSKA_ID_CHAPTERFLAGENABLED
Definition: matroska.h:275
MatroskaTrackPlane
Definition: matroskadec.c:242
color
Definition: vf_paletteuse.c:513
EBML_MAX_DEPTH
#define EBML_MAX_DEPTH
Definition: matroska.h:381
matroska_parse_prores
static int matroska_parse_prores(MatroskaTrack *track, uint8_t **data, int *size)
Definition: matroskadec.c:3736
av_bprint_init
void av_bprint_init(AVBPrint *buf, unsigned size_init, unsigned size_max)
Definition: bprint.c:69
MatroskaTrackVideo::pixel_cropr
uint64_t pixel_cropr
Definition: matroskadec.c:215
GetByteContext
Definition: bytestream.h:33
AV_PKT_DATA_FRAME_CROPPING
@ AV_PKT_DATA_FRAME_CROPPING
The number of pixels to discard from the top/bottom/left/right border of the decoded frame to obtain ...
Definition: packet.h:340
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: codec_par.h:47
AVFMT_FLAG_IGNIDX
#define AVFMT_FLAG_IGNIDX
Ignore index.
Definition: avformat.h:1418
segment_start
static int segment_start(AVFormatContext *s, int write_header)
Definition: segment.c:232
EBML_ID_EBMLMAXSIZELENGTH
#define EBML_ID_EBMLMAXSIZELENGTH
Definition: matroska.h:38
MatroskaTrack::audio
MatroskaTrackAudio audio
Definition: matroskadec.c:277
MatroskaAttachment::description
char * description
Definition: matroskadec.c:297
ffformatcontext
static av_always_inline FFFormatContext * ffformatcontext(AVFormatContext *s)
Definition: internal.h:123
MatroskaTags
Definition: matroskadec.c:339
MatroskaAttachment::bin
EbmlBin bin
Definition: matroskadec.c:299
AVCodecParameters::color_space
enum AVColorSpace color_space
Definition: codec_par.h:169
avformat_new_stream
AVStream * avformat_new_stream(AVFormatContext *s, const struct AVCodec *c)
Add a new stream to a media file.
MATROSKA_ID_TRACKOPERATION
#define MATROSKA_ID_TRACKOPERATION
Definition: matroska.h:82
ebml_read_num
static int ebml_read_num(MatroskaDemuxContext *matroska, AVIOContext *pb, int max_size, uint64_t *number, int eof_forbidden)
Definition: matroskadec.c:907
matroska_parse_frame
static int matroska_parse_frame(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVStream *st, AVBufferRef *buf, uint8_t *data, int pkt_size, uint64_t timecode, uint64_t lace_duration, int64_t pos, int is_keyframe, MatroskaBlockMore *blockmore, int nb_blockmore, int64_t discard_padding)
Definition: matroskadec.c:3962
MATROSKA_VIDEO_FIELDORDER_PROGRESSIVE
@ MATROSKA_VIDEO_FIELDORDER_PROGRESSIVE
Definition: matroska.h:304
MATROSKA_ID_TRACKFLAGTEXTDESCRIPTIONS
#define MATROSKA_ID_TRACKFLAGTEXTDESCRIPTIONS
Definition: matroska.h:102
AVERROR_EOF
#define AVERROR_EOF
End of file.
Definition: error.h:57
EBML_STOP
@ EBML_STOP
Definition: matroskadec.c:98
AVBufferRef::data
uint8_t * data
The data buffer.
Definition: buffer.h:90
AVStream::discard
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed.
Definition: avformat.h:816
AV_FIELD_PROGRESSIVE
@ AV_FIELD_PROGRESSIVE
Definition: defs.h:202
MATROSKA_ID_VIDEOPIXELWIDTH
#define MATROSKA_ID_VIDEOPIXELWIDTH
Definition: matroska.h:119
TTA_EXTRADATA_SIZE
#define TTA_EXTRADATA_SIZE
Definition: matroskadec.c:2589
MATROSKA_VIDEO_STEREOMODE_TYPE_CHECKERBOARD_LR
@ MATROSKA_VIDEO_STEREOMODE_TYPE_CHECKERBOARD_LR
Definition: matroska.h:318
MATROSKA_ID_AUDIOSAMPLINGFREQ
#define MATROSKA_ID_AUDIOSAMPLINGFREQ
Definition: matroska.h:169
AV_PKT_DATA_MASTERING_DISPLAY_METADATA
@ AV_PKT_DATA_MASTERING_DISPLAY_METADATA
Mastering display metadata (based on SMPTE-2086:2014).
Definition: packet.h:219
EbmlList
Definition: matroskadec.c:127
av_int2double
static av_always_inline double av_int2double(uint64_t i)
Reinterpret a 64-bit integer as a double.
Definition: intfloat.h:60
matrix
Definition: vc1dsp.c:43
AVMasteringDisplayMetadata::display_primaries
AVRational display_primaries[3][2]
CIE 1931 xy chromaticity coords of color primaries (r, g, b order).
Definition: mastering_display_metadata.h:42
matroska_resync
static int matroska_resync(MatroskaDemuxContext *matroska, int64_t last_pos)
Definition: matroskadec.c:860
MatroskaSeekhead::pos
uint64_t pos
Definition: matroskadec.c:346
MATROSKA_VIDEO_PROJECTION_TYPE_RECTANGULAR
@ MATROSKA_VIDEO_PROJECTION_TYPE_RECTANGULAR
Definition: matroska.h:354
MatroskaTrack::name
char * name
Definition: matroskadec.c:262
AVMasteringDisplayMetadata::has_luminance
int has_luminance
Flag indicating whether the luminance (min_ and max_) have been set.
Definition: mastering_display_metadata.h:67
Ebml::version
uint64_t version
Definition: matroskadec.c:141
matroska_track_combine_planes
static EbmlSyntax matroska_track_combine_planes[2]
Definition: matroskadec.c:445
Ebml::max_size
uint64_t max_size
Definition: matroskadec.c:142
MATROSKA_ID_DISCARDPADDING
#define MATROSKA_ID_DISCARDPADDING
Definition: matroska.h:250
MATROSKA_VIDEO_FIELDORDER_BB
@ MATROSKA_VIDEO_FIELDORDER_BB
Definition: matroska.h:307
matroska_cluster_parsing
static EbmlSyntax matroska_cluster_parsing[8]
Definition: matroskadec.c:448
MatroskaTrackAudio::sub_packet_cnt
int sub_packet_cnt
Definition: matroskadec.c:236
EbmlSyntax::n
const struct EbmlSyntax * n
Definition: matroskadec.c:123
int64_t
long long int64_t
Definition: coverity.c:34
MATROSKA_ID_EDITIONFLAGORDERED
#define MATROSKA_ID_EDITIONFLAGORDERED
Definition: matroska.h:272
MATROSKA_ID_DURATION
#define MATROSKA_ID_DURATION
Definition: matroska.h:66
av_asprintf
char * av_asprintf(const char *fmt,...)
Definition: avstring.c:115
MATROSKA_ID_VIDEOCOLORCHROMASITINGVERT
#define MATROSKA_ID_VIDEOCOLORCHROMASITINGVERT
Definition: matroska.h:141
MatroskaTrackEncoding::scope
uint64_t scope
Definition: matroskadec.c:159
matroska_read_header
static int matroska_read_header(AVFormatContext *s)
Definition: matroskadec.c:3290
matroska_find_track_by_num
static MatroskaTrack * matroska_find_track_by_num(MatroskaDemuxContext *matroska, uint64_t num)
Definition: matroskadec.c:1655
MATROSKA_ID_VIDEOCOLORPRIMARIES
#define MATROSKA_ID_VIDEOCOLORPRIMARIES
Definition: matroska.h:145
matroska_chapters
static EbmlSyntax matroska_chapters[2]
Definition: matroskadec.c:446
MATROSKA_VIDEO_DISPLAYUNIT_PIXELS
@ MATROSKA_VIDEO_DISPLAYUNIT_PIXELS
Definition: matroska.h:332
av_unused
#define av_unused
Definition: attributes.h:131
MATROSKA_ID_ENCODINGSIGNATURE
#define MATROSKA_ID_ENCODINGSIGNATURE
Definition: matroska.h:190
MATROSKA_ID_SEGMENT
#define MATROSKA_ID_SEGMENT
Definition: matroska.h:52
AV_DISPOSITION_DEFAULT
#define AV_DISPOSITION_DEFAULT
The stream should be chosen by default among other streams of the same type, unless the user has expl...
Definition: avformat.h:618
mask
int mask
Definition: mediacodecdec_common.c:154
CUES_START
#define CUES_START
Definition: matroska.h:429
out_size
int out_size
Definition: movenc.c:56
MATROSKA_ID_BLKADDIDTYPE
#define MATROSKA_ID_BLKADDIDTYPE
Definition: matroska.h:195
AVContentLightMetadata::MaxCLL
unsigned MaxCLL
Max content light level (cd/m^2).
Definition: mastering_display_metadata.h:111
MatroskaMasteringMeta::white_y
double white_y
Definition: matroskadec.c:173
MatroskaTagTarget::trackuid
uint64_t trackuid
Definition: matroskadec.c:334
MatroskaBlock::discard_padding
int64_t discard_padding
Definition: matroskadec.c:365
AV_CODEC_ID_RA_144
@ AV_CODEC_ID_RA_144
Definition: codec_id.h:433
ff_metadata_conv
void ff_metadata_conv(AVDictionary **pm, const AVMetadataConv *d_conv, const AVMetadataConv *s_conv)
Definition: metadata.c:26
MATROSKA_ID_CHAPTERS
#define MATROSKA_ID_CHAPTERS
Definition: matroska.h:62
tmp
static uint8_t tmp[11]
Definition: aes_ctr.c:28
MATROSKA_ID_VIDEOCOLOR_BY
#define MATROSKA_ID_VIDEOCOLOR_BY
Definition: matroska.h:155
pixdesc.h
rmsipr.h
AVPacketSideData
This structure stores auxiliary information for decoding, presenting, or otherwise processing the cod...
Definition: packet.h:386
MATROSKA_ID_BLOCKDURATION
#define MATROSKA_ID_BLOCKDURATION
Definition: matroska.h:247
w
uint8_t w
Definition: llviddspenc.c:38
AVCOL_RANGE_JPEG
@ AVCOL_RANGE_JPEG
Full range content.
Definition: pixfmt.h:750
MATROSKA_ID_VIDEOCOLORRANGE
#define MATROSKA_ID_VIDEOCOLORRANGE
Definition: matroska.h:142
AVFormatContext::strict_std_compliance
int strict_std_compliance
Allow non-standard and experimental extension.
Definition: avformat.h:1619
MATROSKA_ID_BLOCK
#define MATROSKA_ID_BLOCK
Definition: matroska.h:246
MatroskaDemuxContext::unknown_count
int unknown_count
Definition: matroskadec.c:389
av_display_matrix_flip
void av_display_matrix_flip(int32_t matrix[9], int hflip, int vflip)
Flip the input matrix horizontally and/or vertically.
Definition: display.c:66
AVPacket::data
uint8_t * data
Definition: packet.h:535
MatroskaTag::string
char * string
Definition: matroskadec.c:325
MATROSKA_ID_TRACKDEFAULTDURATION
#define MATROSKA_ID_TRACKDEFAULTDURATION
Definition: matroska.h:108
MatroskaDemuxContext::num_levels
int num_levels
Definition: matroskadec.c:386
matroska_track_encodings
static EbmlSyntax matroska_track_encodings[2]
Definition: matroskadec.c:444
matroska_tags
static EbmlSyntax matroska_tags[2]
Definition: matroskadec.c:447
MATROSKA_ID_TAGTARGETS_TYPE
#define MATROSKA_ID_TAGTARGETS_TYPE
Definition: matroska.h:221
MatroskaTrackAudio::coded_framesize
int coded_framesize
Definition: matroskadec.c:232
MatroskaSeekhead
Definition: matroskadec.c:344
AVCodecParameters::seek_preroll
int seek_preroll
Audio only.
Definition: codec_par.h:214
bitdepth
#define bitdepth
Definition: aom_film_grain_template.c:67
AVOption
AVOption.
Definition: opt.h:429
matroska_video_stereo_plane
static const char *const matroska_video_stereo_plane[MATROSKA_VIDEO_STEREO_PLANE_COUNT]
Definition: matroskadec.c:828
b
#define b
Definition: input.c:42
AVCOL_TRC_UNSPECIFIED
@ AVCOL_TRC_UNSPECIFIED
Definition: pixfmt.h:647
matroska_read_seek
static int matroska_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int flags)
Definition: matroskadec.c:4309
CountedElement::u
uint64_t u
Definition: matroskadec.c:104
AVStream::avg_frame_rate
AVRational avg_frame_rate
Average framerate.
Definition: avformat.h:834
matroska_read_close
static int matroska_read_close(AVFormatContext *s)
Definition: matroskadec.c:4377
PacketList
Definition: packet_internal.h:33
spherical.h
MATROSKA_ID_ENCODINGSCOPE
#define MATROSKA_ID_ENCODINGSCOPE
Definition: matroska.h:177
data
const char data[16]
Definition: mxf.c:149
MATROSKA_VIDEO_INTERLACE_FLAG_INTERLACED
@ MATROSKA_VIDEO_INTERLACE_FLAG_INTERLACED
Definition: matroska.h:299
MatroskaTrack::end_timecode
int64_t end_timecode
Definition: matroskadec.c:284
AV_CODEC_ID_ALAC
@ AV_CODEC_ID_ALAC
Definition: codec_id.h:464
MATROSKA_ID_DATEUTC
#define MATROSKA_ID_DATEUTC
Definition: matroska.h:70
FF_COMPLIANCE_STRICT
#define FF_COMPLIANCE_STRICT
Strictly conform to all the things in the spec no matter what consequences.
Definition: defs.h:59
MATROSKA_ID_VIDEOCOLORCHROMASUBHORZ
#define MATROSKA_ID_VIDEOCOLORCHROMASUBHORZ
Definition: matroska.h:136
MatroskaTag::sub
EbmlList sub
Definition: matroskadec.c:328
MatroskaTrack::video
MatroskaTrackVideo video
Definition: matroskadec.c:276
AVIOContext::error
int error
contains the error code or 0 if no error happened
Definition: avio.h:239
AAC_MAX_EXTRADATA_SIZE
#define AAC_MAX_EXTRADATA_SIZE
Definition: matroskadec.c:2588
MATROSKA_VIDEO_STEREOMODE_TYPE_BOTH_EYES_BLOCK_LR
@ MATROSKA_VIDEO_STEREOMODE_TYPE_BOTH_EYES_BLOCK_LR
Definition: matroska.h:326
matroska.h
MatroskaTrackEncoding
Definition: matroskadec.c:158
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:225
mkv_parse_video_codec
static int mkv_parse_video_codec(MatroskaTrack *track, AVCodecParameters *par, const MatroskaDemuxContext *matroska, int *extradata_offset)
Definition: matroskadec.c:2866
MATROSKA_ID_VIDEOPIXELCROPT
#define MATROSKA_ID_VIDEOPIXELCROPT
Definition: matroska.h:122
aac_profiles
static const AVProfile aac_profiles[]
Definition: audiotoolboxenc.c:607
MATROSKA_ID_VIDEOPIXELCROPB
#define MATROSKA_ID_VIDEOPIXELCROPB
Definition: matroska.h:121
av_display_rotation_set
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...
Definition: display.c:51
AVPacket::duration
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
Definition: packet.h:553
MATROSKA_ID_VIDEOCOLORCBSUBVERT
#define MATROSKA_ID_VIDEOCOLORCBSUBVERT
Definition: matroska.h:139
AVCodecParameters::codec_tag
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
Definition: codec_par.h:59
AV_SPHERICAL_EQUIRECTANGULAR_TILE
@ AV_SPHERICAL_EQUIRECTANGULAR_TILE
Video represents a portion of a sphere mapped on a flat surface using equirectangular projection.
Definition: spherical.h:68
MatroskaTrackVideoColor
Definition: matroskadec.c:178
mkv_parse_video_projection
static int mkv_parse_video_projection(AVStream *st, const MatroskaTrack *track, void *logctx)
Definition: matroskadec.c:2398
mathematics.h
MATROSKA_COLOUR_CHROMASITINGHORZ_UNDETERMINED
@ MATROSKA_COLOUR_CHROMASITINGHORZ_UNDETERMINED
Definition: matroska.h:340
MATROSKA_ID_CUES
#define MATROSKA_ID_CUES
Definition: matroska.h:57
AVDictionary
Definition: dict.c:32
ffio_init_read_context
void ffio_init_read_context(FFIOContext *s, const uint8_t *buffer, int buffer_size)
Wrap a buffer in an AVIOContext for reading.
Definition: aviobuf.c:99
AV_CODEC_ID_FLAC
@ AV_CODEC_ID_FLAC
Definition: codec_id.h:460
MatroskaTrackEncoding::type
uint64_t type
Definition: matroskadec.c:160
AVProbeData::buf_size
int buf_size
Size of buf except extra allocated bytes.
Definition: avformat.h:454
AVChannelLayout::order
enum AVChannelOrder order
Channel order used in this layout.
Definition: channel_layout.h:324
FFMAX
#define FFMAX(a, b)
Definition: macros.h:47
av_buffer_ref
AVBufferRef * av_buffer_ref(const AVBufferRef *buf)
Create a new reference to an AVBuffer.
Definition: buffer.c:103
matroska_blockadditions
static EbmlSyntax matroska_blockadditions[2]
Definition: matroskadec.c:448
MATROSKA_ID_CUETIME
#define MATROSKA_ID_CUETIME
Definition: matroska.h:202
MatroskaTrackVideoProjection
Definition: matroskadec.c:195
AV_PROFILE_ARIB_PROFILE_C
#define AV_PROFILE_ARIB_PROFILE_C
Definition: defs.h:189
MatroskaMasteringMeta::b_y
double b_y
Definition: matroskadec.c:171
matroska_read_packet
static int matroska_read_packet(AVFormatContext *s, AVPacket *pkt)
Definition: matroskadec.c:4289
MATROSKA_ID_CUERELATIVEPOSITION
#define MATROSKA_ID_CUERELATIVEPOSITION
Definition: matroska.h:208
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:329
bit_depth
static void bit_depth(AudioStatsContext *s, const uint64_t *const mask, uint8_t *depth)
Definition: af_astats.c:246
AV_SPHERICAL_EQUIRECTANGULAR
@ AV_SPHERICAL_EQUIRECTANGULAR
Video represents a sphere mapped on a flat surface using equirectangular projection.
Definition: spherical.h:52
intfloat.h
MatroskaDemuxContext::title
char * title
Definition: matroskadec.c:393
MatroskaTrackVideoColor::primaries
uint64_t primaries
Definition: matroskadec.c:189
MATROSKA_ID_CHAPLANG
#define MATROSKA_ID_CHAPLANG
Definition: matroska.h:267
MatroskaTrackVideoProjection::yaw
double yaw
Definition: matroskadec.c:198
ebml_parse
static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, void *data)
Definition: matroskadec.c:1252
AV_CODEC_ID_TRUEHD
@ AV_CODEC_ID_TRUEHD
Definition: codec_id.h:492
MATROSKA_ID_CUEDURATION
#define MATROSKA_ID_CUEDURATION
Definition: matroska.h:209
FFIOContext
Definition: avio_internal.h:28
AV_PKT_FLAG_KEY
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Definition: packet.h:590
avpriv_update_cur_dts
void avpriv_update_cur_dts(AVFormatContext *s, AVStream *ref_st, int64_t timestamp)
Update cur_dts of all streams based on the given timestamp and AVStream.
Definition: seek.c:37
MATROSKA_VIDEO_STEREOMODE_TYPE_ROW_INTERLEAVED_LR
@ MATROSKA_VIDEO_STEREOMODE_TYPE_ROW_INTERLEAVED_LR
Definition: matroska.h:320
MatroskaTrack::stream
AVStream * stream
Definition: matroskadec.c:283
AVIndexEntry
Definition: avformat.h:599
AV_WB64
#define AV_WB64(p, v)
Definition: intreadwrite.h:429
MATROSKA_ID_VIDEOCOLORBITSPERCHANNEL
#define MATROSKA_ID_VIDEOCOLORBITSPERCHANNEL
Definition: matroska.h:135
matroska_segment
static EbmlSyntax matroska_segment[9]
Definition: matroskadec.c:443
AV_CODEC_ID_BIN_DATA
@ AV_CODEC_ID_BIN_DATA
Definition: codec_id.h:599
av_malloc
#define av_malloc(s)
Definition: tableprint_vlc.h:31
matroska_metadata_creation_time
static void matroska_metadata_creation_time(AVDictionary **metadata, int64_t date_utc)
Definition: matroskadec.c:2130
MatroskaBlock::duration
uint64_t duration
Definition: matroskadec.c:360
AVINDEX_KEYFRAME
#define AVINDEX_KEYFRAME
Definition: avformat.h:607
AV_FIELD_BT
@ AV_FIELD_BT
Bottom coded first, top displayed first.
Definition: defs.h:206
MatroskaDemuxContext
Definition: matroskadec.c:380
MatroskaTrackVideo::alpha_mode
uint64_t alpha_mode
Definition: matroskadec.c:220
MatroskaTrackVideo::display_unit
uint64_t display_unit
Definition: matroskadec.c:216
MATROSKA_VIDEO_DISPLAYUNIT_UNKNOWN
@ MATROSKA_VIDEO_DISPLAYUNIT_UNKNOWN
Definition: matroska.h:336
AVContentLightMetadata
Content light level needed by to transmit HDR over HDMI (CTA-861.3).
Definition: mastering_display_metadata.h:107
MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX
Definition: matroska.h:158
update_pos
#define update_pos(td, mb_y, mb_x)
Definition: vp8.c:2379
MATROSKA_VIDEO_STEREOMODE_TYPE_ANAGLYPH_GREEN_MAG
@ MATROSKA_VIDEO_STEREOMODE_TYPE_ANAGLYPH_GREEN_MAG
Definition: matroska.h:325
MatroskaTrack::flag_default
uint64_t flag_default
Definition: matroskadec.c:268
matroska_track_encoding_compression
static EbmlSyntax matroska_track_encoding_compression[]
Definition: matroskadec.c:549
AVCodecParameters::color_primaries
enum AVColorPrimaries color_primaries
Definition: codec_par.h:167
MATROSKA_ID_VIDEOCOLOR_WHITEY
#define MATROSKA_ID_VIDEOCOLOR_WHITEY
Definition: matroska.h:157
MatroskaTrack::block_addition_mappings
EbmlList block_addition_mappings
Definition: matroskadec.c:288
AVPROBE_SCORE_MAX
#define AVPROBE_SCORE_MAX
maximum score
Definition: avformat.h:463
CodecMime
Definition: internal.h:47
primaries
enum AVColorPrimaries primaries
Definition: mediacodec_wrapper.c:2612
AV_PROFILE_ARIB_PROFILE_A
#define AV_PROFILE_ARIB_PROFILE_A
Definition: defs.h:188
AVCOL_SPC_RESERVED
@ AVCOL_SPC_RESERVED
reserved for future use by ITU-T and ISO/IEC just like 15-255 are
Definition: pixfmt.h:677
AV_FIELD_TT
@ AV_FIELD_TT
Top coded_first, top displayed first.
Definition: defs.h:203
ebml_read_sint
static int ebml_read_sint(AVIOContext *pb, int size, int64_t default_value, int64_t *num)
Definition: matroskadec.c:1006
NOTHING
#define NOTHING(STEREOMODETYPE, WDIV, HDIV, WEBM)
ebml_syntax
static EbmlSyntax ebml_syntax[3]
Definition: matroskadec.c:443
MATROSKA_ID_AUDIOOUTSAMPLINGFREQ
#define MATROSKA_ID_AUDIOOUTSAMPLINGFREQ
Definition: matroska.h:170
MATROSKA_BLOCK_ADD_ID_TYPE_DEFAULT
@ MATROSKA_BLOCK_ADD_ID_TYPE_DEFAULT
Definition: matroska.h:361
avpriv_set_pts_info
void avpriv_set_pts_info(AVStream *st, int pts_wrap_bits, unsigned int pts_num, unsigned int pts_den)
Set the time base and wrapping info for a given stream.
Definition: avformat.c:777
mpeg4audio.h
MATROSKA_ID_VIDEOPROJECTIONPRIVATE
#define MATROSKA_ID_VIDEOPROJECTIONPRIVATE
Definition: matroska.h:163
MatroskaTrack::ms_compat
int ms_compat
Definition: matroskadec.c:285
av_packet_add_side_data
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.
Definition: packet.c:198
MatroskaTag::def
uint64_t def
Definition: matroskadec.c:327
AV_PKT_DATA_PALETTE
@ AV_PKT_DATA_PALETTE
An AV_PKT_DATA_PALETTE side data packet contains exactly AVPALETTE_SIZE bytes worth of palette.
Definition: packet.h:47
ffstream
static av_always_inline FFStream * ffstream(AVStream *st)
Definition: internal.h:347
MatroskaTrackPlane::uid
uint64_t uid
Definition: matroskadec.c:243
AV_CODEC_ID_PCM_S16BE
@ AV_CODEC_ID_PCM_S16BE
Definition: codec_id.h:336
MatroskaDemuxContext::current_cluster
MatroskaCluster current_cluster
Definition: matroskadec.c:426
MATROSKA_VIDEO_STEREOMODE_TYPE_MONO
@ MATROSKA_VIDEO_STEREOMODE_TYPE_MONO
Definition: matroska.h:313
MATROSKA_ID_ENCODINGSIGALGO
#define MATROSKA_ID_ENCODINGSIGALGO
Definition: matroska.h:187
MATROSKA_ID_VIDEOASPECTRATIO
#define MATROSKA_ID_VIDEOASPECTRATIO
Definition: matroska.h:130
fail
#define fail()
Definition: checkasm.h:193
AVSEEK_FLAG_ANY
#define AVSEEK_FLAG_ANY
seek to any frame, even non-keyframes
Definition: avformat.h:2381
av_int2float
static av_always_inline float av_int2float(uint32_t i)
Reinterpret a 32-bit integer as a float.
Definition: intfloat.h:40
MatroskaMasteringMeta
Definition: matroskadec.c:165
MatroskaDemuxContext::level1_elems
MatroskaLevel1Element level1_elems[64]
Definition: matroskadec.c:423
read_seek
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
Definition: libcdio.c:151
MATROSKA_ID_CHAPTERDISPLAY
#define MATROSKA_ID_CHAPTERDISPLAY
Definition: matroska.h:265
inflate
static void inflate(uint8_t *dst, const uint8_t *p1, int width, int threshold, const uint8_t *coordinates[], int coord, int maxc)
Definition: vf_neighbor.c:194
av_add_index_entry
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.
Definition: seek.c:122
MATROSKA_ID_TRACKUID
#define MATROSKA_ID_TRACKUID
Definition: matroska.h:78
MATROSKA_ID_ENCODINGSIGKEYID
#define MATROSKA_ID_ENCODINGSIGKEYID
Definition: matroska.h:189
EBML_ID_DOCTYPEVERSION
#define EBML_ID_DOCTYPEVERSION
Definition: matroska.h:40
read_close
static av_cold int read_close(AVFormatContext *ctx)
Definition: libcdio.c:143
MATROSKA_COLOUR_CHROMASITINGVERT_NB
@ MATROSKA_COLOUR_CHROMASITINGVERT_NB
Definition: matroska.h:350
avio_tell
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
Definition: avio.h:494
MatroskaCluster::pos
int64_t pos
Definition: matroskadec.c:371
avpriv_packet_list_get
int avpriv_packet_list_get(PacketList *pkt_buffer, AVPacket *pkt)
Remove the oldest AVPacket in the list and return it.
Definition: packet.c:583
MatroskaTrack
Definition: matroskadec.c:258
EbmlBin::buf
AVBufferRef * buf
Definition: matroskadec.c:135
ff_matroska_video_stereo_mode
const char *const ff_matroska_video_stereo_mode[MATROSKA_VIDEO_STEREOMODE_TYPE_NB]
Definition: matroska.c:131
mkv_parse_block_addition_mappings
static int mkv_parse_block_addition_mappings(AVFormatContext *s, AVStream *st, MatroskaTrack *track)
Definition: matroskadec.c:2498
AVChapter
Definition: avformat.h:1224
MatroskaBlock
Definition: matroskadec.c:359
matroska_probe
static int matroska_probe(const AVProbeData *p)
Definition: matroskadec.c:1608
AV_DISPOSITION_FORCED
#define AV_DISPOSITION_FORCED
Track should be used during playback by default.
Definition: avformat.h:651
MATROSKA_BLOCK_ADD_ID_TYPE_ITU_T_T35
@ MATROSKA_BLOCK_ADD_ID_TYPE_ITU_T_T35
Definition: matroska.h:363
MATROSKA_VIDEO_STEREOMODE_TYPE_CHECKERBOARD_RL
@ MATROSKA_VIDEO_STEREOMODE_TYPE_CHECKERBOARD_RL
Definition: matroska.h:317
matroska_segments
static EbmlSyntax matroska_segments[]
Definition: matroskadec.c:764
matroska_doctypes
static const char *const matroska_doctypes[]
Definition: matroskadec.c:834
type
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
Definition: writing_filters.txt:86
MatroskaTag::lang
char * lang
Definition: matroskadec.c:326
mka_parse_audio_codec
static int mka_parse_audio_codec(MatroskaTrack *track, AVCodecParameters *par, const MatroskaDemuxContext *matroska, AVFormatContext *s, int *extradata_offset)
Definition: matroskadec.c:2592
MATROSKA_ID_VIDEOALPHAMODE
#define MATROSKA_ID_VIDEOALPHAMODE
Definition: matroska.h:129
AV_CODEC_ID_MP3
@ AV_CODEC_ID_MP3
preferred ID for decoding MPEG audio layer 1, 2 or 3
Definition: codec_id.h:449
mkv_parse_video_color
static int mkv_parse_video_color(AVStream *st, const MatroskaTrack *track)
Definition: matroskadec.c:2273
EBML_ID_DOCTYPE
#define EBML_ID_DOCTYPE
Definition: matroska.h:39
MatroskaTrackVideoColor::mastering_meta
MatroskaMasteringMeta mastering_meta
Definition: matroskadec.c:192
MatroskaTrackOperation
Definition: matroskadec.c:247
av_reduce
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
Definition: rational.c:35
EbmlList::elem
void * elem
Definition: matroskadec.c:130
MATROSKA_ID_VIDEOCOLOR_WHITEX
#define MATROSKA_ID_VIDEOCOLOR_WHITEX
Definition: matroska.h:156
AVRational::num
int num
Numerator.
Definition: rational.h:59
EbmlSyntax::type
uint8_t type
Definition: matroskadec.c:114
MatroskaSeekhead::id
uint64_t id
Definition: matroskadec.c:345
AV_FIELD_TB
@ AV_FIELD_TB
Top coded first, bottom displayed first.
Definition: defs.h:205
MATROSKA_TRACK_TYPE_METADATA
@ MATROSKA_TRACK_TYPE_METADATA
Definition: matroska.h:287
AV_CODEC_ID_ATRAC3
@ AV_CODEC_ID_ATRAC3
Definition: codec_id.h:479
matroska_tag
static EbmlSyntax matroska_tag[3]
Definition: matroskadec.c:447
AV_DICT_DONT_STRDUP_VAL
#define AV_DICT_DONT_STRDUP_VAL
Take ownership of a value that's been allocated with av_malloc() or another memory allocation functio...
Definition: dict.h:79
MatroskaTrackOperation::combine_planes
EbmlList combine_planes
Definition: matroskadec.c:248
MATROSKA_VIDEO_FIELDORDER_TT
@ MATROSKA_VIDEO_FIELDORDER_TT
Definition: matroska.h:305
MatroskaDemuxContext::skip_to_keyframe
int skip_to_keyframe
Definition: matroskadec.c:416
MatroskaDemuxContext::levels
MatroskaLevel levels[EBML_MAX_DEPTH]
Definition: matroskadec.c:385
AV_PKT_DATA_WEBVTT_SETTINGS
@ AV_PKT_DATA_WEBVTT_SETTINGS
The optional settings (rendering instructions) that immediately follow the timestamp specifier of a W...
Definition: packet.h:199
MatroskaVideoStereoModeType
MatroskaVideoStereoModeType
Definition: matroska.h:312
AV_CODEC_ID_SIPR
@ AV_CODEC_ID_SIPR
Definition: codec_id.h:489
AVCodecParameters::color_trc
enum AVColorTransferCharacteristic color_trc
Definition: codec_par.h:168
CountedElement::f
double f
Definition: matroskadec.c:106
MATROSKA_ID_BLKADDIDNAME
#define MATROSKA_ID_BLKADDIDNAME
Definition: matroska.h:194
AV_CODEC_ID_PCM_S8
@ AV_CODEC_ID_PCM_S8
Definition: codec_id.h:339
description
Tag description
Definition: snow.txt:206
MATROSKA_ID_BLOCKADDITIONAL
#define MATROSKA_ID_BLOCKADDITIONAL
Definition: matroska.h:242
SKIP_THRESHOLD
#define SKIP_THRESHOLD
Definition: matroskadec.c:85
ebml_parse_nest
static int ebml_parse_nest(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, void *data)
Definition: matroskadec.c:1162
avio_rb32
unsigned int avio_rb32(AVIOContext *s)
Definition: aviobuf.c:761
pkt
AVPacket * pkt
Definition: movenc.c:60
matroska_parse_seekhead_entry
static int matroska_parse_seekhead_entry(MatroskaDemuxContext *matroska, int64_t pos)
Definition: matroskadec.c:1907
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:209
MatroskaTrackAudio::buf_timecode
uint64_t buf_timecode
Definition: matroskadec.c:238
MATROSKA_ID_TRACKCONTENTENCODING
#define MATROSKA_ID_TRACKCONTENTENCODING
Definition: matroska.h:110
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
MatroskaTrackVideoColor::bits_per_channel
uint64_t bits_per_channel
Definition: matroskadec.c:180
EBML_ID_VOID
#define EBML_ID_VOID
Definition: matroska.h:44
MATROSKA_ID_TAGDEFAULT_BUG
#define MATROSKA_ID_TAGDEFAULT_BUG
Definition: matroska.h:219
CountedElement::el
union CountedElement::@416 el
MATROSKA_ID_CODECDOWNLOADURL
#define MATROSKA_ID_CODECDOWNLOADURL
Definition: matroska.h:91
MATROSKA_ID_VIDEOFIELDORDER
#define MATROSKA_ID_VIDEOFIELDORDER
Definition: matroska.h:127
AV_PROFILE_UNKNOWN
#define AV_PROFILE_UNKNOWN
Definition: defs.h:65
AVCodecTag
Definition: internal.h:42
matroska_info
static EbmlSyntax matroska_info[]
Definition: matroskadec.c:467
MATROSKA_ID_VIDEOPIXELCROPR
#define MATROSKA_ID_VIDEOPIXELCROPR
Definition: matroska.h:124
MATROSKA_COLOUR_CHROMASITINGHORZ_NB
@ MATROSKA_COLOUR_CHROMASITINGHORZ_NB
Definition: matroska.h:343
MATROSKA_ID_TAGS
#define MATROSKA_ID_TAGS
Definition: matroska.h:58
AV_CODEC_ID_TTA
@ AV_CODEC_ID_TTA
Definition: codec_id.h:470
matroska_index_entry
static EbmlSyntax matroska_index_entry[3]
Definition: matroskadec.c:447
AV_CODEC_ID_TTF
@ AV_CODEC_ID_TTF
Definition: codec_id.h:588
MatroskaDemuxContext::muxingapp
char * muxingapp
Definition: matroskadec.c:394
AVCOL_PRI_RESERVED0
@ AVCOL_PRI_RESERVED0
Definition: pixfmt.h:620
duration
int64_t duration
Definition: movenc.c:65
read_packet
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
Definition: avio_read_callback.c:42
AV_FIELD_UNKNOWN
@ AV_FIELD_UNKNOWN
Definition: defs.h:201
EBML_ID_EBMLMAXIDLENGTH
#define EBML_ID_EBMLMAXIDLENGTH
Definition: matroska.h:37
AVCodecParameters::frame_size
int frame_size
Audio only.
Definition: codec_par.h:195
MatroskaTrackVideoColor::max_cll
uint64_t max_cll
Definition: matroskadec.c:190
matroska_parse_cluster
static int matroska_parse_cluster(MatroskaDemuxContext *matroska)
Definition: matroskadec.c:4235
av_dict_get
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
Definition: dict.c:60
EbmlSyntax::list_elem_size
size_t list_elem_size
Definition: matroskadec.c:116
ff_add_attached_pic
int ff_add_attached_pic(AVFormatContext *s, AVStream *st, AVIOContext *pb, AVBufferRef **buf, int size)
Add an attached pic to an AVStream.
Definition: demux_utils.c:107
ebml_read_float
static int ebml_read_float(AVIOContext *pb, int size, double default_value, double *num)
Definition: matroskadec.c:1029
av_fast_realloc
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.
Definition: mem.c:497
matroska_find_level1_elem
static MatroskaLevel1Element * matroska_find_level1_elem(MatroskaDemuxContext *matroska, uint32_t id, int64_t pos)
Definition: matroskadec.c:1218
MATROSKA_COLOUR_CHROMASITINGVERT_UNDETERMINED
@ MATROSKA_COLOUR_CHROMASITINGVERT_UNDETERMINED
Definition: matroska.h:347
AVMasteringDisplayMetadata::white_point
AVRational white_point[2]
CIE 1931 xy chromaticity coords of white point.
Definition: mastering_display_metadata.h:47
intreadwrite.h
MATROSKA_ID_FILEUID
#define MATROSKA_ID_FILEUID
Definition: matroska.h:258
MatroskaMasteringMeta::b_x
double b_x
Definition: matroskadec.c:170
s
#define s(width, name)
Definition: cbs_vp9.c:198
MATROSKA_VIDEO_INTERLACE_FLAG_PROGRESSIVE
@ MATROSKA_VIDEO_INTERLACE_FLAG_PROGRESSIVE
Definition: matroska.h:300
Ebml::id_length
uint64_t id_length
Definition: matroskadec.c:143
av_new_packet
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values.
Definition: packet.c:99
MatroskaTag::name
char * name
Definition: matroskadec.c:324
MatroskaLevel1Element::pos
int64_t pos
Definition: matroskadec.c:375
MatroskaDemuxContext::num_level1_elems
int num_level1_elems
Definition: matroskadec.c:424
MatroskaTagTarget::attachuid
uint64_t attachuid
Definition: matroskadec.c:336
CodecTags::str
char str[22]
Definition: matroska.h:376
MatroskaTrackVideo::field_order
uint64_t field_order
Definition: matroskadec.c:218
MATROSKA_ID_VIDEODISPLAYWIDTH
#define MATROSKA_ID_VIDEODISPLAYWIDTH
Definition: matroska.h:117
AVFormatContext::flags
int flags
Flags modifying the (de)muxer behaviour.
Definition: avformat.h:1416
AVInputFormat::name
const char * name
A comma separated list of short names for the format.
Definition: avformat.h:550
MATROSKA_VIDEO_FIELDORDER_BT
@ MATROSKA_VIDEO_FIELDORDER_BT
Definition: matroska.h:309
AVProbeData::buf
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
Definition: avformat.h:453
MatroskaDemuxContext::duration
double duration
Definition: matroskadec.c:392
MatroskaTrackVideo::pixel_width
uint64_t pixel_width
Definition: matroskadec.c:207
AVSphericalMapping::bound_top
uint32_t bound_top
Distance from the top edge.
Definition: spherical.h:180
MATROSKA_ID_TAGNAME
#define MATROSKA_ID_TAGNAME
Definition: matroska.h:215
MatroskaChapter
Definition: matroskadec.c:304
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:202
AV_CODEC_ID_VP9
@ AV_CODEC_ID_VP9
Definition: codec_id.h:222
AVCodecParameters::width
int width
Video only.
Definition: codec_par.h:134
AV_CHANNEL_ORDER_UNSPEC
@ AV_CHANNEL_ORDER_UNSPEC
Only the channel count is specified, without any further information about the channel order.
Definition: channel_layout.h:119
EbmlBin::size
int size
Definition: matroskadec.c:134
MATROSKA_ID_TAG
#define MATROSKA_ID_TAG
Definition: matroska.h:213
av_channel_layout_from_mask
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.
Definition: channel_layout.c:252
MatroskaTrackAudio::sub_packet_size
int sub_packet_size
Definition: matroskadec.c:235
TRACK_NUMBER
#define TRACK_NUMBER
Definition: matroska.h:436
MATROSKA_ID_TIMECODESCALE
#define MATROSKA_ID_TIMECODESCALE
Definition: matroska.h:65
GetByteContext::buffer
const uint8_t * buffer
Definition: bytestream.h:34
matroska_cluster_enter
static EbmlSyntax matroska_cluster_enter[]
Definition: matroskadec.c:804
MATROSKA_ID_CLUSTERPOSITION
#define MATROSKA_ID_CLUSTERPOSITION
Definition: matroska.h:236
bits
uint8_t bits
Definition: vp3data.h:128
AVIndexEntry::timestamp
int64_t timestamp
Timestamp in AVStream.time_base units, preferably the time from which on correctly decoded frames are...
Definition: avformat.h:601
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:40
MATROSKA_ID_CUETRACKPOSITION
#define MATROSKA_ID_CUETRACKPOSITION
Definition: matroska.h:203
MATROSKA_ID_SEEKENTRY
#define MATROSKA_ID_SEEKENTRY
Definition: matroska.h:228
matroska_decode_buffer
static int matroska_decode_buffer(uint8_t **buf, int *buf_size, MatroskaTrack *track)
Definition: matroskadec.c:1669
MatroskaDemuxContext::attachments
EbmlList attachments
Definition: matroskadec.c:397
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
MATROSKA_ID_TRACKTYPE
#define MATROSKA_ID_TRACKTYPE
Definition: matroska.h:79
AVPacketSideData::data
uint8_t * data
Definition: packet.h:387
CLUSTER_KEYFRAME
#define CLUSTER_KEYFRAME
Definition: matroska.h:434
FFFormatContext::data_offset
int64_t data_offset
offset of the first packet
Definition: internal.h:89
MatroskaTrack::encodings
EbmlList encodings
Definition: matroskadec.c:279
MATROSKA_VIDEO_STEREOMODE_TYPE_COL_INTERLEAVED_LR
@ MATROSKA_VIDEO_STEREOMODE_TYPE_COL_INTERLEAVED_LR
Definition: matroska.h:322
MATROSKA_ID_SEGMENTUID
#define MATROSKA_ID_SEGMENTUID
Definition: matroska.h:71
channels
channels
Definition: aptx.h:31
EbmlType
EbmlType
Definition: matroskadec.c:88
matroska_track
static EbmlSyntax matroska_track[33]
Definition: matroskadec.c:444
mkv_parse_subtitle_codec
static int mkv_parse_subtitle_codec(MatroskaTrack *track, AVStream *st, AVCodecParameters *par, const MatroskaDemuxContext *matroska)
Definition: matroskadec.c:3051
MATROSKA_ID_TRACKBLKADDMAPPING
#define MATROSKA_ID_TRACKBLKADDMAPPING
Definition: matroska.h:113
AV_RL16
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_RL16
Definition: bytestream.h:94
MatroskaTrackVideo::interlaced
uint64_t interlaced
Definition: matroskadec.c:217
matroska_track_video_projection
static EbmlSyntax matroska_track_video_projection[]
Definition: matroskadec.c:510
MatroskaTrackAudio::sub_packet_h
int sub_packet_h
Definition: matroskadec.c:233
AV_PKT_DATA_STEREO3D
@ AV_PKT_DATA_STEREO3D
This side data should be associated with a video stream and contains Stereoscopic 3D information in f...
Definition: packet.h:111
av_rescale_q
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
Definition: mathematics.c:142
WAVPACK_EXTRADATA_SIZE
#define WAVPACK_EXTRADATA_SIZE
Definition: matroskadec.c:2590
MATROSKA_ID_INFO
#define MATROSKA_ID_INFO
Definition: matroska.h:55
Ebml::doctype_version
uint64_t doctype_version
Definition: matroskadec.c:145
MatroskaTrackEncryption::algo
uint64_t algo
Definition: matroskadec.c:154
MatroskaTrackVideo::color
EbmlList color
Definition: matroskadec.c:221
MATROSKA_ID_AUDIOCHANNELS
#define MATROSKA_ID_AUDIOCHANNELS
Definition: matroska.h:173
codec_id
enum AVCodecID codec_id
Definition: vaapi_decode.c:410
MATROSKA_ID_BLKADDIDVALUE
#define MATROSKA_ID_BLKADDIDVALUE
Definition: matroska.h:193
MatroskaTrackVideoColor::chroma_siting_vert
uint64_t chroma_siting_vert
Definition: matroskadec.c:186
MATROSKA_VIDEO_STEREOMODE_TYPE_ANAGLYPH_CYAN_RED
@ MATROSKA_VIDEO_STEREOMODE_TYPE_ANAGLYPH_CYAN_RED
Definition: matroska.h:323
key
const char * key
Definition: hwcontext_opencl.c:189
MatroskaAttachment::stream
AVStream * stream
Definition: matroskadec.c:301
AVCodecParameters::nb_coded_side_data
int nb_coded_side_data
Amount of entries in coded_side_data.
Definition: codec_par.h:86
MatroskaTagTarget::type
char * type
Definition: matroskadec.c:332
MatroskaDemuxContext::seekhead
EbmlList seekhead
Definition: matroskadec.c:401
AVCOL_PRI_UNSPECIFIED
@ AVCOL_PRI_UNSPECIFIED
Definition: pixfmt.h:622
av_content_light_metadata_alloc
AVContentLightMetadata * av_content_light_metadata_alloc(size_t *size)
Allocate an AVContentLightMetadata structure and set its fields to default values.
Definition: mastering_display_metadata.c:72
MATROSKA_ID_VIDEOSTEREOMODE
#define MATROSKA_ID_VIDEOSTEREOMODE
Definition: matroska.h:128
MatroskaDemuxContext::queue
PacketList queue
Definition: matroskadec.c:411
MatroskaTrack::type
uint64_t type
Definition: matroskadec.c:261
matroska_clear_queue
static void matroska_clear_queue(MatroskaDemuxContext *matroska)
Definition: matroskadec.c:3473
AV_CODEC_ID_ARIB_CAPTION
@ AV_CODEC_ID_ARIB_CAPTION
Definition: codec_id.h:583
AVStereo3D::flags
int flags
Additional information about the frame packing.
Definition: stereo3d.h:212
MATROSKA_ID_VIDEOCOLORSPACE
#define MATROSKA_ID_VIDEOCOLORSPACE
Definition: matroska.h:131
AV_CODEC_ID_PNG
@ AV_CODEC_ID_PNG
Definition: codec_id.h:113
time_internal.h
if
if(ret)
Definition: filter_design.txt:179
MATROSKA_ID_TRACKNAME
#define MATROSKA_ID_TRACKNAME
Definition: matroska.h:95
FFFormatContext
Definition: internal.h:64
FF_INFMT_FLAG_INIT_CLEANUP
#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...
Definition: demux.h:35
FLAC_METADATA_TYPE_VORBIS_COMMENT
@ FLAC_METADATA_TYPE_VORBIS_COMMENT
Definition: flac.h:50
MatroskaTrackCompression::algo
uint64_t algo
Definition: matroskadec.c:149
FFStream::need_parsing
enum AVStreamParseType need_parsing
Definition: internal.h:314
avpriv_packet_list_free
void avpriv_packet_list_free(PacketList *pkt_buf)
Wipe the list and unref all the packets in it.
Definition: packet.c:597
AV_CODEC_ID_WEBVTT
@ AV_CODEC_ID_WEBVTT
Definition: codec_id.h:576
matroska_convert_tag
static void matroska_convert_tag(AVFormatContext *s, EbmlList *list, AVDictionary **metadata, char *prefix)
Definition: matroskadec.c:1807
EBML_ID_DOCTYPEREADVERSION
#define EBML_ID_DOCTYPEREADVERSION
Definition: matroska.h:41
AVDISCARD_ALL
@ AVDISCARD_ALL
discard all
Definition: defs.h:221
AVFormatContext
Format I/O context.
Definition: avformat.h:1265
matroska_parse_content_encodings
static int matroska_parse_content_encodings(MatroskaTrackEncoding *encodings, unsigned nb_encodings, MatroskaTrack *track, char **key_id_base64, void *logctx)
Definition: matroskadec.c:2035
MATROSKA_ID_CODECSTATE
#define MATROSKA_ID_CODECSTATE
Definition: matroska.h:249
internal.h
MATROSKA_ID_TRACKFLAGHEARINGIMPAIRED
#define MATROSKA_ID_TRACKFLAGHEARINGIMPAIRED
Definition: matroska.h:100
AVCOL_TRC_RESERVED0
@ AVCOL_TRC_RESERVED0
Definition: pixfmt.h:645
AVPacket::buf
AVBufferRef * buf
A reference to the reference-counted buffer where the packet data is stored.
Definition: packet.h:518
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:768
MATROSKA_VIDEO_STEREOMODE_TYPE_TOP_BOTTOM
@ MATROSKA_VIDEO_STEREOMODE_TYPE_TOP_BOTTOM
Definition: matroska.h:316
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
MatroskaAttachment::filename
char * filename
Definition: matroskadec.c:296
MATROSKA_ID_ENCODINGENCALGO
#define MATROSKA_ID_ENCODINGENCALGO
Definition: matroska.h:185
MatroskaTrackVideo::cropped_height
uint64_t cropped_height
Definition: matroskadec.c:210
MATROSKA_ID_BLOCKGROUP
#define MATROSKA_ID_BLOCKGROUP
Definition: matroska.h:238
MATROSKA_ID_VIDEOCOLOR_LUMINANCEMIN
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMIN
Definition: matroska.h:159
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
result
and forward the result(frame or status change) to the corresponding input. If nothing is possible
AVStream::time_base
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
Definition: avformat.h:784
NULL
#define NULL
Definition: coverity.c:32
MATROSKA_ID_ATTACHMENTS
#define MATROSKA_ID_ATTACHMENTS
Definition: matroska.h:60
STEREOMODE_STEREO3D_MAPPING
#define STEREOMODE_STEREO3D_MAPPING(MAP, MKV_ONLY)
Definition: matroska.h:401
AVERROR_PATCHWELCOME
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
Definition: error.h:64
MATROSKA_ID_CHAPTERATOM
#define MATROSKA_ID_CHAPTERATOM
Definition: matroska.h:262
ebml_parse_id
static EbmlSyntax * ebml_parse_id(EbmlSyntax *syntax, uint32_t id)
Definition: matroskadec.c:1149
MATROSKA_ID_TRACKCONTENTENCODINGS
#define MATROSKA_ID_TRACKCONTENTENCODINGS
Definition: matroska.h:109
av_buffer_unref
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
Definition: buffer.c:139
MatroskaDemuxContext::index
EbmlList index
Definition: matroskadec.c:399
matroska_parse_cues
static void matroska_parse_cues(MatroskaDemuxContext *matroska)
Definition: matroskadec.c:2016
MATROSKA_TRACK_TYPE_AUDIO
@ MATROSKA_TRACK_TYPE_AUDIO
Definition: matroska.h:281
MATROSKA_ID_EDITIONUID
#define MATROSKA_ID_EDITIONUID
Definition: matroska.h:269
isom.h
MATROSKA_ID_TRACKFLAGORIGINAL
#define MATROSKA_ID_TRACKFLAGORIGINAL
Definition: matroska.h:103
matroska_reset_status
static int matroska_reset_status(MatroskaDemuxContext *matroska, uint32_t id, int64_t position)
Definition: matroskadec.c:839
ff_matroska_demuxer
const FFInputFormat ff_matroska_demuxer
Definition: matroskadec.c:4838
matroska_execute_seekhead
static void matroska_execute_seekhead(MatroskaDemuxContext *matroska)
Definition: matroskadec.c:1945
MatroskaTrackVideo::pixel_height
uint64_t pixel_height
Definition: matroskadec.c:208
avpriv_packet_list_put
int avpriv_packet_list_put(PacketList *packet_buffer, AVPacket *pkt, int(*copy)(AVPacket *dst, const AVPacket *src), int flags)
Append an AVPacket to the list.
Definition: packet.c:544
matroska_ebmlnum_sint
static int matroska_ebmlnum_sint(MatroskaDemuxContext *matroska, AVIOContext *pb, int64_t *num)
Definition: matroskadec.c:1130
MATROSKA_ID_ENCODINGORDER
#define MATROSKA_ID_ENCODINGORDER
Definition: matroska.h:176
flac_parse_block_header
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.
Definition: flac.h:63
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
matroska_parse_webvtt
static int matroska_parse_webvtt(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVStream *st, uint8_t *data, int data_len, uint64_t timecode, uint64_t duration, int64_t pos)
Definition: matroskadec.c:3757
MATROSKA_ID_WRITINGAPP
#define MATROSKA_ID_WRITINGAPP
Definition: matroska.h:68
isnan
#define isnan(x)
Definition: libm.h:342
AV_DISPOSITION_COMMENT
#define AV_DISPOSITION_COMMENT
The stream is a commentary track.
Definition: avformat.h:636
MATROSKA_ID_VIDEOCOLOR_GY
#define MATROSKA_ID_VIDEOCOLOR_GY
Definition: matroska.h:153
AVPALETTE_SIZE
#define AVPALETTE_SIZE
Definition: pixfmt.h:32
matroska_track_operation
static EbmlSyntax matroska_track_operation[2]
Definition: matroskadec.c:445
MATROSKA_VIDEO_STEREOMODE_TYPE_BOTTOM_TOP
@ MATROSKA_VIDEO_STEREOMODE_TYPE_BOTTOM_TOP
Definition: matroska.h:315
MatroskaBlockAdditionMapping::extradata
EbmlBin extradata
Definition: matroskadec.c:255
MatroskaTrackVideo
Definition: matroskadec.c:203
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:239
avio_rb64
uint64_t avio_rb64(AVIOContext *s)
Definition: aviobuf.c:908
AVFormatContext::pb
AVIOContext * pb
I/O context.
Definition: avformat.h:1307
MatroskaBlockMore::additional
EbmlBin additional
Definition: matroskadec.c:356
mkv_field_order
static int mkv_field_order(const MatroskaDemuxContext *matroska, uint64_t field_order)
Definition: matroskadec.c:2191
MatroskaTrackVideoColor::cb_sub_horz
uint64_t cb_sub_horz
Definition: matroskadec.c:183
MATROSKA_ID_SIMPLETAG
#define MATROSKA_ID_SIMPLETAG
Definition: matroska.h:214
MATROSKA_ID_TRACKPLANEUID
#define MATROSKA_ID_TRACKPLANEUID
Definition: matroska.h:85
FFStream::nb_index_entries
int nb_index_entries
Definition: internal.h:186
MATROSKA_ID_VIDEOPROJECTION
#define MATROSKA_ID_VIDEOPROJECTION
Definition: matroska.h:161
AVProbeData
This structure contains the data a format has to probe a file.
Definition: avformat.h:451
list
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 list
Definition: filter_design.txt:25
options
Definition: swscale.c:43
AVStream::metadata
AVDictionary * metadata
Definition: avformat.h:825
MATROSKA_ID_SEEKID
#define MATROSKA_ID_SEEKID
Definition: matroska.h:231
FLAC_STREAMINFO_SIZE
#define FLAC_STREAMINFO_SIZE
Definition: flac.h:32
AV_DISPOSITION_METADATA
#define AV_DISPOSITION_METADATA
The subtitle stream contains time-aligned metadata that is not intended to be directly presented to t...
Definition: avformat.h:700
MatroskaTrackAudio::buf
uint8_t * buf
Definition: matroskadec.c:239
double
double
Definition: af_crystalizer.c:132
MatroskaTrack::codec_delay
uint64_t codec_delay
Definition: matroskadec.c:280
LEVEL_ENDED
#define LEVEL_ENDED
Definition: matroskadec.c:84
MATROSKA_ID_CHAPTERTIMESTART
#define MATROSKA_ID_CHAPTERTIMESTART
Definition: matroska.h:263
MatroskaTagTarget::typevalue
uint64_t typevalue
Definition: matroskadec.c:333
ff_codec_movvideo_tags
const AVCodecTag ff_codec_movvideo_tags[]
Definition: isom_tags.c:29
MatroskaMasteringMeta::min_luminance
CountedElement min_luminance
Definition: matroskadec.c:175
MATROSKA_ID_CUEBLOCKNUMBER
#define MATROSKA_ID_CUEBLOCKNUMBER
Definition: matroska.h:210
AV_DISPOSITION_ORIGINAL
#define AV_DISPOSITION_ORIGINAL
The stream is in original language.
Definition: avformat.h:632
MatroskaLevel1Element::parsed
int parsed
Definition: matroskadec.c:377
MatroskaTrack::flag_hearingimpaired
uint64_t flag_hearingimpaired
Definition: matroskadec.c:271
MatroskaTrackVideo::cropped_width
uint64_t cropped_width
Definition: matroskadec.c:209
MATROSKA_TRACK_TYPE_VIDEO
@ MATROSKA_TRACK_TYPE_VIDEO
Definition: matroska.h:280
CountedElement::s
char * s
Definition: matroskadec.c:107
AVCodecParameters::ch_layout
AVChannelLayout ch_layout
Audio only.
Definition: codec_par.h:180
av_chroma_location_pos_to_enum
enum AVChromaLocation av_chroma_location_pos_to_enum(int xpos, int ypos)
Converts swscale x/y chroma position to AVChromaLocation.
Definition: pixdesc.c:3771
MATROSKA_ID_FILEMIMETYPE
#define MATROSKA_ID_FILEMIMETYPE
Definition: matroska.h:256
MATROSKA_ID_VIDEODISPLAYHEIGHT
#define MATROSKA_ID_VIDEODISPLAYHEIGHT
Definition: matroska.h:118
base64.h
MatroskaTrackPlane::type
uint64_t type
Definition: matroskadec.c:244
MatroskaLevel1Element
Definition: matroskadec.c:374
AV_PKT_DATA_CONTENT_LIGHT_LEVEL
@ AV_PKT_DATA_CONTENT_LIGHT_LEVEL
Content light level (based on CTA-861.3).
Definition: packet.h:232
MATROSKA_ID_TRACKAUDIO
#define MATROSKA_ID_TRACKAUDIO
Definition: matroska.h:81
AVCOL_RANGE_UNSPECIFIED
@ AVCOL_RANGE_UNSPECIFIED
Definition: pixfmt.h:716
matroska_index_pos
static EbmlSyntax matroska_index_pos[]
Definition: matroskadec.c:691
CUES_END
#define CUES_END
Definition: matroska.h:430
ff_codec_movaudio_tags
const AVCodecTag ff_codec_movaudio_tags[]
Definition: isom_tags.c:305
MatroskaTrackEncoding::compression
MatroskaTrackCompression compression
Definition: matroskadec.c:161
av_stereo3d_alloc_size
AVStereo3D * av_stereo3d_alloc_size(size_t *size)
Allocate an AVStereo3D structure and set its fields to default values.
Definition: stereo3d.c:40
index
int index
Definition: gxfenc.c:90
c
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
Definition: undefined.txt:32
AVPALETTE_COUNT
#define AVPALETTE_COUNT
Definition: pixfmt.h:33
AVPROBE_SCORE_EXTENSION
#define AVPROBE_SCORE_EXTENSION
score for file extension
Definition: avformat.h:461
AVCodecParameters::sample_rate
int sample_rate
Audio only.
Definition: codec_par.h:184
av_buffer_create
AVBufferRef * av_buffer_create(uint8_t *data, size_t size, void(*free)(void *opaque, uint8_t *data), void *opaque, int flags)
Create an AVBuffer from an existing array.
Definition: buffer.c:55
bytestream2_get_bytes_left
static av_always_inline int bytestream2_get_bytes_left(GetByteContext *g)
Definition: bytestream.h:158
SKIP_TRACK
@ SKIP_TRACK
Definition: matroskadec.c:2585
ff_log2_tab
const uint8_t ff_log2_tab[256]
Definition: log2_tab.c:23
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: codec_id.h:49
MatroskaChapter::start
uint64_t start
Definition: matroskadec.c:305
EBML_STR
@ EBML_STR
Definition: matroskadec.c:93
MATROSKA_ID_VIDEOCOLORMAXCLL
#define MATROSKA_ID_VIDEOCOLORMAXCLL
Definition: matroska.h:146
AV_PKT_DATA_SPHERICAL
@ AV_PKT_DATA_SPHERICAL
This side data should be associated with a video stream and corresponds to the AVSphericalMapping str...
Definition: packet.h:225
MATROSKA_ID_TRACKENTRY
#define MATROSKA_ID_TRACKENTRY
Definition: matroska.h:74
AVCodecParameters::extradata_size
int extradata_size
Size of the extradata content in bytes.
Definition: codec_par.h:73
AV_WB32
#define AV_WB32(p, v)
Definition: intreadwrite.h:415
matroska_track_encoding_encryption
static EbmlSyntax matroska_track_encoding_encryption[]
Definition: matroskadec.c:555
EBML_FLOAT
@ EBML_FLOAT
Definition: matroskadec.c:92
MatroskaTrack::default_duration
uint64_t default_duration
Definition: matroskadec.c:267
AV_CODEC_ID_AAC
@ AV_CODEC_ID_AAC
Definition: codec_id.h:450
ebml_read_uint
static int ebml_read_uint(AVIOContext *pb, int size, uint64_t default_value, uint64_t *num)
Definition: matroskadec.c:985
MATROSKA_ID_TAGDEFAULT
#define MATROSKA_ID_TAGDEFAULT
Definition: matroska.h:218
MatroskaTrackVideoProjection::type
uint64_t type
Definition: matroskadec.c:196
MATROSKA_TRACK_ENCODING_COMP_BZLIB
@ MATROSKA_TRACK_ENCODING_COMP_BZLIB
Definition: matroska.h:292
options
const OptionDef options[]
AV_DISPOSITION_CAPTIONS
#define AV_DISPOSITION_CAPTIONS
The subtitle stream contains captions, providing a transcription and possibly a translation of audio.
Definition: avformat.h:689
MATROSKA_ID_AUDIOBITDEPTH
#define MATROSKA_ID_AUDIOBITDEPTH
Definition: matroska.h:172
MatroskaDemuxContext::tracks
EbmlList tracks
Definition: matroskadec.c:396
MatroskaTrackVideoColor::cb_sub_vert
uint64_t cb_sub_vert
Definition: matroskadec.c:184
MatroskaTrack::flag_visualimpaired
uint64_t flag_visualimpaired
Definition: matroskadec.c:272
MATROSKA_VIDEO_STEREOMODE_TYPE_LEFT_RIGHT
@ MATROSKA_VIDEO_STEREOMODE_TYPE_LEFT_RIGHT
Definition: matroska.h:314
MATROSKA_ID_TRACKFLAGDEFAULT
#define MATROSKA_ID_TRACKFLAGDEFAULT
Definition: matroska.h:98
AVIOContext
Bytestream IO Context.
Definition: avio.h:160
AV_CODEC_ID_PCM_S24LE
@ AV_CODEC_ID_PCM_S24LE
Definition: codec_id.h:347
MatroskaCluster::block
MatroskaBlock block
Definition: matroskadec.c:369
av_lzo1x_decode
int av_lzo1x_decode(void *out, int *outlen, const void *in, int *inlen)
Decodes LZO 1x compressed data.
Definition: lzo.c:136
AV_SPHERICAL_CUBEMAP
@ AV_SPHERICAL_CUBEMAP
Video frame is split into 6 faces of a cube, and arranged on a 3x2 layout.
Definition: spherical.h:61
MATROSKA_ID_ENCODINGCOMPALGO
#define MATROSKA_ID_ENCODINGCOMPALGO
Definition: matroska.h:180
AV_CODEC_ID_OTF
@ AV_CODEC_ID_OTF
Definition: codec_id.h:595
MATROSKA_ID_TRACKFLAGCOMMENTARY
#define MATROSKA_ID_TRACKFLAGCOMMENTARY
Definition: matroska.h:104
MatroskaTrack::flag_textdescriptions
uint64_t flag_textdescriptions
Definition: matroskadec.c:273
STEREO_MODE_CONV
#define STEREO_MODE_CONV(STEREOMODETYPE, STEREO3DTYPE, FLAGS, WDIV, HDIV, WEBM)
MatroskaDemuxContext::is_live
int is_live
Definition: matroskadec.c:431
EbmlSyntax
Definition: matroskadec.c:112
MATROSKA_ID_TRACKFLAGLACING
#define MATROSKA_ID_TRACKFLAGLACING
Definition: matroska.h:105
AVPacket::size
int size
Definition: packet.h:536
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:94
FFFormatContext::parse_pkt
AVPacket * parse_pkt
The generic code uses this as a temporary packet to parse packets or for muxing, especially flushing.
Definition: internal.h:104
MatroskaTrackVideoColor::matrix_coefficients
uint64_t matrix_coefficients
Definition: matroskadec.c:179
ff_codec_get_id
enum AVCodecID ff_codec_get_id(const AVCodecTag *tags, unsigned int tag)
Definition: utils.c:136
MATROSKA_ID_VIDEOCOLOR_GX
#define MATROSKA_ID_VIDEOCOLOR_GX
Definition: matroska.h:152
mkv_create_display_matrix
static int mkv_create_display_matrix(AVStream *st, const MatroskaTrackVideoProjection *proj, void *logctx)
Definition: matroskadec.c:2356
AVIOContext::seekable
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable.
Definition: avio.h:261
qtpalette.h
av_bprint_finalize
int av_bprint_finalize(AVBPrint *buf, char **ret_str)
Finalize a print buffer.
Definition: bprint.c:240
FFStream
Definition: internal.h:128
matroska_convert_tags
static void matroska_convert_tags(AVFormatContext *s)
Definition: matroskadec.c:1842
AVSphericalMapping::bound_right
uint32_t bound_right
Distance from the right edge.
Definition: spherical.h:181
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
AV_PKT_DATA_DYNAMIC_HDR10_PLUS
@ AV_PKT_DATA_DYNAMIC_HDR10_PLUS
HDR10+ dynamic metadata associated with a video frame.
Definition: packet.h:296
MatroskaTrackEncoding::encryption
MatroskaTrackEncryption encryption
Definition: matroskadec.c:162
MATROSKA_ID_TRACKFLAGENABLED
#define MATROSKA_ID_TRACKFLAGENABLED
Definition: matroska.h:97
ff_dict_set_timestamp
int ff_dict_set_timestamp(AVDictionary **dict, const char *key, int64_t timestamp)
Set a dictionary value to an ISO-8601 compliant timestamp string.
Definition: utils.c:603
FFIOContext::pub
AVIOContext pub
Definition: avio_internal.h:29
MatroskaTrackAudio::frame_size
int frame_size
Definition: matroskadec.c:234
EBML_NONE
@ EBML_NONE
Definition: matroskadec.c:89
MATROSKA_ID_FILEDATA
#define MATROSKA_ID_FILEDATA
Definition: matroska.h:257
bps
unsigned bps
Definition: movenc.c:1912
MatroskaTrack::max_block_additional_id
uint64_t max_block_additional_id
Definition: matroskadec.c:287
MATROSKA_ID_VIDEOPROJECTIONPOSEPITCH
#define MATROSKA_ID_VIDEOPROJECTIONPOSEPITCH
Definition: matroska.h:165
MatroskaTrack::uid
uint64_t uid
Definition: matroskadec.c:260
size
int size
Definition: twinvq_data.h:10344
MATROSKA_VIDEO_FIELDORDER_UNDETERMINED
@ MATROSKA_VIDEO_FIELDORDER_UNDETERMINED
Definition: matroska.h:306
MATROSKA_ID_BLOCKMORE
#define MATROSKA_ID_BLOCKMORE
Definition: matroska.h:240
mka_parse_audio
static int mka_parse_audio(MatroskaTrack *track, AVStream *st, AVCodecParameters *par, const MatroskaDemuxContext *matroska, AVFormatContext *s, int *extradata_offset)
Definition: matroskadec.c:2822
MATROSKA_BLOCK_ADD_ID_TYPE_OPAQUE
@ MATROSKA_BLOCK_ADD_ID_TYPE_OPAQUE
Definition: matroska.h:362
AV_WL32A
#define AV_WL32A(p, v)
Definition: intreadwrite.h:571
ff_get_qtpalette
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,...
Definition: qtpalette.c:323
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:248
MKBETAG
#define MKBETAG(a, b, c, d)
Definition: macros.h:56
planes
static const struct @489 planes[]
mkv_stereo_mode_display_mul
static void mkv_stereo_mode_display_mul(int stereo_mode, int *h_width, int *h_height)
Definition: matroskadec.c:2218
AV_RB32
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
Definition: bytestream.h:96
avpriv_report_missing_feature
void avpriv_report_missing_feature(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
MATROSKA_ID_VIDEOCOLORMAXFALL
#define MATROSKA_ID_VIDEOCOLORMAXFALL
Definition: matroska.h:147
PacketListEntry::pkt
AVPacket pkt
Definition: packet_internal.h:30
matroska_attachments
static EbmlSyntax matroska_attachments[2]
Definition: matroskadec.c:446
transfer_characteristics
static const struct TransferCharacteristics transfer_characteristics[AVCOL_TRC_NB]
Definition: vf_colorspace.c:167
EbmlBin
Definition: matroskadec.c:133
NEEDS_CHECKING
#define NEEDS_CHECKING
Definition: matroskadec.c:83
AVCodecParameters::profile
int profile
Codec-specific bitstream restrictions that the stream conforms to.
Definition: codec_par.h:128
AV_DISPOSITION_DUB
#define AV_DISPOSITION_DUB
The stream is not in original language.
Definition: avformat.h:626
range
enum AVColorRange range
Definition: mediacodec_wrapper.c:2594
EBML_UNKNOWN_LENGTH
#define EBML_UNKNOWN_LENGTH
Definition: matroskadec.c:82
MATROSKA_ID_VIDEOCOLORCBSUBHORZ
#define MATROSKA_ID_VIDEOCOLORCBSUBHORZ
Definition: matroska.h:138
AVStream::sample_aspect_ratio
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
Definition: avformat.h:823
FFInputFormat::p
AVInputFormat p
The public AVInputFormat.
Definition: demux.h:46
INITIALIZATION_RANGE
#define INITIALIZATION_RANGE
Definition: matroska.h:428
EBML_NEST
@ EBML_NEST
Definition: matroskadec.c:96
MATROSKA_ID_POINTENTRY
#define MATROSKA_ID_POINTENTRY
Definition: matroska.h:199
dovi_isom.h
header
static const uint8_t header[24]
Definition: sdr2.c:68
AV_DISPOSITION_HEARING_IMPAIRED
#define AV_DISPOSITION_HEARING_IMPAIRED
The stream is intended for hearing impaired audiences.
Definition: avformat.h:655
MATROSKA_ID_BLKADDIDEXTRADATA
#define MATROSKA_ID_BLKADDIDEXTRADATA
Definition: matroska.h:196
AVPacket::dts
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
Definition: packet.h:534
AV_WL16
#define AV_WL16(p, v)
Definition: intreadwrite.h:408
MatroskaTrack::codec_id
char * codec_id
Definition: matroskadec.c:263
avio_r8
int avio_r8(AVIOContext *s)
Definition: aviobuf.c:603
matroska_simpletag
static EbmlSyntax matroska_simpletag[]
Definition: matroskadec.c:711
AVSphericalMapping::padding
uint32_t padding
Number of pixels to pad from the edge of each cube face.
Definition: spherical.h:194
MatroskaTrack::num
uint64_t num
Definition: matroskadec.c:259
EbmlList::nb_elem
int nb_elem
Definition: matroskadec.c:128
a
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
Definition: undefined.txt:41
MATROSKA_ID_ENCODINGTYPE
#define MATROSKA_ID_ENCODINGTYPE
Definition: matroska.h:178
EBML_SINT
@ EBML_SINT
Definition: matroskadec.c:91
av_packet_side_data_add
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.
Definition: packet.c:700
AV_CODEC_ID_RV30
@ AV_CODEC_ID_RV30
Definition: codec_id.h:120
offset
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
Definition: writing_filters.txt:86
MatroskaIndexPos::track
uint64_t track
Definition: matroskadec.c:314
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: packet.h:541
av_dict_free
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
Definition: dict.c:221
read_header
static int read_header(FFV1Context *f, RangeCoder *c)
Definition: ffv1dec.c:467
MatroskaTrack::codec_delay_in_track_tb
uint64_t codec_delay_in_track_tb
Definition: matroskadec.c:281
av_strstart
int av_strstart(const char *str, const char *pfx, const char **ptr)
Return non-zero if pfx is a prefix of str.
Definition: avstring.c:36
version
version
Definition: libkvazaar.c:315
MATROSKA_ID_VIDEOPIXELHEIGHT
#define MATROSKA_ID_VIDEOPIXELHEIGHT
Definition: matroska.h:120
MatroskaTrackVideoColor::chroma_siting_horz
uint64_t chroma_siting_horz
Definition: matroskadec.c:185
MatroskaTagTarget
Definition: matroskadec.c:331
MatroskaBlockMore::additional_id
uint64_t additional_id
Definition: matroskadec.c:355
MATROSKA_ID_VIDEOFRAMERATE
#define MATROSKA_ID_VIDEOFRAMERATE
Definition: matroska.h:116
MatroskaBlock::non_simple
uint64_t non_simple
Definition: matroskadec.c:362
MatroskaBlockAdditionMapping
Definition: matroskadec.c:251
EBML_UTF8
@ EBML_UTF8
Definition: matroskadec.c:94
MatroskaIndex::pos
EbmlList pos
Definition: matroskadec.c:320
AV_LOG_INFO
#define AV_LOG_INFO
Standard information.
Definition: log.h:220
CountedElement::count
unsigned count
Definition: matroskadec.c:109
matroska_aac_sri
static int matroska_aac_sri(int samplerate)
Definition: matroskadec.c:2120
MatroskaChapter::chapter
AVChapter * chapter
Definition: matroskadec.c:310
MATROSKA_ID_MUXINGAPP
#define MATROSKA_ID_MUXINGAPP
Definition: matroska.h:69
MatroskaDemuxContext::resync_pos
int64_t resync_pos
Definition: matroskadec.c:388
MATROSKA_ID_EDITIONFLAGDEFAULT
#define MATROSKA_ID_EDITIONFLAGDEFAULT
Definition: matroska.h:271
AVFormatContext::error_recognition
int error_recognition
Error recognition; higher values will detect more errors but may misdetect some more or less valid pa...
Definition: avformat.h:1524
av_mastering_display_metadata_alloc_size
AVMasteringDisplayMetadata * av_mastering_display_metadata_alloc_size(size_t *size)
Allocate an AVMasteringDisplayMetadata structure and set its fields to default values.
Definition: mastering_display_metadata.c:44
MATROSKA_ID_TRACKPLANETYPE
#define MATROSKA_ID_TRACKPLANETYPE
Definition: matroska.h:86
FFStream::skip_to_keyframe
int skip_to_keyframe
Indicates that everything up to the next keyframe should be discarded.
Definition: internal.h:203
ffio_limit
int ffio_limit(AVIOContext *s, int size)
Definition: aviobuf.c:1061
layout
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
Definition: filter_design.txt:18
MATROSKA_ID_CODECINFOURL
#define MATROSKA_ID_CODECINFOURL
Definition: matroska.h:90
MatroskaTrackVideo::display_height
uint64_t display_height
Definition: matroskadec.c:206
EBML_TYPE_COUNT
@ EBML_TYPE_COUNT
Definition: matroskadec.c:99
MATROSKA_ID_FILEDESC
#define MATROSKA_ID_FILEDESC
Definition: matroska.h:254
AV_CODEC_ID_GIF
@ AV_CODEC_ID_GIF
Definition: codec_id.h:149
MATROSKA_ID_VIDEOPROJECTIONTYPE
#define MATROSKA_ID_VIDEOPROJECTIONTYPE
Definition: matroska.h:162
AV_CODEC_ID_MJPEG
@ AV_CODEC_ID_MJPEG
Definition: codec_id.h:59
MatroskaLevel::length
uint64_t length
Definition: matroskadec.c:351
EbmlSyntax::i
int64_t i
Definition: matroskadec.c:119
MATROSKA_ID_FILENAME
#define MATROSKA_ID_FILENAME
Definition: matroska.h:255
interlaced
uint8_t interlaced
Definition: mxfenc.c:2287
AV_CODEC_ID_ATRAC1
@ AV_CODEC_ID_ATRAC1
Definition: codec_id.h:494
MatroskaDemuxContext::chapters
EbmlList chapters
Definition: matroskadec.c:398
AV_CODEC_ID_RA_288
@ AV_CODEC_ID_RA_288
Definition: codec_id.h:434
FILENAME
#define FILENAME
Definition: matroska.h:431
bprint.h
AV_CODEC_ID_RV40
@ AV_CODEC_ID_RV40
Definition: codec_id.h:121
MatroskaTrackAudio::pkt_cnt
int pkt_cnt
Definition: matroskadec.c:237
AV_BASE64_SIZE
#define AV_BASE64_SIZE(x)
Calculate the output size needed to base64-encode x bytes to a null-terminated string.
Definition: base64.h:66
AVSphericalMapping::roll
int32_t roll
Rotation around the forward vector [-180, 180].
Definition: spherical.h:140
MatroskaChapter::uid
uint64_t uid
Definition: matroskadec.c:307
MATROSKA_ID_CODECID
#define MATROSKA_ID_CODECID
Definition: matroska.h:87
MatroskaTrackVideoColor::range
uint64_t range
Definition: matroskadec.c:187
AV_CODEC_ID_RV10
@ AV_CODEC_ID_RV10
Definition: codec_id.h:57
MatroskaTrackVideo::color_space
EbmlBin color_space
Definition: matroskadec.c:211
MatroskaTrackVideo::pixel_cropb
uint64_t pixel_cropb
Definition: matroskadec.c:214
MatroskaLevel::start
uint64_t start
Definition: matroskadec.c:350
matroska_track_video
static EbmlSyntax matroska_track_video[19]
Definition: matroskadec.c:443
AV_CODEC_ID_NONE
@ AV_CODEC_ID_NONE
Definition: codec_id.h:50
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
AVPacket::pts
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
Definition: packet.h:528
avio_internal.h
AV_LZO_OUTPUT_PADDING
#define AV_LZO_OUTPUT_PADDING
Definition: lzo.h:47
MatroskaIndex::time
uint64_t time
Definition: matroskadec.c:319
matroska_track_audio
static EbmlSyntax matroska_track_audio[]
Definition: matroskadec.c:541
ff_isom_parse_dvcc_dvvc
int ff_isom_parse_dvcc_dvvc(void *logctx, AVStream *st, const uint8_t *buf_ptr, uint64_t size)
Definition: dovi_isom.c:32
MatroskaIndexPos
Definition: matroskadec.c:313
matroska_tagtargets
static EbmlSyntax matroska_tagtargets[]
Definition: matroskadec.c:721
MatroskaTags::target
MatroskaTagTarget target
Definition: matroskadec.c:340
BANDWIDTH
#define BANDWIDTH
Definition: matroska.h:432
MATROSKA_TRACK_ENCODING_COMP_HEADERSTRIP
@ MATROSKA_TRACK_ENCODING_COMP_HEADERSTRIP
Definition: matroska.h:294
algo
Definition: dct.c:57
AVCodecParameters::height
int height
Definition: codec_par.h:135
CountedElement::i
int64_t i
Definition: matroskadec.c:105
DURATION
#define DURATION
Definition: matroska.h:433
AV_TIME_BASE
#define AV_TIME_BASE
Internal time base represented as integer.
Definition: avutil.h:254
MATROSKA_ID_CUECLUSTERPOSITION
#define MATROSKA_ID_CUECLUSTERPOSITION
Definition: matroska.h:207
MATROSKA_TRACK_ENCODING_COMP_ZLIB
@ MATROSKA_TRACK_ENCODING_COMP_ZLIB
Definition: matroska.h:291
AVCodecParameters::block_align
int block_align
Audio only.
Definition: codec_par.h:191
MatroskaMasteringMeta::r_x
double r_x
Definition: matroskadec.c:166
MATROSKA_ID_CHAPTERPHYSEQUIV
#define MATROSKA_ID_CHAPTERPHYSEQUIV
Definition: matroska.h:276
MatroskaTrackVideo::projection
MatroskaTrackVideoProjection projection
Definition: matroskadec.c:222
av_malloc_array
#define av_malloc_array(a, b)
Definition: tableprint_vlc.h:32
MATROSKA_ID_CUETRACK
#define MATROSKA_ID_CUETRACK
Definition: matroska.h:206
display.h
Ebml::doctype
char * doctype
Definition: matroskadec.c:144
AV_FIELD_BB
@ AV_FIELD_BB
Bottom coded first, bottom displayed first.
Definition: defs.h:204
MATROSKA_ID_SEEKPOSITION
#define MATROSKA_ID_SEEKPOSITION
Definition: matroska.h:232
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:56
MATROSKA_ID_CLUSTER
#define MATROSKA_ID_CLUSTER
Definition: matroska.h:61
MATROSKA_ID_TRACKLANGUAGE
#define MATROSKA_ID_TRACKLANGUAGE
Definition: matroska.h:96
AV_CODEC_ID_RV20
@ AV_CODEC_ID_RV20
Definition: codec_id.h:58
AV_CODEC_ID_HEVC
@ AV_CODEC_ID_HEVC
Definition: codec_id.h:228
value
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
Definition: writing_filters.txt:86
AVMEDIA_TYPE_ATTACHMENT
@ AVMEDIA_TYPE_ATTACHMENT
Opaque data information usually sparse.
Definition: avutil.h:205
FFMIN
#define FFMIN(a, b)
Definition: macros.h:49
MatroskaDemuxContext::is_webm
int is_webm
Definition: matroskadec.c:428
av_d2q
AVRational av_d2q(double d, int max)
Convert a double precision floating point number to a rational.
Definition: rational.c:106
MATROSKA_ID_VIDEOFLAGINTERLACED
#define MATROSKA_ID_VIDEOFLAGINTERLACED
Definition: matroska.h:126
matroska_chapter
static EbmlSyntax matroska_chapter[6]
Definition: matroskadec.c:446
CUE_TIMESTAMPS
#define CUE_TIMESTAMPS
Definition: matroska.h:435
AV_CODEC_ID_PCM_S32BE
@ AV_CODEC_ID_PCM_S32BE
Definition: codec_id.h:344
MatroskaTrackAudio
Definition: matroskadec.c:225
EBML_ID_CRC32
#define EBML_ID_CRC32
Definition: matroska.h:45
EbmlSyntax::data_offset
size_t data_offset
Definition: matroskadec.c:117
MatroskaDemuxContext::tags
EbmlList tags
Definition: matroskadec.c:400
MatroskaLevel1Element::id
uint32_t id
Definition: matroskadec.c:376
EbmlSyntax::f
double f
Definition: matroskadec.c:121
ff_mkv_metadata_conv
const AVMetadataConv ff_mkv_metadata_conv[]
Definition: matroska.c:125
demux.h
AVCodecParameters::color_range
enum AVColorRange color_range
Video only.
Definition: codec_par.h:166
MatroskaTrack::flag_forced
uint64_t flag_forced
Definition: matroskadec.c:269
AVMasteringDisplayMetadata
Mastering display metadata capable of representing the color volume of the display used to master the...
Definition: mastering_display_metadata.h:38
len
int len
Definition: vorbis_enc_data.h:426
MatroskaTrack::flag_comment
uint64_t flag_comment
Definition: matroskadec.c:270
get_qt_codec
static int get_qt_codec(MatroskaTrack *track, uint32_t *fourcc, enum AVCodecID *codec_id)
Definition: matroskadec.c:2553
profile
int profile
Definition: mxfenc.c:2250
ff_get_wav_header
int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian)
Definition: riffdec.c:95
AVCOL_SPC_UNSPECIFIED
@ AVCOL_SPC_UNSPECIFIED
Definition: pixfmt.h:676
av_rescale
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest.
Definition: mathematics.c:129
AVCodecParameters::coded_side_data
AVPacketSideData * coded_side_data
Additional data associated with the entire stream.
Definition: codec_par.h:81
MATROSKA_ID_EDITIONFLAGHIDDEN
#define MATROSKA_ID_EDITIONFLAGHIDDEN
Definition: matroska.h:270
MATROSKA_ID_CHAPTERUID
#define MATROSKA_ID_CHAPTERUID
Definition: matroska.h:273
EbmlList::alloc_elem_size
unsigned int alloc_elem_size
Definition: matroskadec.c:129
matroska_index
static EbmlSyntax matroska_index[2]
Definition: matroskadec.c:447
MatroskaTrackCompression::settings
EbmlBin settings
Definition: matroskadec.c:150
AVCodecParameters::field_order
enum AVFieldOrder field_order
Video only.
Definition: codec_par.h:161
AVDynamicHDRPlus
This struct represents dynamic metadata for color volume transform - application 4 of SMPTE 2094-40:2...
Definition: hdr_dynamic_metadata.h:243
MATROSKA_VIDEO_STEREOMODE_TYPE_RIGHT_LEFT
@ MATROSKA_VIDEO_STEREOMODE_TYPE_RIGHT_LEFT
Definition: matroska.h:324
MatroskaAttachment::uid
uint64_t uid
Definition: matroskadec.c:295
MatroskaTrackAudio::bitdepth
uint64_t bitdepth
Definition: matroskadec.c:228
matroska_mastering_meta
static EbmlSyntax matroska_mastering_meta[]
Definition: matroskadec.c:478
MATROSKA_ID_VIDEOPROJECTIONPOSEYAW
#define MATROSKA_ID_VIDEOPROJECTIONPOSEYAW
Definition: matroska.h:164
language
Undefined Behavior In the C language
Definition: undefined.txt:3
matroska_track_video_color
static EbmlSyntax matroska_track_video_color[15]
Definition: matroskadec.c:443
AVStream::disposition
int disposition
Stream disposition - a combination of AV_DISPOSITION_* flags.
Definition: avformat.h:814
AV_PKT_DATA_MATROSKA_BLOCKADDITIONAL
@ AV_PKT_DATA_MATROSKA_BLOCKADDITIONAL
Data found in BlockAdditional element of matroska container.
Definition: packet.h:188
AV_DISPOSITION_VISUAL_IMPAIRED
#define AV_DISPOSITION_VISUAL_IMPAIRED
The stream is intended for visually impaired audiences.
Definition: avformat.h:659
MatroskaMasteringMeta::g_x
double g_x
Definition: matroskadec.c:168
MatroskaTags::tag
EbmlList tag
Definition: matroskadec.c:341
tag
uint32_t tag
Definition: movenc.c:1911
MatroskaTagTarget::chapteruid
uint64_t chapteruid
Definition: matroskadec.c:335
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:745
mkv_mime_tags
static const CodecMime mkv_mime_tags[]
Definition: matroskadec.c:819
EbmlBin::pos
int64_t pos
Definition: matroskadec.c:137
mkv_parse_video
static int mkv_parse_video(MatroskaTrack *track, AVStream *st, AVCodecParameters *par, const MatroskaDemuxContext *matroska, int *extradata_offset)
Definition: matroskadec.c:2934
avio_seek
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
Definition: aviobuf.c:231
AVClass::class_name
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
Definition: log.h:80
av_strlcat
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,...
Definition: avstring.c:95
AVSphericalMapping::pitch
int32_t pitch
Rotation around the right vector [-90, 90].
Definition: spherical.h:139
MATROSKA_ID_TRACKCOMBINEPLANES
#define MATROSKA_ID_TRACKCOMBINEPLANES
Definition: matroska.h:83
AVStereo3D::type
enum AVStereo3DType type
How views are packed within the video.
Definition: stereo3d.h:207
MatroskaTrackCompression
Definition: matroskadec.c:148
av_channel_layout_check
int av_channel_layout_check(const AVChannelLayout *channel_layout)
Check whether a channel layout is valid, i.e.
Definition: channel_layout.c:783
sps
static int FUNC() sps(CodedBitstreamContext *ctx, RWContext *rw, H264RawSPS *current)
Definition: cbs_h264_syntax_template.c:260
EbmlSyntax::u
uint64_t u
Definition: matroskadec.c:120
matroska_blockmore
static EbmlSyntax matroska_blockmore[]
Definition: matroskadec.c:769
MATROSKA_ID_VIDEOCOLOR_BX
#define MATROSKA_ID_VIDEOCOLOR_BX
Definition: matroska.h:154
MATROSKA_ID_TAGSTRING
#define MATROSKA_ID_TAGSTRING
Definition: matroska.h:216
MatroskaDemuxContext::ctx
AVFormatContext * ctx
Definition: matroskadec.c:382
AVSTREAM_PARSE_HEADERS
@ AVSTREAM_PARSE_HEADERS
Only parse headers, do not repack.
Definition: avformat.h:591
pos
unsigned int pos
Definition: spdifenc.c:414
MATROSKA_ID_VIDEOCOLORMATRIXCOEFF
#define MATROSKA_ID_VIDEOCOLORMATRIXCOEFF
Definition: matroska.h:134
avformat.h
MatroskaDemuxContext::time_scale
uint64_t time_scale
Definition: matroskadec.c:391
MatroskaAttachment
Definition: matroskadec.c:294
av_bprintf
void av_bprintf(AVBPrint *buf, const char *fmt,...)
Definition: bprint.c:99
dict.h
av_packet_side_data_new
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.
Definition: packet.c:707
lzo.h
MATROSKA_ID_SIMPLEBLOCK
#define MATROSKA_ID_SIMPLEBLOCK
Definition: matroska.h:243
MATROSKA_ID_TRACKPLANE
#define MATROSKA_ID_TRACKPLANE
Definition: matroska.h:84
AV_DISPOSITION_DESCRIPTIONS
#define AV_DISPOSITION_DESCRIPTIONS
The subtitle stream contains a textual description of the video content.
Definition: avformat.h:695
AV_INPUT_BUFFER_PADDING_SIZE
#define AV_INPUT_BUFFER_PADDING_SIZE
Definition: defs.h:40
id
enum AVCodecID id
Definition: dts2pts.c:367
MATROSKA_ID_VIDEOPIXELCROPL
#define MATROSKA_ID_VIDEOPIXELCROPL
Definition: matroska.h:123
MATROSKA_BLOCK_ADD_ID_TYPE_DVVC
@ MATROSKA_BLOCK_ADD_ID_TYPE_DVVC
Definition: matroska.h:365
AV_RL32
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
Definition: bytestream.h:92
U
#define U(x)
Definition: vpx_arith.h:37
MatroskaIndex
Definition: matroskadec.c:318
AVCodecParameters::chroma_location
enum AVChromaLocation chroma_location
Definition: codec_par.h:170
MATROSKA_VIDEO_STEREOMODE_TYPE_COL_INTERLEAVED_RL
@ MATROSKA_VIDEO_STEREOMODE_TYPE_COL_INTERLEAVED_RL
Definition: matroska.h:321
MATROSKA_ID_CODECNAME
#define MATROSKA_ID_CODECNAME
Definition: matroska.h:89
AV_PKT_DATA_WEBVTT_IDENTIFIER
@ AV_PKT_DATA_WEBVTT_IDENTIFIER
The optional first identifier line of a WebVTT cue.
Definition: packet.h:193
webm_dash_class
static const AVClass webm_dash_class
Definition: webmdashenc.c:539
MatroskaTrackVideo::frame_rate
double frame_rate
Definition: matroskadec.c:204
oggdec.h
MATROSKA_ID_EDITIONENTRY
#define MATROSKA_ID_EDITIONENTRY
Definition: matroska.h:261
MatroskaChapter::title
char * title
Definition: matroskadec.c:308
OFFSET
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 keep it simple and lowercase description are in without and describe what they for example set the foo of the bar offset is the offset of the field in your see the OFFSET() macro
syntax
static const ParseSyntax syntax[]
Definition: concatdec.c:443
matroska_seekhead_entry
static EbmlSyntax matroska_seekhead_entry[]
Definition: matroskadec.c:741
AVStream::index
int index
stream index in AVFormatContext
Definition: avformat.h:751
MATROSKA_ID_TRACKMAXCACHE
#define MATROSKA_ID_TRACKMAXCACHE
Definition: matroska.h:107
matroska_seekhead
static EbmlSyntax matroska_seekhead[2]
Definition: matroskadec.c:447
ff_codec_bmp_tags
const AVCodecTag ff_codec_bmp_tags[]
Definition: riff.c:36
matroska_add_index_entries
static void matroska_add_index_entries(MatroskaDemuxContext *matroska)
Definition: matroskadec.c:1983
MATROSKA_ID_TRACKMAXBLKADDID
#define MATROSKA_ID_TRACKMAXBLKADDID
Definition: matroska.h:112
itut35.h
EBML_ID_HEADER
#define EBML_ID_HEADER
Definition: matroska.h:32
MatroskaTrack::needs_decoding
int needs_decoding
Definition: matroskadec.c:286
matroska_blockgroup
static EbmlSyntax matroska_blockgroup[8]
Definition: matroskadec.c:448
MATROSKA_ID_TAGTARGETS_TYPEVALUE
#define MATROSKA_ID_TAGTARGETS_TYPEVALUE
Definition: matroska.h:222
EBML_ID_EBMLVERSION
#define EBML_ID_EBMLVERSION
Definition: matroska.h:35
MatroskaTrackType
MatroskaTrackType
Definition: matroska.h:278
MatroskaLevel
Definition: matroskadec.c:349
MATROSKA_ID_CLUSTERPREVSIZE
#define MATROSKA_ID_CLUSTERPREVSIZE
Definition: matroska.h:237
AVIO_SEEKABLE_NORMAL
#define AVIO_SEEKABLE_NORMAL
Seeking works like for a local file.
Definition: avio.h:41
av_packet_new_side_data
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, size_t size)
Allocate new information of a packet.
Definition: packet.c:232
buffer
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
Definition: filter_design.txt:49
MatroskaTrackVideo::display_width
uint64_t display_width
Definition: matroskadec.c:205
ff_sipr_subpk_size
const unsigned char ff_sipr_subpk_size[4]
Definition: rmsipr.c:25
MATROSKA_ID_TAGLANG
#define MATROSKA_ID_TAGLANG
Definition: matroska.h:217
MatroskaTrackVideoColor::chroma_sub_horz
uint64_t chroma_sub_horz
Definition: matroskadec.c:181
is_ebml_id_valid
static int is_ebml_id_valid(uint32_t id)
Definition: matroskadec.c:1205
AVRational::den
int den
Denominator.
Definition: rational.h:60
MatroskaTrackAudio::channels
uint64_t channels
Definition: matroskadec.c:229
MATROSKA_VIDEO_STEREO_PLANE_COUNT
#define MATROSKA_VIDEO_STEREO_PLANE_COUNT
Definition: matroska.h:383
mkv_parse_dvcc_dvvc
static int mkv_parse_dvcc_dvvc(AVFormatContext *s, AVStream *st, const MatroskaTrack *track, EbmlBin *bin)
Definition: matroskadec.c:2492
MATROSKA_ID_VIDEOCOLOR
#define MATROSKA_ID_VIDEOCOLOR
Definition: matroska.h:132
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Underlying C type is int.
Definition: opt.h:259
MatroskaChapter::end
uint64_t end
Definition: matroskadec.c:306
matroska_tracks
static EbmlSyntax matroska_tracks[2]
Definition: matroskadec.c:445
defs.h
MatroskaDemuxContext::date_utc
EbmlBin date_utc
Definition: matroskadec.c:395
MATROSKA_ID_VIDEOCOLORTRANSFERCHARACTERISTICS
#define MATROSKA_ID_VIDEOCOLORTRANSFERCHARACTERISTICS
Definition: matroska.h:143
video
A Quick Description Of Rate Distortion Theory We want to encode a video
Definition: rate_distortion.txt:3
MATROSKA_ID_VIDEOCOLOR_RX
#define MATROSKA_ID_VIDEOCOLOR_RX
Definition: matroska.h:150
matroska_parse_wavpack
static int matroska_parse_wavpack(MatroskaTrack *track, uint8_t **data, int *size)
Definition: matroskadec.c:3652
avio_read
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
Definition: aviobuf.c:612
MATROSKA_TRACK_TYPE_SUBTITLE
@ MATROSKA_TRACK_TYPE_SUBTITLE
Definition: matroska.h:284
sign_extend
static av_const int sign_extend(int val, unsigned bits)
Definition: mathops.h:131
EbmlSyntax::def
union EbmlSyntax::@417 def
MatroskaMasteringMeta::max_luminance
double max_luminance
Definition: matroskadec.c:174
hdr_dynamic_metadata.h
temp
else temp
Definition: vf_mcdeint.c:263
AVStream::r_frame_rate
AVRational r_frame_rate
Real base framerate of the stream.
Definition: avformat.h:879
AV_LZO_OUTPUT_FULL
#define AV_LZO_OUTPUT_FULL
decoded data did not fit into output buffer
Definition: lzo.h:39
AV_PKT_DATA_SKIP_SAMPLES
@ AV_PKT_DATA_SKIP_SAMPLES
Recommmends skipping the specified number of samples.
Definition: packet.h:153
AVIndexEntry::pos
int64_t pos
Definition: avformat.h:600
AVIOContext::eof_reached
int eof_reached
true if was unable to read due to error or eof
Definition: avio.h:238
av_base64_encode
char * av_base64_encode(char *out, int out_size, const uint8_t *in, int in_size)
Encode data to base64 and null-terminate.
Definition: base64.c:147
MatroskaBlockAdditionMapping::name
char * name
Definition: matroskadec.c:253
samples
Filter the word “frame” indicates either a video frame or a group of audio samples
Definition: filter_design.txt:8
MATROSKA_ID_VIDEOCOLORCHROMASUBVERT
#define MATROSKA_ID_VIDEOCOLORCHROMASUBVERT
Definition: matroska.h:137
MATROSKA_VIDEO_PROJECTION_TYPE_EQUIRECTANGULAR
@ MATROSKA_VIDEO_PROJECTION_TYPE_EQUIRECTANGULAR
Definition: matroska.h:355
AVMasteringDisplayMetadata::min_luminance
AVRational min_luminance
Min luminance of mastering display (cd/m^2).
Definition: mastering_display_metadata.h:52
EBML_UINT
@ EBML_UINT
Definition: matroskadec.c:90
AVFormatContext::duration
int64_t duration
Duration of the stream, in AV_TIME_BASE fractional seconds.
Definition: avformat.h:1400
AVPacket::stream_index
int stream_index
Definition: packet.h:537
matroska_parse_rm_audio
static int matroska_parse_rm_audio(MatroskaDemuxContext *matroska, MatroskaTrack *track, AVStream *st, uint8_t *data, int size, uint64_t timecode, int64_t pos)
Definition: matroskadec.c:3574
MatroskaTrackVideoColor::max_fall
uint64_t max_fall
Definition: matroskadec.c:191
av_buffer_realloc
int av_buffer_realloc(AVBufferRef **pbuf, size_t size)
Reallocate a given buffer.
Definition: buffer.c:183
avio_skip
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
Definition: aviobuf.c:318
MatroskaTrackVideoProjection::private
EbmlBin private
Definition: matroskadec.c:197
MATROSKA_ID_VIDEOCOLORCHROMASITINGHORZ
#define MATROSKA_ID_VIDEOCOLORCHROMASITINGHORZ
Definition: matroska.h:140
MATROSKA_TRACK_ENCODING_COMP_LZO
@ MATROSKA_TRACK_ENCODING_COMP_LZO
Definition: matroska.h:293
FFStream::index_entries
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
Definition: internal.h:184
ff_mpeg4audio_sample_rates
const int ff_mpeg4audio_sample_rates[16]
Definition: mpeg4audio_sample_rates.h:26
av_dict_set_int
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.
Definition: dict.c:165
CodecMime::id
enum AVCodecID id
Definition: internal.h:49
av_spherical_alloc
AVSphericalMapping * av_spherical_alloc(size_t *size)
Allocate a AVSphericalVideo structure and initialize its fields to default values.
Definition: spherical.c:26
av_strdup
char * av_strdup(const char *s)
Duplicate a string.
Definition: mem.c:272
AV_OPT_FLAG_DECODING_PARAM
#define AV_OPT_FLAG_DECODING_PARAM
A generic parameter which can be set by the user for demuxing or decoding.
Definition: opt.h:356
MATROSKA_ID_BLOCKREFERENCE
#define MATROSKA_ID_BLOCKREFERENCE
Definition: matroska.h:248
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
read_probe
static int read_probe(const AVProbeData *p)
Definition: cdg.c:30
AV_CODEC_ID_PCM_S32LE
@ AV_CODEC_ID_PCM_S32LE
Definition: codec_id.h:343
AVCodecParameters::bits_per_coded_sample
int bits_per_coded_sample
The number of bits per sample in the codedwords.
Definition: codec_par.h:110
MatroskaBlock::bin
EbmlBin bin
Definition: matroskadec.c:363
mem.h
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
CodecTags::id
enum AVCodecID id
Definition: matroska.h:377
packet_internal.h
MATROSKA_ID_VIDEOCOLOR_RY
#define MATROSKA_ID_VIDEOCOLOR_RY
Definition: matroska.h:151
AV_CODEC_ID_PCM_U8
@ AV_CODEC_ID_PCM_U8
Definition: codec_id.h:340
MATROSKA_VIDEO_FIELDORDER_TB
@ MATROSKA_VIDEO_FIELDORDER_TB
Definition: matroska.h:308
mastering_display_metadata.h
ITU_T_T35_COUNTRY_CODE_US
#define ITU_T_T35_COUNTRY_CODE_US
Definition: itut35.h:24
EbmlSyntax::s
const char * s
Definition: matroskadec.c:122
AVSphericalMapping::bound_left
uint32_t bound_left
Distance from the left edge.
Definition: spherical.h:179
MatroskaTrack::has_palette
int has_palette
Definition: matroskadec.c:291
MatroskaTrackVideoProjection::roll
double roll
Definition: matroskadec.c:200
AVCOL_TRC_RESERVED
@ AVCOL_TRC_RESERVED
Definition: pixfmt.h:648
MATROSKA_ID_TRACKVIDEO
#define MATROSKA_ID_TRACKVIDEO
Definition: matroska.h:80
av_dynamic_hdr_plus_alloc
AVDynamicHDRPlus * av_dynamic_hdr_plus_alloc(size_t *size)
Allocate an AVDynamicHDRPlus structure and set its fields to default values.
Definition: hdr_dynamic_metadata.c:36
MATROSKA_VIDEO_STEREOMODE_TYPE_BOTH_EYES_BLOCK_RL
@ MATROSKA_VIDEO_STEREOMODE_TYPE_BOTH_EYES_BLOCK_RL
Definition: matroska.h:327
AVIOContext::buffer
unsigned char * buffer
Start of the buffer.
Definition: avio.h:225
ff_mkv_codec_tags
const CodecTags ff_mkv_codec_tags[]
Definition: matroska.c:27
AV_CODEC_ID_PCM_F64LE
@ AV_CODEC_ID_PCM_F64LE
Definition: codec_id.h:358
MatroskaAttachment::mime
char * mime
Definition: matroskadec.c:298
MATROSKA_ID_TRACKFLAGFORCED
#define MATROSKA_ID_TRACKFLAGFORCED
Definition: matroska.h:99
MATROSKA_VIDEO_STEREOMODE_TYPE_NB
@ MATROSKA_VIDEO_STEREOMODE_TYPE_NB
Definition: matroska.h:328
av_free
#define av_free(p)
Definition: tableprint_vlc.h:34
AVDictionaryEntry
Definition: dict.h:89
MatroskaBlockMore
Definition: matroskadec.c:354
EBML_VERSION
#define EBML_VERSION
Definition: matroska.h:29
EBML_ID_EBMLREADVERSION
#define EBML_ID_EBMLREADVERSION
Definition: matroska.h:36
matroska_deliver_packet
static int matroska_deliver_packet(MatroskaDemuxContext *matroska, AVPacket *pkt)
Definition: matroskadec.c:3446
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:55
MatroskaTrack::palette
uint32_t palette[AVPALETTE_COUNT]
Definition: matroskadec.c:290
ITU_T_T35_PROVIDER_CODE_SMTPE
#define ITU_T_T35_PROVIDER_CODE_SMTPE
Definition: itut35.h:30
AVContentLightMetadata::MaxFALL
unsigned MaxFALL
Max average light level per frame (cd/m^2).
Definition: mastering_display_metadata.h:116
AVPacket
This structure stores compressed data.
Definition: packet.h:512
MatroskaTrackEncryption::key_id
EbmlBin key_id
Definition: matroskadec.c:155
AV_OPT_TYPE_BOOL
@ AV_OPT_TYPE_BOOL
Underlying C type is int.
Definition: opt.h:327
MATROSKA_ID_ENCODINGENCAESSETTINGS
#define MATROSKA_ID_ENCODINGENCAESSETTINGS
Definition: matroska.h:184
MATROSKA_ID_CHAPTERFLAGHIDDEN
#define MATROSKA_ID_CHAPTERFLAGHIDDEN
Definition: matroska.h:274
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
av_dict_set
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Definition: dict.c:86
riff.h
MATROSKA_ID_ATTACHEDFILE
#define MATROSKA_ID_ATTACHEDFILE
Definition: matroska.h:253
AVPacket::pos
int64_t pos
byte position in stream, -1 if unknown
Definition: packet.h:555
MATROSKA_ID_TRACKMINCACHE
#define MATROSKA_ID_TRACKMINCACHE
Definition: matroska.h:106
av_dynamic_hdr_plus_from_t35
int av_dynamic_hdr_plus_from_t35(AVDynamicHDRPlus *s, const uint8_t *data, size_t size)
Parse the user data registered ITU-T T.35 to AVbuffer (AVDynamicHDRPlus).
Definition: hdr_dynamic_metadata.c:61
MATROSKA_ID_CODECDELAY
#define MATROSKA_ID_CODECDELAY
Definition: matroska.h:93
FFInputFormat
Definition: demux.h:42
MatroskaMasteringMeta::g_y
double g_y
Definition: matroskadec.c:169
MatroskaTrackVideoColor::transfer_characteristics
uint64_t transfer_characteristics
Definition: matroskadec.c:188
FFMAX3
#define FFMAX3(a, b, c)
Definition: macros.h:48
mkv_stereo3d_conv
static int mkv_stereo3d_conv(AVStream *st, MatroskaVideoStereoModeType stereo_mode)
Definition: matroskadec.c:2243
matroska_track_plane
static EbmlSyntax matroska_track_plane[]
Definition: matroskadec.c:579
int32_t
int32_t
Definition: audioconvert.c:56
bytestream.h
AVSTREAM_PARSE_FULL
@ AVSTREAM_PARSE_FULL
full parsing and repack
Definition: avformat.h:590
MATROSKA_ID_ENCODINGCOMPRESSION
#define MATROSKA_ID_ENCODINGCOMPRESSION
Definition: matroska.h:179
bytestream2_init
static av_always_inline void bytestream2_init(GetByteContext *g, const uint8_t *buf, int buf_size)
Definition: bytestream.h:137
MATROSKA_ID_TAGTARGETS_TRACKUID
#define MATROSKA_ID_TAGTARGETS_TRACKUID
Definition: matroska.h:223
MatroskaTrackVideoProjection::pitch
double pitch
Definition: matroskadec.c:199
av_strlcpy
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
Definition: avstring.c:85
AV_CODEC_ID_PCM_F32LE
@ AV_CODEC_ID_PCM_F32LE
Definition: codec_id.h:356
AVCodecParameters::bit_rate
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
Definition: codec_par.h:97
block
The exact code depends on how similar the blocks are and how related they are to the block
Definition: filter_design.txt:207
MatroskaTrack::flag_original
CountedElement flag_original
Definition: matroskadec.c:274
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
MatroskaBlock::blockmore
EbmlList blockmore
Definition: matroskadec.c:364
MatroskaTrackVideo::stereo_mode
uint64_t stereo_mode
Definition: matroskadec.c:219
AV_CODEC_ID_WAVPACK
@ AV_CODEC_ID_WAVPACK
Definition: codec_id.h:473
UNKNOWN_EQUIV
#define UNKNOWN_EQUIV
Definition: matroskadec.c:86
AV_CODEC_ID_COOK
@ AV_CODEC_ID_COOK
Definition: codec_id.h:468
MATROSKA_ID_CHAPTERTIMEEND
#define MATROSKA_ID_CHAPTERTIMEEND
Definition: matroska.h:264
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
matroska_track_encoding
static EbmlSyntax matroska_track_encoding[6]
Definition: matroskadec.c:444
MatroskaTrack::seek_preroll
uint64_t seek_preroll
Definition: matroskadec.c:275
matroska_chapter_display
static EbmlSyntax matroska_chapter_display[]
Definition: matroskadec.c:658
MatroskaCluster
Definition: matroskadec.c:368
MatroskaTrackVideoColor::chroma_sub_vert
uint64_t chroma_sub_vert
Definition: matroskadec.c:182
MKTAG
#define MKTAG(a, b, c, d)
Definition: macros.h:55
MATROSKA_ID_TRACKS
#define MATROSKA_ID_TRACKS
Definition: matroska.h:56
MATROSKA_ID_ENCODINGENCKEYID
#define MATROSKA_ID_ENCODINGENCKEYID
Definition: matroska.h:186
h
h
Definition: vp9dsp_template.c:2070
MatroskaTrackAudio::samplerate
double samplerate
Definition: matroskadec.c:226
MatroskaMasteringMeta::white_x
double white_x
Definition: matroskadec.c:172
ebml_free
static void ebml_free(EbmlSyntax *syntax, void *data)
Definition: matroskadec.c:1573
AV_CODEC_ID_TIFF
@ AV_CODEC_ID_TIFF
Definition: codec_id.h:148
AVStereo3D
Stereo 3D type: this structure describes how two videos are packed within a single video surface,...
Definition: stereo3d.h:203
AVDictionaryEntry::value
char * value
Definition: dict.h:91
EbmlSyntax::is_counted
uint8_t is_counted
Definition: matroskadec.c:115
avstring.h
ff_reduce_index
void ff_reduce_index(AVFormatContext *s, int stream_index)
Ensure the index uses less memory than the maximum specified in AVFormatContext.max_index_size by dis...
Definition: seek.c:50
MATROSKA_ID_ENCODINGCOMPSETTINGS
#define MATROSKA_ID_ENCODINGCOMPSETTINGS
Definition: matroska.h:181
flac.h
MatroskaDemuxContext::cues_parsing_deferred
int cues_parsing_deferred
Definition: matroskadec.c:420
ff_vorbis_comment
int ff_vorbis_comment(AVFormatContext *ms, AVDictionary **m, const uint8_t *buf, int size, int parse_picture)
Parse Vorbis comments.
Definition: oggparsevorbis.c:149
MatroskaIndexPos::pos
uint64_t pos
Definition: matroskadec.c:315
MATROSKA_ID_SEEKPREROLL
#define MATROSKA_ID_SEEKPREROLL
Definition: matroska.h:94
MatroskaTrackVideo::pixel_cropl
uint64_t pixel_cropl
Definition: matroskadec.c:213
AVIOContext::buf_ptr
unsigned char * buf_ptr
Current position in the buffer.
Definition: avio.h:227
MATROSKA_ID_SEEKHEAD
#define MATROSKA_ID_SEEKHEAD
Definition: matroska.h:59
CHILD_OF
#define CHILD_OF(parent)
Definition: matroskadec.c:437
MatroskaBlock::reference
CountedElement reference
Definition: matroskadec.c:361
EbmlBin::data
uint8_t * data
Definition: matroskadec.c:136
EBML_LEVEL1
@ EBML_LEVEL1
Definition: matroskadec.c:97
MATROSKA_BLOCK_ADD_ID_TYPE_DVCC
@ MATROSKA_BLOCK_ADD_ID_TYPE_DVCC
Definition: matroska.h:364
fourcc
uint32_t fourcc
Definition: vaapi_decode.c:263
snprintf
#define snprintf
Definition: snprintf.h:34
MatroskaDemuxContext::skip_to_timecode
uint64_t skip_to_timecode
Definition: matroskadec.c:417
AVCodecParameters::initial_padding
int initial_padding
Audio only.
Definition: codec_par.h:203
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
MATROSKA_ID_VIDEOPROJECTIONPOSEROLL
#define MATROSKA_ID_VIDEOPROJECTIONPOSEROLL
Definition: matroska.h:166
AV_CODEC_ID_PCM_S24BE
@ AV_CODEC_ID_PCM_S24BE
Definition: codec_id.h:348
MATROSKA_ID_BLOCKADDID
#define MATROSKA_ID_BLOCKADDID
Definition: matroska.h:241
AVSphericalMapping
This structure describes how to handle spherical videos, outlining information about projection,...
Definition: spherical.h:94
skip
static void BS_FUNC() skip(BSCTX *bc, unsigned int n)
Skip n bits in the buffer.
Definition: bitstream_template.h:375
AV_RB64
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
Definition: bytestream.h:95
MatroskaBlockAdditionMapping::value
uint64_t value
Definition: matroskadec.c:252
MatroskaTrackAudio::out_samplerate
double out_samplerate
Definition: matroskadec.c:227
AVSphericalMapping::yaw
int32_t yaw
Rotation around the up vector [-180, 180].
Definition: spherical.h:138
src
#define src
Definition: vp8dsp.c:248
MATROSKA_ID_TAGTARGETS_CHAPTERUID
#define MATROSKA_ID_TAGTARGETS_CHAPTERUID
Definition: matroska.h:224
MatroskaTrackEncryption
Definition: matroskadec.c:153
ebml_read_length
static int ebml_read_length(MatroskaDemuxContext *matroska, AVIOContext *pb, uint64_t *number)
Read a EBML length value.
Definition: matroskadec.c:972
read
static uint32_t BS_FUNC() read(BSCTX *bc, unsigned int n)
Return n bits from the buffer, n has to be in the 0-32 range.
Definition: bitstream_template.h:231
MATROSKA_ID_TRACKTIMECODESCALE
#define MATROSKA_ID_TRACKTIMECODESCALE
Definition: matroska.h:111
matroska_chapter_entry
static EbmlSyntax matroska_chapter_entry[9]
Definition: matroskadec.c:446
MATROSKA_VIDEO_PROJECTION_TYPE_CUBEMAP
@ MATROSKA_VIDEO_PROJECTION_TYPE_CUBEMAP
Definition: matroska.h:356
matroska_aac_profile
static int matroska_aac_profile(char *codec_id)
Definition: matroskadec.c:2109
AV_CODEC_ID_MLP
@ AV_CODEC_ID_MLP
Definition: codec_id.h:477
is_keyframe
static int is_keyframe(NalUnitType naltype)
Definition: libx265.c:94
MatroskaTrack::time_scale
double time_scale
Definition: matroskadec.c:266
MatroskaTrack::language
char * language
Definition: matroskadec.c:265
ff_webm_dash_manifest_demuxer
const FFInputFormat ff_webm_dash_manifest_demuxer
AV_CODEC_ID_PRORES
@ AV_CODEC_ID_PRORES
Definition: codec_id.h:200
AV_RB16
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
Definition: bytestream.h:98
av_realloc
void * av_realloc(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory.
Definition: mem.c:155
CountedElement
Definition: matroskadec.c:102
av_fourcc2str
#define av_fourcc2str(fourcc)
Definition: avutil.h:348
av_index_search_timestamp
int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags)
Get the index for a specific timestamp.
Definition: seek.c:245
MatroskaMasteringMeta::r_y
double r_y
Definition: matroskadec.c:167
matroska_parse_flac
static int matroska_parse_flac(AVFormatContext *s, MatroskaTrack *track, int *offset)
Definition: matroskadec.c:2136
ff_alloc_extradata
int ff_alloc_extradata(AVCodecParameters *par, int size)
Allocate extradata with additional AV_INPUT_BUFFER_PADDING_SIZE at end which is always set to 0.
Definition: utils.c:230
avio_feof
int avio_feof(AVIOContext *s)
Similar to feof() but also returns nonzero on read errors.
Definition: aviobuf.c:346
MATROSKA_ID_BLOCKADDITIONS
#define MATROSKA_ID_BLOCKADDITIONS
Definition: matroska.h:239
MATROSKA_VIDEO_INTERLACE_FLAG_UNDETERMINED
@ MATROSKA_VIDEO_INTERLACE_FLAG_UNDETERMINED
Definition: matroska.h:298
MatroskaDemuxContext::done
int done
Definition: matroskadec.c:413