/src/ffmpeg/libavformat/avidec.c
Line | Count | Source |
1 | | /* |
2 | | * AVI demuxer |
3 | | * Copyright (c) 2001 Fabrice Bellard |
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 | | #include "config_components.h" |
23 | | |
24 | | #include <inttypes.h> |
25 | | |
26 | | #include "libavutil/avassert.h" |
27 | | #include "libavutil/avstring.h" |
28 | | #include "libavutil/mem.h" |
29 | | #include "libavutil/opt.h" |
30 | | #include "libavutil/dict.h" |
31 | | #include "libavutil/integer.h" |
32 | | #include "libavutil/internal.h" |
33 | | #include "libavutil/intreadwrite.h" |
34 | | #include "libavutil/mathematics.h" |
35 | | #include "avformat.h" |
36 | | #include "avi.h" |
37 | | #include "demux.h" |
38 | | #include "dv.h" |
39 | | #include "internal.h" |
40 | | #include "isom.h" |
41 | | #include "riff.h" |
42 | | #include "libavcodec/bytestream.h" |
43 | | #include "libavcodec/exif.h" |
44 | | #include "libavcodec/startcode.h" |
45 | | |
46 | | typedef struct AVIStream { |
47 | | int64_t frame_offset; /* current frame (video) or byte (audio) counter |
48 | | * (used to compute the pts) */ |
49 | | int remaining; |
50 | | int packet_size; |
51 | | |
52 | | uint32_t handler; |
53 | | uint32_t scale; |
54 | | uint32_t rate; |
55 | | int sample_size; /* size of one sample (or packet) |
56 | | * (in the rate/scale sense) in bytes */ |
57 | | |
58 | | int64_t cum_len; /* temporary storage (used during seek) */ |
59 | | int prefix; /* normally 'd'<<8 + 'c' or 'w'<<8 + 'b' */ |
60 | | int prefix_count; |
61 | | uint32_t pal[256]; |
62 | | int has_pal; |
63 | | int dshow_block_align; /* block align variable used to emulate bugs in |
64 | | * the MS dshow demuxer */ |
65 | | |
66 | | AVFormatContext *sub_ctx; |
67 | | AVPacket *sub_pkt; |
68 | | AVBufferRef *sub_buffer; |
69 | | |
70 | | int64_t seek_pos; |
71 | | } AVIStream; |
72 | | |
73 | | typedef struct AVIContext { |
74 | | const AVClass *class; |
75 | | int64_t riff_end; |
76 | | int64_t movi_end; |
77 | | int64_t fsize; |
78 | | int64_t io_fsize; |
79 | | int64_t movi_list; |
80 | | int64_t last_pkt_pos; |
81 | | int index_loaded; |
82 | | int is_odml; |
83 | | int non_interleaved; |
84 | | int stream_index; |
85 | | DVDemuxContext *dv_demux; |
86 | | int odml_depth; |
87 | | int64_t odml_read; |
88 | | int64_t odml_max_pos; |
89 | | int use_odml; |
90 | 3.18k | #define MAX_ODML_DEPTH 1000 |
91 | | int64_t dts_max; |
92 | | } AVIContext; |
93 | | |
94 | | |
95 | | static const AVOption options[] = { |
96 | | { "use_odml", "use odml index", offsetof(AVIContext, use_odml), AV_OPT_TYPE_BOOL, {.i64 = 1}, -1, 1, AV_OPT_FLAG_DECODING_PARAM}, |
97 | | { NULL }, |
98 | | }; |
99 | | |
100 | | static const AVClass demuxer_class = { |
101 | | .class_name = "avi", |
102 | | .item_name = av_default_item_name, |
103 | | .option = options, |
104 | | .version = LIBAVUTIL_VERSION_INT, |
105 | | .category = AV_CLASS_CATEGORY_DEMUXER, |
106 | | }; |
107 | | |
108 | | |
109 | | static const char avi_headers[][8] = { |
110 | | { 'R', 'I', 'F', 'F', 'A', 'V', 'I', ' ' }, |
111 | | { 'R', 'I', 'F', 'F', 'A', 'V', 'I', 'X' }, |
112 | | { 'R', 'I', 'F', 'F', 'A', 'V', 'I', 0x19 }, |
113 | | { 'O', 'N', '2', ' ', 'O', 'N', '2', 'f' }, |
114 | | { 'R', 'I', 'F', 'F', 'A', 'M', 'V', ' ' }, |
115 | | { 0 } |
116 | | }; |
117 | | |
118 | | static const AVMetadataConv avi_metadata_conv[] = { |
119 | | { "strn", "title" }, |
120 | | { "isbj", "subject" }, |
121 | | { "inam", "title" }, |
122 | | { "iart", "artist" }, |
123 | | { "icop", "copyright" }, |
124 | | { "icmt", "comment" }, |
125 | | { "ignr", "genre" }, |
126 | | { "iprd", "product" }, |
127 | | { "isft", "software" }, |
128 | | |
129 | | { 0 }, |
130 | | }; |
131 | | |
132 | | static int avi_load_index(AVFormatContext *s); |
133 | | static int guess_ni_flag(AVFormatContext *s); |
134 | | |
135 | | #define print_tag(s, str, tag, size) \ |
136 | 217k | av_log(s, AV_LOG_TRACE, "pos:%"PRIX64" %s: tag=%s size=0x%x\n", \ |
137 | 217k | avio_tell(pb), str, av_fourcc2str(tag), size) \ |
138 | | |
139 | | static inline int get_duration(AVIStream *ast, int len) |
140 | 2.98M | { |
141 | 2.98M | if (ast->sample_size) |
142 | 2.08M | return len; |
143 | 903k | else if (ast->dshow_block_align) |
144 | 5.13k | return (len + (int64_t)ast->dshow_block_align - 1) / ast->dshow_block_align; |
145 | 898k | else |
146 | 898k | return 1; |
147 | 2.98M | } |
148 | | |
149 | | static int get_riff(AVFormatContext *s, AVIOContext *pb) |
150 | 11.0k | { |
151 | 11.0k | AVIContext *avi = s->priv_data; |
152 | 11.0k | char header[8] = {0}; |
153 | 11.0k | int i; |
154 | | |
155 | | /* check RIFF header */ |
156 | 11.0k | avio_read(pb, header, 4); |
157 | 11.0k | avi->riff_end = avio_rl32(pb); /* RIFF chunk size */ |
158 | 11.0k | avi->riff_end += avio_tell(pb); /* RIFF chunk end */ |
159 | 11.0k | avio_read(pb, header + 4, 4); |
160 | | |
161 | 43.0k | for (i = 0; avi_headers[i][0]; i++) |
162 | 43.0k | if (!memcmp(header, avi_headers[i], 8)) |
163 | 11.0k | break; |
164 | 11.0k | if (!avi_headers[i][0]) |
165 | 46 | return AVERROR_INVALIDDATA; |
166 | | |
167 | 11.0k | if (header[7] == 0x19) |
168 | 1 | av_log(s, AV_LOG_INFO, |
169 | 1 | "This file has been generated by a totally broken muxer.\n"); |
170 | | |
171 | 11.0k | return 0; |
172 | 11.0k | } |
173 | | |
174 | | static int read_odml_index(AVFormatContext *s, int64_t frame_num) |
175 | 3.76k | { |
176 | 3.76k | AVIContext *avi = s->priv_data; |
177 | 3.76k | AVIOContext *pb = s->pb; |
178 | 3.76k | int longs_per_entry = avio_rl16(pb); |
179 | 3.76k | int index_sub_type = avio_r8(pb); |
180 | 3.76k | int index_type = avio_r8(pb); |
181 | 3.76k | int entries_in_use = avio_rl32(pb); |
182 | 3.76k | int chunk_id = avio_rl32(pb); |
183 | 3.76k | int64_t base = avio_rl64(pb); |
184 | 3.76k | int stream_id = ((chunk_id & 0xFF) - '0') * 10 + |
185 | 3.76k | ((chunk_id >> 8 & 0xFF) - '0'); |
186 | 3.76k | AVStream *st; |
187 | 3.76k | AVIStream *ast; |
188 | 3.76k | int i; |
189 | 3.76k | int64_t last_pos = -1; |
190 | 3.76k | int64_t filesize = avi->fsize; |
191 | | |
192 | 3.76k | av_log(s, AV_LOG_TRACE, |
193 | 3.76k | "longs_per_entry:%d index_type:%d entries_in_use:%d " |
194 | 3.76k | "chunk_id:%X base:%16"PRIX64" frame_num:%"PRId64"\n", |
195 | 3.76k | longs_per_entry, |
196 | 3.76k | index_type, |
197 | 3.76k | entries_in_use, |
198 | 3.76k | chunk_id, |
199 | 3.76k | base, |
200 | 3.76k | frame_num); |
201 | | |
202 | 3.76k | if (stream_id >= s->nb_streams || stream_id < 0) |
203 | 434 | return AVERROR_INVALIDDATA; |
204 | 3.32k | st = s->streams[stream_id]; |
205 | 3.32k | ast = st->priv_data; |
206 | | |
207 | 3.32k | if (index_sub_type || entries_in_use < 0) |
208 | 8 | return AVERROR_INVALIDDATA; |
209 | | |
210 | 3.31k | avio_rl32(pb); |
211 | | |
212 | 3.31k | if (index_type && longs_per_entry != 2) |
213 | 3 | return AVERROR_INVALIDDATA; |
214 | 3.31k | if (index_type > 1) |
215 | 0 | return AVERROR_INVALIDDATA; |
216 | | |
217 | 3.31k | if (filesize > 0 && base >= filesize) { |
218 | 33 | av_log(s, AV_LOG_ERROR, "ODML index invalid\n"); |
219 | 33 | if (base >> 32 == (base & 0xFFFFFFFF) && |
220 | 27 | (base & 0xFFFFFFFF) < filesize && |
221 | 25 | filesize <= 0xFFFFFFFF) |
222 | 3 | base &= 0xFFFFFFFF; |
223 | 30 | else |
224 | 30 | return AVERROR_INVALIDDATA; |
225 | 33 | } |
226 | | |
227 | 502k | for (i = 0; i < entries_in_use; i++) { |
228 | 502k | avi->odml_max_pos = FFMAX(avi->odml_max_pos, avio_tell(pb)); |
229 | | |
230 | | // If we read more than there are bytes then we must have been reading something twice |
231 | 502k | if (avi->odml_read > avi->odml_max_pos) |
232 | 0 | return AVERROR_INVALIDDATA; |
233 | | |
234 | 502k | if (index_type) { |
235 | 499k | int64_t pos = avio_rl32(pb) + base - 8; |
236 | 499k | int len = avio_rl32(pb); |
237 | 499k | int key = len >= 0; |
238 | 499k | len &= 0x7FFFFFFF; |
239 | 499k | avi->odml_read += 8; |
240 | | |
241 | 499k | av_log(s, AV_LOG_TRACE, "pos:%"PRId64", len:%X\n", pos, len); |
242 | | |
243 | 499k | if (avio_feof(pb)) |
244 | 78 | return AVERROR_INVALIDDATA; |
245 | | |
246 | 499k | if (last_pos == pos || pos == base - 8) |
247 | 105k | avi->non_interleaved = 1; |
248 | 499k | if (last_pos != pos && len) |
249 | 389k | av_add_index_entry(st, pos, ast->cum_len, len, 0, |
250 | 389k | key ? AVINDEX_KEYFRAME : 0); |
251 | | |
252 | 499k | ast->cum_len += get_duration(ast, len); |
253 | 499k | last_pos = pos; |
254 | 499k | } else { |
255 | 3.19k | int64_t offset, pos; |
256 | 3.19k | int duration; |
257 | 3.19k | int ret; |
258 | 3.19k | avi->odml_read += 16; |
259 | | |
260 | 3.19k | offset = avio_rl64(pb); |
261 | 3.19k | avio_rl32(pb); /* size */ |
262 | 3.19k | duration = avio_rl32(pb); |
263 | | |
264 | 3.19k | if (avio_feof(pb) || offset > INT64_MAX - 8) |
265 | 6 | return AVERROR_INVALIDDATA; |
266 | | |
267 | 3.18k | pos = avio_tell(pb); |
268 | | |
269 | 3.18k | if (avi->odml_depth > MAX_ODML_DEPTH) { |
270 | 3 | av_log(s, AV_LOG_ERROR, "Too deeply nested ODML indexes\n"); |
271 | 3 | return AVERROR_INVALIDDATA; |
272 | 3 | } |
273 | | |
274 | 3.18k | if (avio_seek(pb, offset + 8, SEEK_SET) < 0) |
275 | 39 | return -1; |
276 | 3.14k | avi->odml_depth++; |
277 | 3.14k | ret = read_odml_index(s, frame_num); |
278 | 3.14k | avi->odml_depth--; |
279 | 3.14k | frame_num += duration; |
280 | | |
281 | 3.14k | if (avio_seek(pb, pos, SEEK_SET) < 0) { |
282 | 7 | av_log(s, AV_LOG_ERROR, "Failed to restore position after reading index\n"); |
283 | 7 | return -1; |
284 | 7 | } |
285 | 3.13k | if (ret < 0) |
286 | 3.12k | return ret; |
287 | 3.13k | } |
288 | 502k | } |
289 | 33 | avi->index_loaded = 2; |
290 | 33 | return 0; |
291 | 3.28k | } |
292 | | |
293 | | static void clean_index(AVFormatContext *s) |
294 | 576 | { |
295 | 576 | int i; |
296 | 576 | int64_t j; |
297 | | |
298 | 1.60k | for (i = 0; i < s->nb_streams; i++) { |
299 | 1.03k | AVStream *st = s->streams[i]; |
300 | 1.03k | FFStream *const sti = ffstream(st); |
301 | 1.03k | AVIStream *ast = st->priv_data; |
302 | 1.03k | int n = sti->nb_index_entries; |
303 | 1.03k | int max = ast->sample_size; |
304 | 1.03k | int64_t pos, size, ts; |
305 | | |
306 | 1.03k | if (n != 1 || ast->sample_size == 0) |
307 | 832 | continue; |
308 | | |
309 | 517 | while (max < 1024) |
310 | 319 | max += max; |
311 | | |
312 | 198 | pos = sti->index_entries[0].pos; |
313 | 198 | size = sti->index_entries[0].size; |
314 | 198 | ts = sti->index_entries[0].timestamp; |
315 | | |
316 | 5.39M | for (j = 0; j < size; j += max) |
317 | 5.39M | av_add_index_entry(st, pos + j, ts + j, FFMIN(max, size - j), 0, |
318 | 5.39M | AVINDEX_KEYFRAME); |
319 | 198 | } |
320 | 576 | } |
321 | | |
322 | | static int avi_read_tag(AVFormatContext *s, AVStream *st, uint32_t tag, |
323 | | uint32_t size) |
324 | 51 | { |
325 | 51 | AVIOContext *pb = s->pb; |
326 | 51 | char key[5] = { 0 }; |
327 | 51 | char *value; |
328 | | |
329 | 51 | size += (size & 1); |
330 | | |
331 | 51 | if (size == UINT_MAX) |
332 | 0 | return AVERROR(EINVAL); |
333 | 51 | value = av_malloc(size + 1); |
334 | 51 | if (!value) |
335 | 0 | return AVERROR(ENOMEM); |
336 | 51 | if (avio_read(pb, value, size) != size) { |
337 | 1 | av_freep(&value); |
338 | 1 | return AVERROR_INVALIDDATA; |
339 | 1 | } |
340 | 50 | value[size] = 0; |
341 | | |
342 | 50 | AV_WL32(key, tag); |
343 | | |
344 | 50 | return av_dict_set(st ? &st->metadata : &s->metadata, key, value, |
345 | 50 | AV_DICT_DONT_STRDUP_VAL); |
346 | 51 | } |
347 | | |
348 | | static const char months[12][4] = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", |
349 | | "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" }; |
350 | | |
351 | | static void avi_metadata_creation_time(AVDictionary **metadata, char *date) |
352 | 39 | { |
353 | 39 | char month[4], time[9], buffer[64]; |
354 | 39 | int i, day, year; |
355 | | /* parse standard AVI date format (ie. "Mon Mar 10 15:04:43 2003") */ |
356 | 39 | if (sscanf(date, "%*3s%*[ ]%3s%*[ ]%2d%*[ ]%8s%*[ ]%4d", |
357 | 39 | month, &day, time, &year) == 4) { |
358 | 26 | for (i = 0; i < 12; i++) |
359 | 24 | if (!av_strcasecmp(month, months[i])) { |
360 | 2 | snprintf(buffer, sizeof(buffer), "%.4d-%.2d-%.2d %s", |
361 | 2 | year, i + 1, day, time); |
362 | 2 | av_dict_set(metadata, "creation_time", buffer, 0); |
363 | 2 | } |
364 | 37 | } else if (date[4] == '/' && date[7] == '/') { |
365 | 1 | date[4] = date[7] = '-'; |
366 | 1 | av_dict_set(metadata, "creation_time", date, 0); |
367 | 1 | } |
368 | 39 | } |
369 | | |
370 | | static void avi_read_nikon(AVFormatContext *s, uint64_t end) |
371 | 57 | { |
372 | 1.39k | while (avio_tell(s->pb) < end && !avio_feof(s->pb)) { |
373 | 1.33k | uint32_t tag = avio_rl32(s->pb); |
374 | 1.33k | uint32_t size = avio_rl32(s->pb); |
375 | 1.33k | switch (tag) { |
376 | 46 | case MKTAG('n', 'c', 't', 'g'): /* Nikon Tags */ |
377 | 46 | { |
378 | 46 | uint64_t tag_end = avio_tell(s->pb) + size; |
379 | 1.33k | while (avio_tell(s->pb) < tag_end && !avio_feof(s->pb)) { |
380 | 1.29k | uint16_t tag = avio_rl16(s->pb); |
381 | 1.29k | uint16_t size = avio_rl16(s->pb); |
382 | 1.29k | const char *name = NULL; |
383 | 1.29k | char buffer[64] = { 0 }; |
384 | 1.29k | uint64_t remaining = tag_end - avio_tell(s->pb); |
385 | 1.29k | size = FFMIN(size, remaining); |
386 | 1.29k | size -= avio_read(s->pb, buffer, |
387 | 1.29k | FFMIN(size, sizeof(buffer) - 1)); |
388 | 1.29k | switch (tag) { |
389 | 27 | case 0x03: |
390 | 27 | name = "maker"; |
391 | 27 | break; |
392 | 27 | case 0x04: |
393 | 27 | name = "model"; |
394 | 27 | break; |
395 | 15 | case 0x13: |
396 | 15 | name = "creation_time"; |
397 | 15 | if (buffer[4] == ':' && buffer[7] == ':') |
398 | 0 | buffer[4] = buffer[7] = '-'; |
399 | 15 | break; |
400 | 1.29k | } |
401 | 1.29k | if (name) |
402 | 69 | av_dict_set(&s->metadata, name, buffer, 0); |
403 | 1.29k | avio_skip(s->pb, size); |
404 | 1.29k | } |
405 | 46 | break; |
406 | 46 | } |
407 | 1.29k | default: |
408 | 1.29k | avio_skip(s->pb, size); |
409 | 1.29k | break; |
410 | 1.33k | } |
411 | 1.33k | } |
412 | 57 | } |
413 | | |
414 | | static int avi_extract_stream_metadata(AVFormatContext *s, AVStream *st) |
415 | 5.59k | { |
416 | 5.59k | GetByteContext gb; |
417 | 5.59k | uint8_t *data = st->codecpar->extradata; |
418 | 5.59k | int data_size = st->codecpar->extradata_size; |
419 | 5.59k | int tag, offset; |
420 | | |
421 | 5.59k | if (!data || data_size < 8) { |
422 | 20 | return AVERROR_INVALIDDATA; |
423 | 20 | } |
424 | | |
425 | 5.57k | bytestream2_init(&gb, data, data_size); |
426 | | |
427 | 5.57k | tag = bytestream2_get_le32(&gb); |
428 | | |
429 | 5.57k | switch (tag) { |
430 | 5.22k | case MKTAG('A', 'V', 'I', 'F'): { |
431 | 5.22k | AVExifMetadata ifd = { 0 }; |
432 | 5.22k | int ret; |
433 | | // skip 4 byte padding |
434 | 5.22k | bytestream2_skip(&gb, 4); |
435 | 5.22k | offset = bytestream2_tell(&gb); |
436 | | |
437 | | // decode EXIF tags from IFD, AVI is always little-endian |
438 | 5.22k | ret = av_exif_parse_buffer(s, data + offset, data_size - offset, &ifd, AV_EXIF_ASSUME_LE); |
439 | 5.22k | if (ret < 0) |
440 | 5.05k | return ret; |
441 | 170 | ret = av_exif_ifd_to_dict(s, &ifd, &st->metadata); |
442 | 170 | av_exif_free(&ifd); |
443 | 170 | return ret; |
444 | 5.22k | } |
445 | 2 | case MKTAG('C', 'A', 'S', 'I'): |
446 | 2 | avpriv_request_sample(s, "RIFF stream data tag type CASI (%u)", tag); |
447 | 2 | break; |
448 | 2 | case MKTAG('Z', 'o', 'r', 'a'): |
449 | 2 | avpriv_request_sample(s, "RIFF stream data tag type Zora (%u)", tag); |
450 | 2 | break; |
451 | 354 | default: |
452 | 354 | break; |
453 | 5.57k | } |
454 | | |
455 | 358 | return 0; |
456 | 5.57k | } |
457 | | |
458 | | static int calculate_bitrate(AVFormatContext *s) |
459 | 10.4k | { |
460 | 10.4k | AVIContext *avi = s->priv_data; |
461 | 10.4k | int i, j; |
462 | 10.4k | int64_t lensum = 0; |
463 | 10.4k | int64_t maxpos = 0; |
464 | | |
465 | 30.1k | for (i = 0; i<s->nb_streams; i++) { |
466 | 19.6k | int64_t len = 0; |
467 | 19.6k | FFStream *const sti = ffstream(s->streams[i]); |
468 | | |
469 | 19.6k | if (!sti->nb_index_entries) |
470 | 18.5k | continue; |
471 | | |
472 | 242k | for (j = 0; j < sti->nb_index_entries; j++) |
473 | 241k | len += sti->index_entries[j].size; |
474 | 1.06k | maxpos = FFMAX(maxpos, sti->index_entries[j-1].pos); |
475 | 1.06k | lensum += len; |
476 | 1.06k | } |
477 | 10.4k | if (maxpos < av_rescale(avi->io_fsize, 9, 10)) // index does not cover the whole file |
478 | 2.57k | return 0; |
479 | 7.92k | if (lensum*9/10 > maxpos || lensum < maxpos*9/10) // frame sum and filesize mismatch |
480 | 45 | return 0; |
481 | | |
482 | 22.1k | for (i = 0; i<s->nb_streams; i++) { |
483 | 14.3k | int64_t len = 0; |
484 | 14.3k | AVStream *st = s->streams[i]; |
485 | 14.3k | FFStream *const sti = ffstream(st); |
486 | 14.3k | int64_t duration; |
487 | 14.3k | AVInteger bitrate_i, den_i, num_i; |
488 | | |
489 | 20.9k | for (j = 0; j < sti->nb_index_entries; j++) |
490 | 6.68k | len += sti->index_entries[j].size; |
491 | | |
492 | 14.3k | if (sti->nb_index_entries < 2 || st->codecpar->bit_rate > 0) |
493 | 14.2k | continue; |
494 | 55 | duration = sti->index_entries[j-1].timestamp - sti->index_entries[0].timestamp; |
495 | 55 | den_i = av_mul_i(av_int2i(duration), av_int2i(st->time_base.num)); |
496 | 55 | num_i = av_add_i(av_mul_i(av_int2i(8*len), av_int2i(st->time_base.den)), av_shr_i(den_i, 1)); |
497 | 55 | bitrate_i = av_div_i(num_i, den_i); |
498 | 55 | if (av_cmp_i(bitrate_i, av_int2i(INT64_MAX)) <= 0) { |
499 | 55 | int64_t bitrate = av_i2int(bitrate_i); |
500 | 55 | if (bitrate > 0) { |
501 | 53 | st->codecpar->bit_rate = bitrate; |
502 | 53 | } |
503 | 55 | } |
504 | 55 | } |
505 | 7.87k | return 1; |
506 | 7.92k | } |
507 | | |
508 | | static int avi_read_header(AVFormatContext *s) |
509 | 11.0k | { |
510 | 11.0k | AVIContext *avi = s->priv_data; |
511 | 11.0k | AVIOContext *pb = s->pb; |
512 | 11.0k | unsigned int tag, tag1, handler; |
513 | 11.0k | int codec_type, stream_index, frame_period; |
514 | 11.0k | unsigned int size; |
515 | 11.0k | int i; |
516 | 11.0k | AVStream *st; |
517 | 11.0k | AVIStream *ast = NULL; |
518 | 11.0k | int avih_width = 0, avih_height = 0; |
519 | 11.0k | int amv_file_format = 0; |
520 | 11.0k | uint64_t list_end = 0; |
521 | 11.0k | int64_t pos; |
522 | 11.0k | int ret; |
523 | 11.0k | AVDictionaryEntry *dict_entry; |
524 | | |
525 | 11.0k | avi->stream_index = -1; |
526 | | |
527 | 11.0k | ret = get_riff(s, pb); |
528 | 11.0k | if (ret < 0) |
529 | 46 | return ret; |
530 | | |
531 | 11.0k | av_log(avi, AV_LOG_DEBUG, "use odml:%d\n", avi->use_odml); |
532 | | |
533 | 11.0k | avi->io_fsize = avi->fsize = avio_size(pb); |
534 | 11.0k | if (avi->fsize <= 0 || avi->fsize < avi->riff_end) |
535 | 9.48k | avi->fsize = avi->riff_end == 8 ? INT64_MAX : avi->riff_end; |
536 | | |
537 | | /* first list tag */ |
538 | 11.0k | stream_index = -1; |
539 | 11.0k | codec_type = -1; |
540 | 11.0k | frame_period = 0; |
541 | 182k | for (;;) { |
542 | 182k | if (avio_feof(pb)) |
543 | 462 | return AVERROR_INVALIDDATA; |
544 | 182k | tag = avio_rl32(pb); |
545 | 182k | size = avio_rl32(pb); |
546 | | |
547 | 182k | print_tag(s, "tag", tag, size); |
548 | | |
549 | 182k | switch (tag) { |
550 | 7.65k | case MKTAG('L', 'I', 'S', 'T'): |
551 | 7.65k | list_end = avio_tell(pb) + size; |
552 | | /* Ignored, except at start of video packets. */ |
553 | 7.65k | tag1 = avio_rl32(pb); |
554 | | |
555 | 7.65k | print_tag(s, "list", tag1, 0); |
556 | | |
557 | 7.65k | if (tag1 == MKTAG('m', 'o', 'v', 'i')) { |
558 | 265 | avi->movi_list = avio_tell(pb) - 4; |
559 | 265 | if (size) |
560 | 256 | avi->movi_end = avi->movi_list + size + (size & 1); |
561 | 9 | else |
562 | 9 | avi->movi_end = avi->fsize; |
563 | 265 | av_log(s, AV_LOG_TRACE, "movi end=%"PRIx64"\n", avi->movi_end); |
564 | 265 | goto end_of_header; |
565 | 7.39k | } else if (tag1 == MKTAG('I', 'N', 'F', 'O')) |
566 | 218 | ff_read_riff_info(s, size - 4); |
567 | 7.17k | else if (tag1 == MKTAG('n', 'c', 'd', 't')) |
568 | 57 | avi_read_nikon(s, list_end); |
569 | | |
570 | 7.39k | break; |
571 | 7.39k | case MKTAG('I', 'D', 'I', 'T'): |
572 | 39 | { |
573 | 39 | unsigned char date[64] = { 0 }; |
574 | 39 | size += (size & 1); |
575 | 39 | size -= avio_read(pb, date, FFMIN(size, sizeof(date) - 1)); |
576 | 39 | avio_skip(pb, size); |
577 | 39 | avi_metadata_creation_time(&s->metadata, date); |
578 | 39 | break; |
579 | 7.65k | } |
580 | 101 | case MKTAG('d', 'm', 'l', 'h'): |
581 | 101 | avi->is_odml = 1; |
582 | 101 | avio_skip(pb, size + (size & 1)); |
583 | 101 | break; |
584 | 23 | case MKTAG('a', 'm', 'v', 'h'): |
585 | 23 | amv_file_format = 1; |
586 | 429 | case MKTAG('a', 'v', 'i', 'h'): |
587 | | /* AVI header */ |
588 | | /* using frame_period is bad idea */ |
589 | 429 | frame_period = avio_rl32(pb); |
590 | 429 | avio_rl32(pb); /* max. bytes per second */ |
591 | 429 | avio_rl32(pb); |
592 | 429 | avi->non_interleaved |= avio_rl32(pb) & AVIF_MUSTUSEINDEX; |
593 | | |
594 | 429 | avio_skip(pb, 2 * 4); |
595 | 429 | avio_rl32(pb); |
596 | 429 | avio_rl32(pb); |
597 | 429 | avih_width = avio_rl32(pb); |
598 | 429 | avih_height = avio_rl32(pb); |
599 | | |
600 | 429 | avio_skip(pb, size - 10 * 4); |
601 | 429 | break; |
602 | 22.0k | case MKTAG('s', 't', 'r', 'h'): |
603 | | /* stream header */ |
604 | | |
605 | 22.0k | tag1 = avio_rl32(pb); |
606 | 22.0k | handler = avio_rl32(pb); /* codec tag */ |
607 | | |
608 | 22.0k | if (tag1 == MKTAG('p', 'a', 'd', 's')) { |
609 | 1 | avio_skip(pb, size - 8); |
610 | 1 | break; |
611 | 22.0k | } else { |
612 | 22.0k | stream_index++; |
613 | 22.0k | st = avformat_new_stream(s, NULL); |
614 | 22.0k | if (!st) |
615 | 0 | return AVERROR(ENOMEM); |
616 | | |
617 | 22.0k | st->id = stream_index; |
618 | 22.0k | ast = av_mallocz(sizeof(AVIStream)); |
619 | 22.0k | if (!ast) |
620 | 0 | return AVERROR(ENOMEM); |
621 | 22.0k | st->priv_data = ast; |
622 | 22.0k | } |
623 | 22.0k | if (amv_file_format) |
624 | 40 | tag1 = stream_index ? MKTAG('a', 'u', 'd', 's') |
625 | 40 | : MKTAG('v', 'i', 'd', 's'); |
626 | | |
627 | 22.0k | print_tag(s, "strh", tag1, -1); |
628 | | |
629 | 22.0k | if (tag1 == MKTAG('i', 'a', 'v', 's') || |
630 | 22.0k | tag1 == MKTAG('i', 'v', 'a', 's')) { |
631 | 430 | int64_t dv_dur; |
632 | | |
633 | | /* After some consideration -- I don't think we |
634 | | * have to support anything but DV in type1 AVIs. */ |
635 | 430 | if (s->nb_streams != 1) |
636 | 0 | return AVERROR_INVALIDDATA; |
637 | | |
638 | 430 | if (handler != MKTAG('d', 'v', 's', 'd') && |
639 | 427 | handler != MKTAG('d', 'v', 'h', 'd') && |
640 | 427 | handler != MKTAG('d', 'v', 's', 'l')) |
641 | 2 | return AVERROR_INVALIDDATA; |
642 | | |
643 | 428 | if (!CONFIG_DV_DEMUXER) |
644 | 0 | return AVERROR_DEMUXER_NOT_FOUND; |
645 | | |
646 | 428 | ast = s->streams[0]->priv_data; |
647 | 428 | st->priv_data = NULL; |
648 | 428 | ff_remove_stream(s, st); |
649 | | |
650 | 428 | avi->dv_demux = avpriv_dv_init_demux(s); |
651 | 428 | if (!avi->dv_demux) { |
652 | 0 | av_free(ast); |
653 | 0 | return AVERROR(ENOMEM); |
654 | 0 | } |
655 | | |
656 | 428 | s->streams[0]->priv_data = ast; |
657 | 428 | avio_skip(pb, 3 * 4); |
658 | 428 | ast->scale = avio_rl32(pb); |
659 | 428 | ast->rate = avio_rl32(pb); |
660 | 428 | avio_skip(pb, 4); /* start time */ |
661 | | |
662 | 428 | dv_dur = avio_rl32(pb); |
663 | 428 | if (ast->scale > 0 && ast->rate > 0 && dv_dur > 0) { |
664 | 281 | dv_dur *= AV_TIME_BASE; |
665 | 281 | s->duration = av_rescale(dv_dur, ast->scale, ast->rate); |
666 | 281 | } |
667 | | /* else, leave duration alone; timing estimation in utils.c |
668 | | * will make a guess based on bitrate. */ |
669 | | |
670 | 428 | stream_index = s->nb_streams - 1; |
671 | 428 | avio_skip(pb, size - 9 * 4); |
672 | 428 | break; |
673 | 428 | } |
674 | | |
675 | 21.6k | av_assert0(stream_index < s->nb_streams); |
676 | 21.6k | ast->handler = handler; |
677 | | |
678 | 21.6k | avio_rl32(pb); /* flags */ |
679 | 21.6k | avio_rl16(pb); /* priority */ |
680 | 21.6k | avio_rl16(pb); /* language */ |
681 | 21.6k | avio_rl32(pb); /* initial frame */ |
682 | 21.6k | ast->scale = avio_rl32(pb); |
683 | 21.6k | ast->rate = avio_rl32(pb); |
684 | 21.6k | if (!(ast->scale && ast->rate)) { |
685 | 1.89k | av_log(s, AV_LOG_WARNING, |
686 | 1.89k | "scale/rate is %"PRIu32"/%"PRIu32" which is invalid. " |
687 | 1.89k | "(This file has been generated by broken software.)\n", |
688 | 1.89k | ast->scale, |
689 | 1.89k | ast->rate); |
690 | 1.89k | if (frame_period) { |
691 | 47 | ast->rate = 1000000; |
692 | 47 | ast->scale = frame_period; |
693 | 1.84k | } else { |
694 | 1.84k | ast->rate = 25; |
695 | 1.84k | ast->scale = 1; |
696 | 1.84k | } |
697 | 1.89k | } |
698 | 21.6k | avpriv_set_pts_info(st, 64, ast->scale, ast->rate); |
699 | | |
700 | 21.6k | ast->cum_len = avio_rl32(pb); /* start */ |
701 | 21.6k | st->nb_frames = avio_rl32(pb); |
702 | | |
703 | 21.6k | st->start_time = 0; |
704 | 21.6k | avio_rl32(pb); /* buffer size */ |
705 | 21.6k | avio_rl32(pb); /* quality */ |
706 | 21.6k | if (ast->cum_len > 3600LL * ast->rate / ast->scale) { |
707 | 15.7k | av_log(s, AV_LOG_ERROR, "crazy start time, iam scared, giving up\n"); |
708 | 15.7k | ast->cum_len = 0; |
709 | 15.7k | } |
710 | 21.6k | ast->sample_size = avio_rl32(pb); |
711 | 21.6k | ast->cum_len *= FFMAX(1, ast->sample_size); |
712 | 21.6k | av_log(s, AV_LOG_TRACE, "%"PRIu32" %"PRIu32" %d\n", |
713 | 21.6k | ast->rate, ast->scale, ast->sample_size); |
714 | | |
715 | 21.6k | switch (tag1) { |
716 | 5.25k | case MKTAG('v', 'i', 'd', 's'): |
717 | 5.25k | codec_type = AVMEDIA_TYPE_VIDEO; |
718 | | |
719 | 5.25k | ast->sample_size = 0; |
720 | 5.25k | st->avg_frame_rate = av_inv_q(st->time_base); |
721 | 5.25k | break; |
722 | 2.46k | case MKTAG('a', 'u', 'd', 's'): |
723 | 2.46k | codec_type = AVMEDIA_TYPE_AUDIO; |
724 | 2.46k | break; |
725 | 5.04k | case MKTAG('t', 'x', 't', 's'): |
726 | 5.04k | codec_type = AVMEDIA_TYPE_SUBTITLE; |
727 | 5.04k | break; |
728 | 0 | case MKTAG('d', 'a', 't', 's'): |
729 | 0 | codec_type = AVMEDIA_TYPE_DATA; |
730 | 0 | break; |
731 | 8.87k | default: |
732 | 8.87k | av_log(s, AV_LOG_INFO, "unknown stream type %X\n", tag1); |
733 | 21.6k | } |
734 | | |
735 | 21.6k | if (ast->sample_size < 0) { |
736 | 1.45k | if (s->error_recognition & AV_EF_EXPLODE) { |
737 | 0 | av_log(s, AV_LOG_ERROR, |
738 | 0 | "Invalid sample_size %d at stream %d\n", |
739 | 0 | ast->sample_size, |
740 | 0 | stream_index); |
741 | 0 | return AVERROR_INVALIDDATA; |
742 | 0 | } |
743 | 1.45k | av_log(s, AV_LOG_WARNING, |
744 | 1.45k | "Invalid sample_size %d at stream %d " |
745 | 1.45k | "setting it to 0\n", |
746 | 1.45k | ast->sample_size, |
747 | 1.45k | stream_index); |
748 | 1.45k | ast->sample_size = 0; |
749 | 1.45k | } |
750 | | |
751 | 21.6k | if (ast->sample_size == 0) { |
752 | 7.18k | st->duration = st->nb_frames; |
753 | 7.18k | if (st->duration > 0 && avi->io_fsize > 0 && avi->riff_end > avi->io_fsize) { |
754 | 592 | av_log(s, AV_LOG_DEBUG, "File is truncated adjusting duration\n"); |
755 | 592 | st->duration = av_rescale(st->duration, avi->io_fsize, avi->riff_end); |
756 | 592 | } |
757 | 7.18k | } |
758 | 21.6k | ast->frame_offset = ast->cum_len; |
759 | 21.6k | avio_skip(pb, size - 12 * 4); |
760 | 21.6k | break; |
761 | 11.8k | case MKTAG('s', 't', 'r', 'f'): |
762 | | /* stream header */ |
763 | 11.8k | if (!size && (codec_type == AVMEDIA_TYPE_AUDIO || |
764 | 2.08k | codec_type == AVMEDIA_TYPE_VIDEO)) |
765 | 7 | break; |
766 | 11.7k | if (stream_index >= (unsigned)s->nb_streams || avi->dv_demux) { |
767 | 38 | avio_skip(pb, size); |
768 | 11.7k | } else { |
769 | 11.7k | uint64_t cur_pos = avio_tell(pb); |
770 | 11.7k | FFStream *sti; |
771 | 11.7k | unsigned esize; |
772 | 11.7k | if (cur_pos < list_end) |
773 | 505 | size = FFMIN(size, list_end - cur_pos); |
774 | 11.7k | st = s->streams[stream_index]; |
775 | 11.7k | sti = ffstream(st); |
776 | 11.7k | if (st->codecpar->codec_type != AVMEDIA_TYPE_UNKNOWN) { |
777 | 22 | avio_skip(pb, size); |
778 | 22 | break; |
779 | 22 | } |
780 | 11.7k | switch (codec_type) { |
781 | 5.35k | case AVMEDIA_TYPE_VIDEO: |
782 | 5.35k | if (amv_file_format) { |
783 | 19 | st->codecpar->width = avih_width; |
784 | 19 | st->codecpar->height = avih_height; |
785 | 19 | st->codecpar->codec_type = AVMEDIA_TYPE_VIDEO; |
786 | 19 | st->codecpar->codec_id = AV_CODEC_ID_AMV; |
787 | 19 | avio_skip(pb, size); |
788 | 19 | break; |
789 | 19 | } |
790 | 5.33k | tag1 = ff_get_bmp_header(pb, st, &esize); |
791 | | |
792 | 5.33k | if (tag1 == MKTAG('D', 'X', 'S', 'B') || |
793 | 5.33k | tag1 == MKTAG('D', 'X', 'S', 'A')) { |
794 | 42 | st->codecpar->codec_type = AVMEDIA_TYPE_SUBTITLE; |
795 | 42 | st->codecpar->codec_tag = tag1; |
796 | 42 | st->codecpar->codec_id = AV_CODEC_ID_XSUB; |
797 | 42 | break; |
798 | 42 | } |
799 | | |
800 | 5.29k | if (size > 10 * 4 && size < (1 << 30) && size < avi->fsize) { |
801 | 2.18k | if (esize == size-1 && (esize&1)) { |
802 | 0 | st->codecpar->extradata_size = esize - 10 * 4; |
803 | 0 | } else |
804 | 2.18k | st->codecpar->extradata_size = size - 10 * 4; |
805 | 2.18k | if (st->codecpar->extradata) { |
806 | 0 | av_log(s, AV_LOG_WARNING, "New extradata in strf chunk, freeing previous one.\n"); |
807 | 0 | } |
808 | 2.18k | ret = ff_get_extradata(s, st->codecpar, pb, |
809 | 2.18k | st->codecpar->extradata_size); |
810 | 2.18k | if (ret < 0) |
811 | 22 | return ret; |
812 | 2.18k | } |
813 | | |
814 | | // FIXME: check if the encoder really did this correctly |
815 | 5.26k | if (st->codecpar->extradata_size & 1) |
816 | 1.58k | avio_r8(pb); |
817 | | |
818 | | /* Extract palette from extradata if bpp <= 8. |
819 | | * This code assumes that extradata contains only palette. |
820 | | * This is true for all paletted codecs implemented in |
821 | | * FFmpeg. */ |
822 | 5.26k | if (st->codecpar->extradata_size && |
823 | 2.16k | (st->codecpar->bits_per_coded_sample <= 8)) { |
824 | 1.61k | int pal_size = (1 << st->codecpar->bits_per_coded_sample) << 2; |
825 | 1.61k | const uint8_t *pal_src; |
826 | | |
827 | 1.61k | pal_size = FFMIN(pal_size, st->codecpar->extradata_size); |
828 | 1.61k | pal_src = st->codecpar->extradata + |
829 | 1.61k | st->codecpar->extradata_size - pal_size; |
830 | | /* Exclude the "BottomUp" field from the palette */ |
831 | 1.61k | if (pal_src - st->codecpar->extradata >= 9 && |
832 | 1.55k | !memcmp(st->codecpar->extradata + st->codecpar->extradata_size - 9, "BottomUp", 9)) |
833 | 0 | pal_src -= 9; |
834 | 5.01k | for (i = 0; i < pal_size / 4; i++) |
835 | 3.39k | ast->pal[i] = 0xFFU<<24 | AV_RL32(pal_src + 4 * i); |
836 | 1.61k | ast->has_pal = 1; |
837 | 1.61k | } |
838 | | |
839 | 5.26k | print_tag(s, "video", tag1, 0); |
840 | | |
841 | 5.26k | st->codecpar->codec_type = AVMEDIA_TYPE_VIDEO; |
842 | 5.26k | st->codecpar->codec_tag = tag1; |
843 | 5.26k | st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, |
844 | 5.26k | tag1); |
845 | | /* If codec is not found yet, try with the mov tags. */ |
846 | 5.26k | if (!st->codecpar->codec_id) { |
847 | 1.05k | st->codecpar->codec_id = |
848 | 1.05k | ff_codec_get_id(ff_codec_movvideo_tags, tag1); |
849 | 1.05k | if (st->codecpar->codec_id) |
850 | 11 | av_log(s, AV_LOG_WARNING, |
851 | 11 | "mov tag found in avi (fourcc %s)\n", |
852 | 11 | av_fourcc2str(tag1)); |
853 | 1.05k | } |
854 | 5.26k | if (!st->codecpar->codec_id) |
855 | 1.03k | st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags_unofficial, tag1); |
856 | | |
857 | | /* This is needed to get the pict type which is necessary |
858 | | * for generating correct pts. */ |
859 | 5.26k | sti->need_parsing = AVSTREAM_PARSE_HEADERS; |
860 | | |
861 | 5.26k | if (st->codecpar->codec_id == AV_CODEC_ID_MPEG4 && |
862 | 101 | ast->handler == MKTAG('X', 'V', 'I', 'D')) |
863 | 20 | st->codecpar->codec_tag = MKTAG('X', 'V', 'I', 'D'); |
864 | | |
865 | 5.26k | if (st->codecpar->codec_tag == MKTAG('V', 'S', 'S', 'H')) |
866 | 1.47k | sti->need_parsing = AVSTREAM_PARSE_FULL; |
867 | 5.26k | if (st->codecpar->codec_id == AV_CODEC_ID_RV40) |
868 | 0 | sti->need_parsing = AVSTREAM_PARSE_NONE; |
869 | 5.26k | if (st->codecpar->codec_id == AV_CODEC_ID_HEVC && |
870 | 721 | st->codecpar->codec_tag == MKTAG('H', '2', '6', '5')) |
871 | 90 | sti->need_parsing = AVSTREAM_PARSE_FULL; |
872 | | |
873 | 5.26k | if (st->codecpar->codec_id == AV_CODEC_ID_AVRN && |
874 | 1 | st->codecpar->codec_tag == MKTAG('A', 'V', 'R', 'n') && |
875 | 1 | (st->codecpar->extradata_size < 31 || |
876 | 1 | memcmp(&st->codecpar->extradata[28], "1:1", 3))) |
877 | 0 | st->codecpar->codec_id = AV_CODEC_ID_MJPEG; |
878 | | |
879 | 5.26k | if (st->codecpar->codec_tag == 0 && st->codecpar->height > 0 && |
880 | 154 | st->codecpar->extradata_size < 1U << 30) { |
881 | 154 | st->codecpar->extradata_size += 9; |
882 | 154 | if ((ret = av_reallocp(&st->codecpar->extradata, |
883 | 154 | st->codecpar->extradata_size + |
884 | 154 | AV_INPUT_BUFFER_PADDING_SIZE)) < 0) { |
885 | 0 | st->codecpar->extradata_size = 0; |
886 | 0 | return ret; |
887 | 0 | } else |
888 | 154 | memcpy(st->codecpar->extradata + st->codecpar->extradata_size - 9, |
889 | 154 | "BottomUp", 9); |
890 | 154 | } |
891 | 5.26k | if (st->codecpar->height == INT_MIN) |
892 | 1 | return AVERROR_INVALIDDATA; |
893 | 5.26k | st->codecpar->height = FFABS(st->codecpar->height); |
894 | | |
895 | | // avio_skip(pb, size - 5 * 4); |
896 | 5.26k | break; |
897 | 1.56k | case AVMEDIA_TYPE_AUDIO: |
898 | 1.56k | ret = ff_get_wav_header(s, pb, st->codecpar, size, 0); |
899 | 1.56k | if (ret < 0) |
900 | 5 | return ret; |
901 | 1.55k | ast->dshow_block_align = st->codecpar->block_align; |
902 | 1.55k | if (ast->sample_size && st->codecpar->block_align && |
903 | 1.18k | ast->sample_size != st->codecpar->block_align) { |
904 | 1.04k | av_log(s, |
905 | 1.04k | AV_LOG_WARNING, |
906 | 1.04k | "sample size (%d) != block align (%d)\n", |
907 | 1.04k | ast->sample_size, |
908 | 1.04k | st->codecpar->block_align); |
909 | 1.04k | ast->sample_size = st->codecpar->block_align; |
910 | 1.04k | } |
911 | | /* 2-aligned |
912 | | * (fix for Stargate SG-1 - 3x18 - Shades of Grey.avi) */ |
913 | 1.55k | if (size & 1) |
914 | 504 | avio_skip(pb, 1); |
915 | | /* Force parsing as several audio frames can be in |
916 | | * one packet and timestamps refer to packet start. */ |
917 | 1.55k | sti->need_parsing = AVSTREAM_PARSE_TIMESTAMPS; |
918 | | /* ADTS header is in extradata, AAC without header must be |
919 | | * stored as exact frames. Parser not needed and it will |
920 | | * fail. */ |
921 | 1.55k | if (st->codecpar->codec_id == AV_CODEC_ID_AAC && |
922 | 15 | st->codecpar->extradata_size) |
923 | 4 | sti->need_parsing = AVSTREAM_PARSE_NONE; |
924 | | // The flac parser does not work with AVSTREAM_PARSE_TIMESTAMPS |
925 | 1.55k | if (st->codecpar->codec_id == AV_CODEC_ID_FLAC) |
926 | 0 | sti->need_parsing = AVSTREAM_PARSE_NONE; |
927 | | /* AVI files with Xan DPCM audio (wrongly) declare PCM |
928 | | * audio in the header but have Axan as stream_code_tag. */ |
929 | 1.55k | if (ast->handler == AV_RL32("Axan")) { |
930 | 9 | st->codecpar->codec_id = AV_CODEC_ID_XAN_DPCM; |
931 | 9 | st->codecpar->codec_tag = 0; |
932 | 9 | ast->dshow_block_align = 0; |
933 | 9 | } |
934 | 1.55k | if (amv_file_format) { |
935 | 15 | st->codecpar->codec_id = AV_CODEC_ID_ADPCM_IMA_AMV; |
936 | 15 | ast->dshow_block_align = 0; |
937 | 15 | } |
938 | 1.55k | if ((st->codecpar->codec_id == AV_CODEC_ID_AAC || |
939 | 1.54k | st->codecpar->codec_id == AV_CODEC_ID_FTR || |
940 | 1.50k | st->codecpar->codec_id == AV_CODEC_ID_FLAC || |
941 | 1.50k | st->codecpar->codec_id == AV_CODEC_ID_MP2 ) && ast->dshow_block_align <= 4 && ast->dshow_block_align) { |
942 | 1 | av_log(s, AV_LOG_DEBUG, "overriding invalid dshow_block_align of %d\n", ast->dshow_block_align); |
943 | 1 | ast->dshow_block_align = 0; |
944 | 1 | } |
945 | 1.55k | if (st->codecpar->codec_id == AV_CODEC_ID_AAC && ast->dshow_block_align == 1024 && ast->sample_size == 1024 || |
946 | 1.55k | st->codecpar->codec_id == AV_CODEC_ID_AAC && ast->dshow_block_align == 4096 && ast->sample_size == 4096 || |
947 | 1.55k | st->codecpar->codec_id == AV_CODEC_ID_MP3 && ast->dshow_block_align == 1152 && ast->sample_size == 1152) { |
948 | 1 | av_log(s, AV_LOG_DEBUG, "overriding sample_size\n"); |
949 | 1 | ast->sample_size = 0; |
950 | 1 | } |
951 | 1.55k | break; |
952 | 4.77k | case AVMEDIA_TYPE_SUBTITLE: |
953 | 4.77k | st->codecpar->codec_type = AVMEDIA_TYPE_SUBTITLE; |
954 | 4.77k | sti->request_probe = 1; |
955 | 4.77k | avio_skip(pb, size); |
956 | 4.77k | break; |
957 | 44 | default: |
958 | 44 | st->codecpar->codec_type = AVMEDIA_TYPE_DATA; |
959 | 44 | st->codecpar->codec_id = AV_CODEC_ID_NONE; |
960 | 44 | st->codecpar->codec_tag = 0; |
961 | 44 | avio_skip(pb, size); |
962 | 44 | break; |
963 | 11.7k | } |
964 | 11.7k | } |
965 | 11.7k | break; |
966 | 11.7k | case MKTAG('s', 't', 'r', 'd'): |
967 | 5.62k | if (stream_index >= (unsigned)s->nb_streams |
968 | 5.61k | || s->streams[stream_index]->codecpar->extradata_size |
969 | 5.60k | || s->streams[stream_index]->codecpar->codec_tag == MKTAG('H','2','6','4')) { |
970 | 16 | avio_skip(pb, size); |
971 | 5.60k | } else { |
972 | 5.60k | uint64_t cur_pos = avio_tell(pb); |
973 | 5.60k | if (cur_pos < list_end) |
974 | 5.56k | size = FFMIN(size, list_end - cur_pos); |
975 | 5.60k | st = s->streams[stream_index]; |
976 | | |
977 | 5.60k | if (size<(1<<30)) { |
978 | 5.59k | if (st->codecpar->extradata) { |
979 | 3 | av_log(s, AV_LOG_WARNING, "New extradata in strd chunk, freeing previous one.\n"); |
980 | 3 | } |
981 | 5.59k | if ((ret = ff_get_extradata(s, st->codecpar, pb, size)) < 0) |
982 | 9 | return ret; |
983 | 5.59k | } |
984 | | |
985 | 5.59k | if (st->codecpar->extradata_size & 1) //FIXME check if the encoder really did this correctly |
986 | 5.55k | avio_r8(pb); |
987 | | |
988 | 5.59k | ret = avi_extract_stream_metadata(s, st); |
989 | 5.59k | if (ret < 0) { |
990 | 5.07k | av_log(s, AV_LOG_WARNING, "could not decoding EXIF data in stream header.\n"); |
991 | 5.07k | } |
992 | 5.59k | } |
993 | 5.61k | break; |
994 | 5.61k | case MKTAG('i', 'n', 'd', 'x'): |
995 | 648 | pos = avio_tell(pb); |
996 | 648 | if ((pb->seekable & AVIO_SEEKABLE_NORMAL) && !(s->flags & AVFMT_FLAG_IGNIDX) && |
997 | 616 | avi->use_odml && |
998 | 616 | read_odml_index(s, 0) < 0 && |
999 | 601 | (s->error_recognition & AV_EF_EXPLODE)) |
1000 | 0 | return AVERROR_INVALIDDATA; |
1001 | 648 | avio_seek(pb, pos + size, SEEK_SET); |
1002 | 648 | break; |
1003 | 57 | case MKTAG('v', 'p', 'r', 'p'): |
1004 | 57 | if (stream_index < (unsigned)s->nb_streams && size > 9 * 4) { |
1005 | 27 | AVRational active, active_aspect; |
1006 | | |
1007 | 27 | st = s->streams[stream_index]; |
1008 | 27 | avio_rl32(pb); |
1009 | 27 | avio_rl32(pb); |
1010 | 27 | avio_rl32(pb); |
1011 | 27 | avio_rl32(pb); |
1012 | 27 | avio_rl32(pb); |
1013 | | |
1014 | 27 | active_aspect.den = avio_rl16(pb); |
1015 | 27 | active_aspect.num = avio_rl16(pb); |
1016 | 27 | active.num = avio_rl32(pb); |
1017 | 27 | active.den = avio_rl32(pb); |
1018 | 27 | avio_rl32(pb); // nbFieldsPerFrame |
1019 | | |
1020 | 27 | if (active_aspect.num && active_aspect.den && |
1021 | 24 | active.num && active.den) { |
1022 | 20 | st->sample_aspect_ratio = av_div_q(active_aspect, active); |
1023 | 20 | av_log(s, AV_LOG_TRACE, "vprp %d/%d %d/%d\n", |
1024 | 20 | active_aspect.num, active_aspect.den, |
1025 | 20 | active.num, active.den); |
1026 | 20 | } |
1027 | 27 | size -= 9 * 4; |
1028 | 27 | } |
1029 | 57 | avio_skip(pb, size); |
1030 | 57 | break; |
1031 | 59 | case MKTAG('s', 't', 'r', 'n'): |
1032 | 59 | case MKTAG('i', 's', 'b', 'j'): |
1033 | 59 | case MKTAG('i', 'n', 'a', 'm'): |
1034 | 68 | case MKTAG('i', 'a', 'r', 't'): |
1035 | 68 | case MKTAG('i', 'c', 'o', 'p'): |
1036 | 68 | case MKTAG('i', 'c', 'm', 't'): |
1037 | 70 | case MKTAG('i', 'g', 'n', 'r'): |
1038 | 70 | case MKTAG('i', 'p', 'o', 'd'): |
1039 | 71 | case MKTAG('i', 's', 'o', 'f'): |
1040 | 71 | if (s->nb_streams) { |
1041 | 51 | ret = avi_read_tag(s, s->streams[s->nb_streams - 1], tag, size); |
1042 | 51 | if (ret < 0) |
1043 | 1 | return ret; |
1044 | 50 | break; |
1045 | 51 | } |
1046 | 133k | default: |
1047 | 133k | if (size > 1000000) { |
1048 | 10.2k | av_log(s, AV_LOG_ERROR, |
1049 | 10.2k | "Something went wrong during header parsing, " |
1050 | 10.2k | "tag %s has size %u, " |
1051 | 10.2k | "I will ignore it and try to continue anyway.\n", |
1052 | 10.2k | av_fourcc2str(tag), size); |
1053 | 10.2k | if (s->error_recognition & AV_EF_EXPLODE) |
1054 | 0 | return AVERROR_INVALIDDATA; |
1055 | 10.2k | avi->movi_list = avio_tell(pb) - 4; |
1056 | 10.2k | avi->movi_end = avi->fsize; |
1057 | 10.2k | goto end_of_header; |
1058 | 10.2k | } |
1059 | | /* Do not fail for very large idx1 tags */ |
1060 | 123k | case MKTAG('i', 'd', 'x', '1'): |
1061 | | /* skip tag */ |
1062 | 123k | size += (size & 1); |
1063 | 123k | avio_skip(pb, size); |
1064 | 123k | break; |
1065 | 182k | } |
1066 | 182k | } |
1067 | | |
1068 | 10.4k | end_of_header: |
1069 | | /* check stream number */ |
1070 | 10.4k | if (stream_index != s->nb_streams - 1) |
1071 | 0 | return AVERROR_INVALIDDATA; |
1072 | | |
1073 | 10.4k | if (!avi->index_loaded && (pb->seekable & AVIO_SEEKABLE_NORMAL)) |
1074 | 2.66k | avi_load_index(s); |
1075 | 10.4k | calculate_bitrate(s); |
1076 | 10.4k | avi->index_loaded |= 1; |
1077 | | |
1078 | 10.4k | if ((ret = guess_ni_flag(s)) < 0) |
1079 | 0 | return ret; |
1080 | | |
1081 | 10.4k | avi->non_interleaved |= ret | (s->flags & AVFMT_FLAG_SORT_DTS); |
1082 | | |
1083 | 10.4k | dict_entry = av_dict_get(s->metadata, "ISFT", NULL, 0); |
1084 | 10.4k | if (dict_entry && !strcmp(dict_entry->value, "PotEncoder")) |
1085 | 0 | for (i = 0; i < s->nb_streams; i++) { |
1086 | 0 | AVStream *st = s->streams[i]; |
1087 | 0 | if ( st->codecpar->codec_id == AV_CODEC_ID_MPEG1VIDEO |
1088 | 0 | || st->codecpar->codec_id == AV_CODEC_ID_MPEG2VIDEO) |
1089 | 0 | ffstream(st)->need_parsing = AVSTREAM_PARSE_FULL; |
1090 | 0 | } |
1091 | | |
1092 | 28.9k | for (i = 0; i < s->nb_streams; i++) { |
1093 | 19.1k | AVStream *st = s->streams[i]; |
1094 | 19.1k | if (ffstream(st)->nb_index_entries) |
1095 | 747 | break; |
1096 | 19.1k | } |
1097 | | // DV-in-AVI cannot be non-interleaved, if set this must be |
1098 | | // a mis-detection. |
1099 | 10.4k | if (avi->dv_demux) |
1100 | 400 | avi->non_interleaved = 0; |
1101 | 10.4k | if (i == s->nb_streams && avi->non_interleaved) { |
1102 | 5 | av_log(s, AV_LOG_WARNING, |
1103 | 5 | "Non-interleaved AVI without index, switching to interleaved\n"); |
1104 | 5 | avi->non_interleaved = 0; |
1105 | 5 | } |
1106 | | |
1107 | 10.4k | if (avi->non_interleaved) { |
1108 | 576 | av_log(s, AV_LOG_INFO, "non-interleaved AVI\n"); |
1109 | 576 | clean_index(s); |
1110 | 576 | } |
1111 | | |
1112 | 10.4k | ff_metadata_conv_ctx(s, NULL, avi_metadata_conv); |
1113 | 10.4k | ff_metadata_conv_ctx(s, NULL, ff_riff_info_conv); |
1114 | | |
1115 | 10.4k | return 0; |
1116 | 10.4k | } |
1117 | | |
1118 | | static int read_gab2_sub(AVFormatContext *s, AVStream *st, AVPacket *pkt) |
1119 | 575k | { |
1120 | 575k | if (pkt->size >= 7 && |
1121 | 561k | pkt->size < INT_MAX - AVPROBE_PADDING_SIZE && |
1122 | 561k | !strcmp(pkt->data, "GAB2") && AV_RL16(pkt->data + 5) == 2) { |
1123 | 1.85k | uint8_t desc[256]; |
1124 | 1.85k | int score = AVPROBE_SCORE_EXTENSION, ret; |
1125 | 1.85k | AVIStream *ast = st->priv_data; |
1126 | 1.85k | const AVInputFormat *sub_demuxer; |
1127 | 1.85k | AVRational time_base; |
1128 | 1.85k | int size; |
1129 | 1.85k | AVProbeData pd; |
1130 | 1.85k | unsigned int desc_len; |
1131 | | |
1132 | 1.85k | if (ast->sub_ctx) |
1133 | 4 | return 0; |
1134 | | |
1135 | 1.85k | AVIOContext *pb = avio_alloc_context(pkt->data + 7, |
1136 | 1.85k | pkt->size - 7, |
1137 | 1.85k | 0, NULL, NULL, NULL, NULL); |
1138 | 1.85k | if (!pb) |
1139 | 0 | goto error; |
1140 | | |
1141 | 1.85k | desc_len = avio_rl32(pb); |
1142 | | |
1143 | 1.85k | if (desc_len > pb->buf_end - pb->buf_ptr) |
1144 | 201 | goto error; |
1145 | | |
1146 | 1.65k | ret = avio_get_str16le(pb, desc_len, desc, sizeof(desc)); |
1147 | 1.65k | avio_skip(pb, desc_len - ret); |
1148 | 1.65k | if (*desc) |
1149 | 1.64k | av_dict_set(&st->metadata, "title", desc, 0); |
1150 | | |
1151 | 1.65k | avio_rl16(pb); /* flags? */ |
1152 | 1.65k | avio_rl32(pb); /* data size */ |
1153 | | |
1154 | 1.65k | size = pb->buf_end - pb->buf_ptr; |
1155 | 1.65k | pd = (AVProbeData) { .buf = av_mallocz(size + AVPROBE_PADDING_SIZE), |
1156 | 1.65k | .buf_size = size }; |
1157 | 1.65k | if (!pd.buf) |
1158 | 0 | goto error; |
1159 | 1.65k | memcpy(pd.buf, pb->buf_ptr, size); |
1160 | 1.65k | sub_demuxer = av_probe_input_format2(&pd, 1, &score); |
1161 | 1.65k | av_freep(&pd.buf); |
1162 | 1.65k | if (!sub_demuxer) |
1163 | 1.59k | goto error; |
1164 | | |
1165 | 58 | if (strcmp(sub_demuxer->name, "srt") && strcmp(sub_demuxer->name, "ass")) |
1166 | 37 | goto error; |
1167 | | |
1168 | 21 | if (!(ast->sub_pkt = av_packet_alloc())) |
1169 | 0 | goto error; |
1170 | | |
1171 | 21 | if (!(ast->sub_ctx = avformat_alloc_context())) |
1172 | 0 | goto error; |
1173 | | |
1174 | 21 | ast->sub_ctx->pb = pb; |
1175 | | |
1176 | 21 | if (ff_copy_whiteblacklists(ast->sub_ctx, s) < 0) |
1177 | 0 | goto error; |
1178 | | |
1179 | 21 | if (!avformat_open_input(&ast->sub_ctx, "", sub_demuxer, NULL)) { |
1180 | 21 | if (ast->sub_ctx->nb_streams != 1) |
1181 | 0 | goto error; |
1182 | 21 | ff_read_packet(ast->sub_ctx, ast->sub_pkt); |
1183 | 21 | avcodec_parameters_copy(st->codecpar, ast->sub_ctx->streams[0]->codecpar); |
1184 | 21 | time_base = ast->sub_ctx->streams[0]->time_base; |
1185 | 21 | avpriv_set_pts_info(st, 64, time_base.num, time_base.den); |
1186 | 21 | } |
1187 | 21 | ast->sub_buffer = pkt->buf; |
1188 | 21 | pkt->buf = NULL; |
1189 | 21 | av_packet_unref(pkt); |
1190 | 21 | return 1; |
1191 | | |
1192 | 1.83k | error: |
1193 | 1.83k | av_packet_free(&ast->sub_pkt); |
1194 | 1.83k | av_freep(&ast->sub_ctx); |
1195 | 1.83k | avio_context_free(&pb); |
1196 | 1.83k | } |
1197 | 575k | return 0; |
1198 | 575k | } |
1199 | | |
1200 | | static AVStream *get_subtitle_pkt(AVFormatContext *s, AVStream *next_st, |
1201 | | AVPacket *pkt) |
1202 | 2.47M | { |
1203 | 2.47M | AVIStream *ast, *next_ast = next_st->priv_data; |
1204 | 2.47M | int64_t ts, next_ts, ts_min = INT64_MAX; |
1205 | 2.47M | AVStream *st, *sub_st = NULL; |
1206 | 2.47M | int i; |
1207 | | |
1208 | 2.47M | next_ts = av_rescale_q(next_ast->frame_offset, next_st->time_base, |
1209 | 2.47M | AV_TIME_BASE_Q); |
1210 | | |
1211 | 7.46M | for (i = 0; i < s->nb_streams; i++) { |
1212 | 4.99M | st = s->streams[i]; |
1213 | 4.99M | ast = st->priv_data; |
1214 | 4.99M | if (st->discard < AVDISCARD_ALL && ast && ast->sub_pkt && ast->sub_pkt->data) { |
1215 | 0 | ts = av_rescale_q(ast->sub_pkt->dts, st->time_base, AV_TIME_BASE_Q); |
1216 | 0 | if (ts <= next_ts && ts < ts_min) { |
1217 | 0 | ts_min = ts; |
1218 | 0 | sub_st = st; |
1219 | 0 | } |
1220 | 0 | } |
1221 | 4.99M | } |
1222 | | |
1223 | 2.47M | if (sub_st) { |
1224 | 0 | ast = sub_st->priv_data; |
1225 | 0 | av_packet_move_ref(pkt, ast->sub_pkt); |
1226 | 0 | pkt->stream_index = sub_st->index; |
1227 | |
|
1228 | 0 | if (ff_read_packet(ast->sub_ctx, ast->sub_pkt) < 0) |
1229 | 0 | ast->sub_pkt->data = NULL; |
1230 | 0 | } |
1231 | 2.47M | return sub_st; |
1232 | 2.47M | } |
1233 | | |
1234 | | static int get_stream_idx(const unsigned *d) |
1235 | 99.6M | { |
1236 | 99.6M | if (d[0] >= '0' && d[0] <= '9' && |
1237 | 8.31M | d[1] >= '0' && d[1] <= '9') { |
1238 | 3.80M | return (d[0] - '0') * 10 + (d[1] - '0'); |
1239 | 95.8M | } else { |
1240 | 95.8M | return 100; // invalid stream ID |
1241 | 95.8M | } |
1242 | 99.6M | } |
1243 | | |
1244 | | /** |
1245 | | * |
1246 | | * @param exit_early set to 1 to just gather packet position without making the changes needed to actually read & return the packet |
1247 | | */ |
1248 | | static int avi_sync(AVFormatContext *s, int exit_early) |
1249 | 551k | { |
1250 | 551k | AVIContext *avi = s->priv_data; |
1251 | 551k | AVIOContext *pb = s->pb; |
1252 | 551k | int n; |
1253 | 551k | unsigned int d[8]; |
1254 | 551k | unsigned int size; |
1255 | 551k | int64_t i, sync; |
1256 | | |
1257 | 591k | start_sync: |
1258 | 591k | memset(d, -1, sizeof(d)); |
1259 | 58.4M | for (i = sync = avio_tell(pb); !avio_feof(pb); i++) { |
1260 | 58.4M | int j; |
1261 | | |
1262 | 467M | for (j = 0; j < 7; j++) |
1263 | 408M | d[j] = d[j + 1]; |
1264 | 58.4M | d[7] = avio_r8(pb); |
1265 | | |
1266 | 58.4M | size = d[4] + (d[5] << 8) + (d[6] << 16) + (d[7] << 24); |
1267 | | |
1268 | 58.4M | n = get_stream_idx(d + 2); |
1269 | 58.4M | ff_tlog(s, "%X %X %X %X %X %X %X %X %"PRId64" %u %d\n", |
1270 | 58.4M | d[0], d[1], d[2], d[3], d[4], d[5], d[6], d[7], i, size, n); |
1271 | 58.4M | if (i*(avi->io_fsize>0) + (uint64_t)size > avi->fsize || d[0] > 127) |
1272 | 31.0M | continue; |
1273 | | |
1274 | | // parse ix## |
1275 | 27.4M | if ((d[0] == 'i' && d[1] == 'x' && n < s->nb_streams) || |
1276 | | // parse JUNK |
1277 | 27.4M | (d[0] == 'J' && d[1] == 'U' && d[2] == 'N' && d[3] == 'K') || |
1278 | 27.4M | (d[0] == 'i' && d[1] == 'd' && d[2] == 'x' && d[3] == '1') || |
1279 | 27.4M | (d[0] == 'i' && d[1] == 'n' && d[2] == 'd' && d[3] == 'x')) { |
1280 | 3.15k | avio_skip(pb, size); |
1281 | 3.15k | goto start_sync; |
1282 | 3.15k | } |
1283 | | |
1284 | | // parse stray LIST |
1285 | 27.4M | if (d[0] == 'L' && d[1] == 'I' && d[2] == 'S' && d[3] == 'T') { |
1286 | 5.89k | avio_skip(pb, 4); |
1287 | 5.89k | goto start_sync; |
1288 | 5.89k | } |
1289 | | |
1290 | 27.3M | n = get_stream_idx(d); |
1291 | | |
1292 | 27.3M | if (!((i - avi->last_pkt_pos) & 1) && |
1293 | 13.8M | get_stream_idx(d + 1) < s->nb_streams) |
1294 | 217k | continue; |
1295 | | |
1296 | | // detect ##ix chunk and skip |
1297 | 27.1M | if (d[2] == 'i' && d[3] == 'x' && n < s->nb_streams) { |
1298 | 191 | avio_skip(pb, size); |
1299 | 191 | goto start_sync; |
1300 | 191 | } |
1301 | | |
1302 | 27.1M | if (d[2] == 'w' && d[3] == 'c' && n < s->nb_streams) { |
1303 | 536 | avio_skip(pb, 16 * 3 + 8); |
1304 | 536 | goto start_sync; |
1305 | 536 | } |
1306 | | |
1307 | 27.1M | if (avi->dv_demux && n != 0) |
1308 | 3.86M | continue; |
1309 | | |
1310 | | // parse ##dc/##wb |
1311 | 23.3M | if (n < s->nb_streams) { |
1312 | 722k | AVStream *st; |
1313 | 722k | AVIStream *ast; |
1314 | 722k | st = s->streams[n]; |
1315 | 722k | ast = st->priv_data; |
1316 | | |
1317 | 722k | if (!ast) { |
1318 | 0 | av_log(s, AV_LOG_WARNING, "Skipping foreign stream %d packet\n", n); |
1319 | 0 | continue; |
1320 | 0 | } |
1321 | | |
1322 | 722k | if (s->nb_streams >= 2) { |
1323 | 300k | AVStream *st1 = s->streams[1]; |
1324 | 300k | AVIStream *ast1 = st1->priv_data; |
1325 | | // workaround for broken small-file-bug402.avi |
1326 | 300k | if (ast1 && d[2] == 'w' && d[3] == 'b' |
1327 | 10.2k | && n == 0 |
1328 | 4.81k | && st ->codecpar->codec_type == AVMEDIA_TYPE_VIDEO |
1329 | 4.24k | && st1->codecpar->codec_type == AVMEDIA_TYPE_AUDIO |
1330 | 1.77k | && ast->prefix == 'd'*256+'c' |
1331 | 1.06k | && (d[2]*256+d[3] == ast1->prefix || !ast1->prefix_count) |
1332 | 300k | ) { |
1333 | 769 | n = 1; |
1334 | 769 | st = st1; |
1335 | 769 | ast = ast1; |
1336 | 769 | av_log(s, AV_LOG_WARNING, |
1337 | 769 | "Invalid stream + prefix combination, assuming audio.\n"); |
1338 | 769 | } |
1339 | 300k | } |
1340 | | |
1341 | 722k | if (d[2] == 'p' && d[3] == 'c' && size <= 4 * 256 + 4) { |
1342 | 16.4k | int k = avio_r8(pb); |
1343 | 16.4k | int last = (k + avio_r8(pb) - 1) & 0xFF; |
1344 | | |
1345 | 16.4k | avio_rl16(pb); // flags |
1346 | | |
1347 | | // b + (g << 8) + (r << 16); |
1348 | 54.3k | for (; k <= last; k++) |
1349 | 37.9k | ast->pal[k] = 0xFFU<<24 | avio_rb32(pb)>>8; |
1350 | | |
1351 | 16.4k | ast->has_pal = 1; |
1352 | 16.4k | goto start_sync; |
1353 | 706k | } else if (((ast->prefix_count < 5 || sync + 9 > i) && |
1354 | 129k | d[2] < 128 && d[3] < 128) || |
1355 | 580k | d[2] * 256 + d[3] == ast->prefix /* || |
1356 | | (d[2] == 'd' && d[3] == 'c') || |
1357 | 706k | (d[2] == 'w' && d[3] == 'b') */) { |
1358 | 562k | if (exit_early) |
1359 | 682 | return 0; |
1360 | 561k | if (d[2] * 256 + d[3] == ast->prefix) |
1361 | 521k | ast->prefix_count++; |
1362 | 40.1k | else { |
1363 | 40.1k | ast->prefix = d[2] * 256 + d[3]; |
1364 | 40.1k | ast->prefix_count = 0; |
1365 | 40.1k | } |
1366 | | |
1367 | 561k | if (!avi->dv_demux && |
1368 | 536k | ((st->discard >= AVDISCARD_DEFAULT && size == 0) /* || |
1369 | | // FIXME: needs a little reordering |
1370 | | (st->discard >= AVDISCARD_NONKEY && |
1371 | | !(pkt->flags & AV_PKT_FLAG_KEY)) */ |
1372 | 522k | || st->discard >= AVDISCARD_ALL)) { |
1373 | | |
1374 | 14.0k | ast->frame_offset += get_duration(ast, size); |
1375 | 14.0k | avio_skip(pb, size); |
1376 | 14.0k | goto start_sync; |
1377 | 14.0k | } |
1378 | | |
1379 | 547k | avi->stream_index = n; |
1380 | 547k | ast->packet_size = size + 8; |
1381 | 547k | ast->remaining = size; |
1382 | | |
1383 | 547k | if (size) { |
1384 | 546k | FFStream *const sti = ffstream(st); |
1385 | 546k | uint64_t pos = avio_tell(pb) - 8; |
1386 | 546k | if (!sti->index_entries || !sti->nb_index_entries || |
1387 | 535k | sti->index_entries[sti->nb_index_entries - 1].pos < pos) { |
1388 | 531k | av_add_index_entry(st, pos, ast->frame_offset, size, |
1389 | 531k | 0, AVINDEX_KEYFRAME); |
1390 | 531k | } |
1391 | 546k | } |
1392 | 547k | return 0; |
1393 | 561k | } |
1394 | 722k | } |
1395 | 23.3M | } |
1396 | | |
1397 | 3.30k | if (pb->error) |
1398 | 8 | return pb->error; |
1399 | 3.29k | return AVERROR_EOF; |
1400 | 3.30k | } |
1401 | | |
1402 | | static int ni_prepare_read(AVFormatContext *s) |
1403 | 49.6k | { |
1404 | 49.6k | AVIContext *avi = s->priv_data; |
1405 | 49.6k | int best_stream_index = 0; |
1406 | 49.6k | AVStream *best_st = NULL; |
1407 | 49.6k | FFStream *best_sti; |
1408 | 49.6k | AVIStream *best_ast; |
1409 | 49.6k | int64_t best_ts = INT64_MAX; |
1410 | 49.6k | int i; |
1411 | | |
1412 | 184k | for (i = 0; i < s->nb_streams; i++) { |
1413 | 135k | AVStream *st = s->streams[i]; |
1414 | 135k | FFStream *const sti = ffstream(st); |
1415 | 135k | AVIStream *ast = st->priv_data; |
1416 | 135k | int64_t ts = ast->frame_offset; |
1417 | 135k | int64_t last_ts; |
1418 | | |
1419 | 135k | if (!sti->nb_index_entries) |
1420 | 44.4k | continue; |
1421 | | |
1422 | 90.6k | last_ts = sti->index_entries[sti->nb_index_entries - 1].timestamp; |
1423 | 90.6k | if (!ast->remaining && ts > last_ts) |
1424 | 37.1k | continue; |
1425 | | |
1426 | 53.4k | ts = av_rescale_q(ts, st->time_base, |
1427 | 53.4k | (AVRational) { FFMAX(1, ast->sample_size), |
1428 | 53.4k | AV_TIME_BASE }); |
1429 | | |
1430 | 53.4k | av_log(s, AV_LOG_TRACE, "%"PRId64" %d/%d %"PRId64"\n", ts, |
1431 | 53.4k | st->time_base.num, st->time_base.den, ast->frame_offset); |
1432 | 53.4k | if (ts < best_ts) { |
1433 | 51.3k | best_ts = ts; |
1434 | 51.3k | best_st = st; |
1435 | 51.3k | best_stream_index = i; |
1436 | 51.3k | } |
1437 | 53.4k | } |
1438 | 49.6k | if (!best_st) |
1439 | 72 | return AVERROR_EOF; |
1440 | | |
1441 | 49.6k | best_sti = ffstream(best_st); |
1442 | 49.6k | best_ast = best_st->priv_data; |
1443 | 49.6k | best_ts = best_ast->frame_offset; |
1444 | 49.6k | if (best_ast->remaining) { |
1445 | 43.1k | i = av_index_search_timestamp(best_st, |
1446 | 43.1k | best_ts, |
1447 | 43.1k | AVSEEK_FLAG_ANY | |
1448 | 43.1k | AVSEEK_FLAG_BACKWARD); |
1449 | 43.1k | } else { |
1450 | 6.50k | i = av_index_search_timestamp(best_st, best_ts, AVSEEK_FLAG_ANY); |
1451 | 6.50k | if (i >= 0) |
1452 | 6.50k | best_ast->frame_offset = best_sti->index_entries[i].timestamp; |
1453 | 6.50k | } |
1454 | | |
1455 | 49.6k | if (i >= 0) { |
1456 | 49.6k | int64_t pos = best_sti->index_entries[i].pos; |
1457 | 49.6k | pos += best_ast->packet_size - best_ast->remaining; |
1458 | 49.6k | if (avio_seek(s->pb, pos + 8, SEEK_SET) < 0) |
1459 | 704 | return AVERROR_EOF; |
1460 | | |
1461 | 48.9k | av_assert0(best_ast->remaining <= best_ast->packet_size); |
1462 | | |
1463 | 48.9k | avi->stream_index = best_stream_index; |
1464 | 48.9k | if (!best_ast->remaining) |
1465 | 5.83k | best_ast->packet_size = |
1466 | 5.83k | best_ast->remaining = best_sti->index_entries[i].size; |
1467 | 48.9k | } |
1468 | 0 | else |
1469 | 0 | return AVERROR_EOF; |
1470 | | |
1471 | 48.9k | return 0; |
1472 | 49.6k | } |
1473 | | |
1474 | | static int avi_read_packet(AVFormatContext *s, AVPacket *pkt) |
1475 | 2.48M | { |
1476 | 2.48M | AVIContext *avi = s->priv_data; |
1477 | 2.48M | AVIOContext *pb = s->pb; |
1478 | 2.48M | int err; |
1479 | | |
1480 | 2.48M | if (CONFIG_DV_DEMUXER && avi->dv_demux) { |
1481 | 26.1k | int size = avpriv_dv_get_packet(avi->dv_demux, pkt); |
1482 | 26.1k | if (size >= 0) |
1483 | 446 | return size; |
1484 | 25.6k | else |
1485 | 25.6k | goto resync; |
1486 | 26.1k | } |
1487 | | |
1488 | 2.45M | if (avi->non_interleaved) { |
1489 | 49.6k | err = ni_prepare_read(s); |
1490 | 49.6k | if (err < 0) |
1491 | 776 | return err; |
1492 | 49.6k | } |
1493 | | |
1494 | 3.02M | resync: |
1495 | 3.02M | if (avi->stream_index >= 0) { |
1496 | 2.47M | AVStream *st = s->streams[avi->stream_index]; |
1497 | 2.47M | FFStream *const sti = ffstream(st); |
1498 | 2.47M | AVIStream *ast = st->priv_data; |
1499 | 2.47M | int dv_demux = CONFIG_DV_DEMUXER && avi->dv_demux; |
1500 | 2.47M | int size, err; |
1501 | | |
1502 | 2.47M | if (get_subtitle_pkt(s, st, pkt)) |
1503 | 0 | return 0; |
1504 | | |
1505 | | // minorityreport.AVI block_align=1024 sample_size=1 IMA-ADPCM |
1506 | 2.47M | if (ast->sample_size <= 1) |
1507 | 456k | size = INT_MAX; |
1508 | 2.01M | else if (ast->sample_size < 32) |
1509 | | // arbitrary multiplier to avoid tiny packets for raw PCM data |
1510 | 1.46k | size = 1024 * ast->sample_size; |
1511 | 2.01M | else |
1512 | 2.01M | size = ast->sample_size; |
1513 | | |
1514 | 2.47M | if (size > ast->remaining) |
1515 | 536k | size = ast->remaining; |
1516 | 2.47M | avi->last_pkt_pos = avio_tell(pb); |
1517 | 2.47M | err = av_get_packet(pb, pkt, size); |
1518 | 2.47M | if (err < 0) |
1519 | 17.6k | return err; |
1520 | 2.45M | size = err; |
1521 | | |
1522 | 2.45M | if (ast->has_pal && pkt->size < (unsigned)INT_MAX / 2 && !dv_demux) { |
1523 | 12.0k | uint8_t *pal; |
1524 | 12.0k | pal = av_packet_new_side_data(pkt, |
1525 | 12.0k | AV_PKT_DATA_PALETTE, |
1526 | 12.0k | AVPALETTE_SIZE); |
1527 | 12.0k | if (!pal) { |
1528 | 0 | av_log(s, AV_LOG_ERROR, |
1529 | 0 | "Failed to allocate data for palette\n"); |
1530 | 12.0k | } else { |
1531 | 12.0k | memcpy(pal, ast->pal, AVPALETTE_SIZE); |
1532 | 12.0k | ast->has_pal = 0; |
1533 | 12.0k | } |
1534 | 12.0k | } |
1535 | | |
1536 | 2.45M | if (CONFIG_DV_DEMUXER && dv_demux) { |
1537 | 24.9k | size = avpriv_dv_produce_packet(avi->dv_demux, pkt, |
1538 | 24.9k | pkt->data, pkt->size, pkt->pos); |
1539 | 24.9k | pkt->flags |= AV_PKT_FLAG_KEY; |
1540 | 24.9k | if (size < 0) |
1541 | 24.6k | av_packet_unref(pkt); |
1542 | 2.43M | } else if (st->codecpar->codec_type == AVMEDIA_TYPE_SUBTITLE && |
1543 | 576k | !st->codecpar->codec_tag && read_gab2_sub(s, st, pkt)) { |
1544 | 21 | ast->frame_offset++; |
1545 | 21 | avi->stream_index = -1; |
1546 | 21 | ast->remaining = 0; |
1547 | 21 | goto resync; |
1548 | 2.43M | } else { |
1549 | | /* XXX: How to handle B-frames in AVI? */ |
1550 | 2.43M | pkt->dts = ast->frame_offset; |
1551 | | // pkt->dts += ast->start; |
1552 | 2.43M | if (ast->sample_size) |
1553 | 2.01M | pkt->dts /= ast->sample_size; |
1554 | 2.43M | pkt->stream_index = avi->stream_index; |
1555 | | |
1556 | 2.43M | if (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO && sti->index_entries) { |
1557 | 729k | AVIndexEntry *e; |
1558 | 729k | int index; |
1559 | | |
1560 | 729k | index = av_index_search_timestamp(st, ast->frame_offset, AVSEEK_FLAG_ANY); |
1561 | 729k | e = &sti->index_entries[index]; |
1562 | | |
1563 | 729k | if (index >= 0 && e->timestamp == ast->frame_offset) { |
1564 | 282k | if (index == sti->nb_index_entries-1) { |
1565 | 273k | int key=1; |
1566 | 273k | uint32_t state=-1; |
1567 | 273k | if (st->codecpar->codec_id == AV_CODEC_ID_MPEG4) { |
1568 | 2.79k | const uint8_t *ptr = pkt->data, *end = ptr + FFMIN(size, 256); |
1569 | 6.37k | while (ptr < end) { |
1570 | 4.28k | ptr = avpriv_find_start_code(ptr, end, &state); |
1571 | 4.28k | if (state == 0x1B6 && ptr < end) { |
1572 | 707 | key = !(*ptr & 0xC0); |
1573 | 707 | break; |
1574 | 707 | } |
1575 | 4.28k | } |
1576 | 2.79k | } |
1577 | 273k | if (!key) |
1578 | 612 | e->flags &= ~AVINDEX_KEYFRAME; |
1579 | 273k | } |
1580 | 282k | if (e->flags & AVINDEX_KEYFRAME) |
1581 | 276k | pkt->flags |= AV_PKT_FLAG_KEY; |
1582 | 282k | } |
1583 | 1.70M | } else { |
1584 | 1.70M | pkt->flags |= AV_PKT_FLAG_KEY; |
1585 | 1.70M | } |
1586 | 2.43M | ast->frame_offset += get_duration(ast, pkt->size); |
1587 | 2.43M | } |
1588 | 2.45M | ast->remaining -= err; |
1589 | 2.45M | if (!ast->remaining) { |
1590 | 545k | avi->stream_index = -1; |
1591 | 545k | ast->packet_size = 0; |
1592 | 545k | } |
1593 | | |
1594 | 2.45M | if (!avi->non_interleaved && pkt->pos >= 0 && ast->seek_pos > pkt->pos) { |
1595 | 0 | av_packet_unref(pkt); |
1596 | 0 | goto resync; |
1597 | 0 | } |
1598 | 2.45M | ast->seek_pos= 0; |
1599 | | |
1600 | 2.45M | if (!avi->non_interleaved && sti->nb_index_entries > 1 && avi->index_loaded > 1) { |
1601 | 18.1k | int64_t dts= av_rescale_q(pkt->dts, st->time_base, AV_TIME_BASE_Q); |
1602 | | |
1603 | 18.1k | if (avi->dts_max < dts) { |
1604 | 16.6k | avi->dts_max = dts; |
1605 | 16.6k | } else if (avi->dts_max - (uint64_t)dts > 2*AV_TIME_BASE) { |
1606 | 4 | avi->non_interleaved= 1; |
1607 | 4 | av_log(s, AV_LOG_INFO, "Switching to NI mode, due to poor interleaving\n"); |
1608 | 4 | } |
1609 | 18.1k | } |
1610 | | |
1611 | 2.45M | return 0; |
1612 | 2.45M | } |
1613 | | |
1614 | 550k | if ((err = avi_sync(s, 0)) < 0) |
1615 | 3.28k | return err; |
1616 | 547k | goto resync; |
1617 | 550k | } |
1618 | | |
1619 | | /* XXX: We make the implicit supposition that the positions are sorted |
1620 | | * for each stream. */ |
1621 | | static int avi_read_idx1(AVFormatContext *s, int size) |
1622 | 705 | { |
1623 | 705 | AVIContext *avi = s->priv_data; |
1624 | 705 | AVIOContext *pb = s->pb; |
1625 | 705 | int nb_index_entries, i; |
1626 | 705 | AVStream *st; |
1627 | 705 | AVIStream *ast; |
1628 | 705 | int64_t pos; |
1629 | 705 | unsigned int index, tag, flags, len, first_packet = 1; |
1630 | 705 | int64_t last_pos = -1; |
1631 | 705 | unsigned last_idx = -1; |
1632 | 705 | int64_t idx1_pos, first_packet_pos = 0, data_offset = 0; |
1633 | 705 | int anykey = 0; |
1634 | | |
1635 | 705 | nb_index_entries = size / 16; |
1636 | 705 | if (nb_index_entries <= 0) |
1637 | 7 | return AVERROR_INVALIDDATA; |
1638 | | |
1639 | 698 | idx1_pos = avio_tell(pb); |
1640 | 698 | avio_seek(pb, avi->movi_list + 4, SEEK_SET); |
1641 | 698 | if (avi_sync(s, 1) == 0) |
1642 | 682 | first_packet_pos = avio_tell(pb) - 8; |
1643 | 698 | avi->stream_index = -1; |
1644 | 698 | avio_seek(pb, idx1_pos, SEEK_SET); |
1645 | | |
1646 | 698 | if (s->nb_streams == 1 && s->streams[0]->codecpar->codec_tag == AV_RL32("MMES")) { |
1647 | 0 | first_packet_pos = 0; |
1648 | 0 | data_offset = avi->movi_list; |
1649 | 0 | } |
1650 | | |
1651 | | /* Read the entries and sort them in each stream component. */ |
1652 | 452k | for (i = 0; i < nb_index_entries; i++) { |
1653 | 452k | if (avio_feof(pb)) |
1654 | 426 | return -1; |
1655 | | |
1656 | 452k | tag = avio_rl32(pb); |
1657 | 452k | flags = avio_rl32(pb); |
1658 | 452k | pos = avio_rl32(pb); |
1659 | 452k | len = avio_rl32(pb); |
1660 | 452k | av_log(s, AV_LOG_TRACE, "%d: tag=0x%x flags=0x%x pos=0x%"PRIx64" len=%d/", |
1661 | 452k | i, tag, flags, pos, len); |
1662 | | |
1663 | 452k | index = ((tag & 0xff) - '0') * 10; |
1664 | 452k | index += (tag >> 8 & 0xff) - '0'; |
1665 | 452k | if (index >= s->nb_streams) |
1666 | 409k | continue; |
1667 | 42.4k | st = s->streams[index]; |
1668 | 42.4k | ast = st->priv_data; |
1669 | | |
1670 | | /* Skip 'xxpc' palette change entries in the index until a logic |
1671 | | * to process these is properly implemented. */ |
1672 | 42.4k | if ((tag >> 16 & 0xff) == 'p' && (tag >> 24 & 0xff) == 'c') |
1673 | 117 | continue; |
1674 | | |
1675 | 42.3k | if (first_packet && first_packet_pos) { |
1676 | 662 | if (avi->movi_list + 4 != pos || pos + 500 > first_packet_pos) |
1677 | 661 | data_offset = first_packet_pos - pos; |
1678 | 662 | first_packet = 0; |
1679 | 662 | } |
1680 | 42.3k | pos += data_offset; |
1681 | | |
1682 | 42.3k | av_log(s, AV_LOG_TRACE, "%d cum_len=%"PRId64"\n", len, ast->cum_len); |
1683 | | |
1684 | | // even if we have only a single stream, we should |
1685 | | // switch to non-interleaved to get correct timestamps |
1686 | 42.3k | if (last_pos == pos) |
1687 | 14.4k | avi->non_interleaved = 1; |
1688 | 42.3k | if (last_idx != pos && len) { |
1689 | 23.2k | av_add_index_entry(st, pos, ast->cum_len, len, 0, |
1690 | 23.2k | (flags & AVIIF_INDEX) ? AVINDEX_KEYFRAME : 0); |
1691 | 23.2k | last_idx= pos; |
1692 | 23.2k | } |
1693 | 42.3k | ast->cum_len += get_duration(ast, len); |
1694 | 42.3k | last_pos = pos; |
1695 | 42.3k | anykey |= flags&AVIIF_INDEX; |
1696 | 42.3k | } |
1697 | 272 | if (!anykey) { |
1698 | 206 | for (index = 0; index < s->nb_streams; index++) { |
1699 | 131 | FFStream *const sti = ffstream(s->streams[index]); |
1700 | 131 | if (sti->nb_index_entries) |
1701 | 80 | sti->index_entries[0].flags |= AVINDEX_KEYFRAME; |
1702 | 131 | } |
1703 | 75 | } |
1704 | 272 | return 0; |
1705 | 698 | } |
1706 | | |
1707 | | /* Scan the index and consider any file with streams more than |
1708 | | * 2 seconds or 64MB apart non-interleaved. */ |
1709 | | static int check_stream_max_drift(AVFormatContext *s) |
1710 | 10.2k | { |
1711 | 10.2k | int64_t min_pos, pos; |
1712 | 10.2k | int i; |
1713 | 10.2k | int *idx = av_calloc(s->nb_streams, sizeof(*idx)); |
1714 | 10.2k | if (!idx) |
1715 | 0 | return AVERROR(ENOMEM); |
1716 | 34.5k | for (min_pos = pos = 0; min_pos != INT64_MAX; pos = min_pos + 1ULL) { |
1717 | 24.3k | int64_t max_dts = INT64_MIN / 2; |
1718 | 24.3k | int64_t min_dts = INT64_MAX / 2; |
1719 | 24.3k | int64_t max_buffer = 0; |
1720 | | |
1721 | 24.3k | min_pos = INT64_MAX; |
1722 | | |
1723 | 63.2k | for (i = 0; i < s->nb_streams; i++) { |
1724 | 38.8k | AVStream *st = s->streams[i]; |
1725 | 38.8k | AVIStream *ast = st->priv_data; |
1726 | 38.8k | FFStream *const sti = ffstream(st); |
1727 | 38.8k | int n = sti->nb_index_entries; |
1728 | 274k | while (idx[i] < n && sti->index_entries[idx[i]].pos < pos) |
1729 | 235k | idx[i]++; |
1730 | 38.8k | if (idx[i] < n) { |
1731 | 19.2k | int64_t dts; |
1732 | 19.2k | dts = av_rescale_q(sti->index_entries[idx[i]].timestamp / |
1733 | 19.2k | FFMAX(ast->sample_size, 1), |
1734 | 19.2k | st->time_base, AV_TIME_BASE_Q); |
1735 | 19.2k | min_dts = FFMIN(min_dts, dts); |
1736 | 19.2k | min_pos = FFMIN(min_pos, sti->index_entries[idx[i]].pos); |
1737 | 19.2k | } |
1738 | 38.8k | } |
1739 | 63.2k | for (i = 0; i < s->nb_streams; i++) { |
1740 | 38.8k | AVStream *st = s->streams[i]; |
1741 | 38.8k | FFStream *const sti = ffstream(st); |
1742 | 38.8k | AVIStream *ast = st->priv_data; |
1743 | | |
1744 | 38.8k | if (idx[i] && min_dts != INT64_MAX / 2) { |
1745 | 18.6k | int64_t dts, delta_dts; |
1746 | 18.6k | dts = av_rescale_q(sti->index_entries[idx[i] - 1].timestamp / |
1747 | 18.6k | FFMAX(ast->sample_size, 1), |
1748 | 18.6k | st->time_base, AV_TIME_BASE_Q); |
1749 | 18.6k | delta_dts = av_sat_sub64(dts, min_dts); |
1750 | 18.6k | max_dts = FFMAX(max_dts, dts); |
1751 | 18.6k | max_buffer = FFMAX(max_buffer, |
1752 | 18.6k | av_rescale(delta_dts, |
1753 | 18.6k | st->codecpar->bit_rate, |
1754 | 18.6k | AV_TIME_BASE)); |
1755 | 18.6k | } |
1756 | 38.8k | } |
1757 | 24.3k | if (av_sat_sub64(max_dts, min_dts) > 2 * AV_TIME_BASE || |
1758 | 24.3k | max_buffer > 1024 * 1024 * 8 * 8) { |
1759 | 50 | av_free(idx); |
1760 | 50 | return 1; |
1761 | 50 | } |
1762 | 24.3k | } |
1763 | 10.1k | av_free(idx); |
1764 | 10.1k | return 0; |
1765 | 10.2k | } |
1766 | | |
1767 | | static int guess_ni_flag(AVFormatContext *s) |
1768 | 10.4k | { |
1769 | 10.4k | int i; |
1770 | 10.4k | int64_t last_start = 0; |
1771 | 10.4k | int64_t first_end = INT64_MAX; |
1772 | 10.4k | int64_t oldpos = avio_tell(s->pb); |
1773 | | |
1774 | 30.1k | for (i = 0; i < s->nb_streams; i++) { |
1775 | 19.6k | AVStream *st = s->streams[i]; |
1776 | 19.6k | FFStream *const sti = ffstream(st); |
1777 | 19.6k | int n = sti->nb_index_entries; |
1778 | 19.6k | unsigned int size; |
1779 | | |
1780 | 19.6k | if (n <= 0) |
1781 | 18.5k | continue; |
1782 | | |
1783 | 1.06k | if (n >= 2) { |
1784 | 761 | int64_t pos = sti->index_entries[0].pos; |
1785 | 761 | unsigned tag[2]; |
1786 | 761 | avio_seek(s->pb, pos, SEEK_SET); |
1787 | 761 | tag[0] = avio_r8(s->pb); |
1788 | 761 | tag[1] = avio_r8(s->pb); |
1789 | 761 | avio_rl16(s->pb); |
1790 | 761 | size = avio_rl32(s->pb); |
1791 | 761 | if (get_stream_idx(tag) == i && pos + size > sti->index_entries[1].pos) |
1792 | 13 | last_start = INT64_MAX; |
1793 | 761 | if (get_stream_idx(tag) == i && size == sti->index_entries[0].size + 8) |
1794 | 0 | last_start = INT64_MAX; |
1795 | 761 | } |
1796 | | |
1797 | 1.06k | if (sti->index_entries[0].pos > last_start) |
1798 | 701 | last_start = sti->index_entries[0].pos; |
1799 | 1.06k | if (sti->index_entries[n - 1].pos < first_end) |
1800 | 874 | first_end = sti->index_entries[n - 1].pos; |
1801 | 1.06k | } |
1802 | 10.4k | avio_seek(s->pb, oldpos, SEEK_SET); |
1803 | | |
1804 | 10.4k | if (last_start > first_end) |
1805 | 252 | return 1; |
1806 | | |
1807 | 10.2k | return check_stream_max_drift(s); |
1808 | 10.4k | } |
1809 | | |
1810 | | static int avi_load_index(AVFormatContext *s) |
1811 | 2.66k | { |
1812 | 2.66k | AVIContext *avi = s->priv_data; |
1813 | 2.66k | AVIOContext *pb = s->pb; |
1814 | 2.66k | uint32_t tag, size; |
1815 | 2.66k | int64_t pos = avio_tell(pb); |
1816 | 2.66k | int64_t next; |
1817 | 2.66k | int ret = -1; |
1818 | | |
1819 | 2.66k | if (avio_seek(pb, avi->movi_end, SEEK_SET) < 0) |
1820 | 1.40k | goto the_end; // maybe truncated file |
1821 | 1.26k | av_log(s, AV_LOG_TRACE, "movi_end=0x%"PRIx64"\n", avi->movi_end); |
1822 | 101k | for (;;) { |
1823 | 101k | tag = avio_rl32(pb); |
1824 | 101k | size = avio_rl32(pb); |
1825 | 101k | if (avio_feof(pb)) |
1826 | 299 | break; |
1827 | 101k | next = avio_tell(pb); |
1828 | 101k | if (next < 0 || next > INT64_MAX - size - (size & 1)) |
1829 | 21 | break; |
1830 | 101k | next += size + (size & 1LL); |
1831 | | |
1832 | 101k | if (tag == MKTAG('i', 'd', 'x', '1') && |
1833 | 705 | avi_read_idx1(s, size) >= 0) { |
1834 | 272 | avi->index_loaded=2; |
1835 | 272 | ret = 0; |
1836 | 101k | }else if (tag == MKTAG('L', 'I', 'S', 'T')) { |
1837 | 834 | uint32_t tag1 = avio_rl32(pb); |
1838 | | |
1839 | 834 | if (tag1 == MKTAG('I', 'N', 'F', 'O')) |
1840 | 250 | ff_read_riff_info(s, size - 4); |
1841 | 100k | }else if (!ret) |
1842 | 243 | break; |
1843 | | |
1844 | 101k | if (avio_seek(pb, next, SEEK_SET) < 0) |
1845 | 698 | break; // something is wrong here |
1846 | 101k | } |
1847 | | |
1848 | 2.66k | the_end: |
1849 | 2.66k | avio_seek(pb, pos, SEEK_SET); |
1850 | 2.66k | return ret; |
1851 | 1.26k | } |
1852 | | |
1853 | | static void seek_subtitle(AVStream *st, AVStream *st2, int64_t timestamp) |
1854 | 0 | { |
1855 | 0 | AVIStream *ast2 = st2->priv_data; |
1856 | 0 | int64_t ts2 = av_rescale_q(timestamp, st->time_base, st2->time_base); |
1857 | 0 | av_packet_unref(ast2->sub_pkt); |
1858 | 0 | if (avformat_seek_file(ast2->sub_ctx, 0, INT64_MIN, ts2, ts2, 0) >= 0 || |
1859 | 0 | avformat_seek_file(ast2->sub_ctx, 0, ts2, ts2, INT64_MAX, 0) >= 0) |
1860 | 0 | ff_read_packet(ast2->sub_ctx, ast2->sub_pkt); |
1861 | 0 | } |
1862 | | |
1863 | | static int avi_read_seek(AVFormatContext *s, int stream_index, |
1864 | | int64_t timestamp, int flags) |
1865 | 0 | { |
1866 | 0 | AVIContext *avi = s->priv_data; |
1867 | 0 | AVStream *st; |
1868 | 0 | FFStream *sti; |
1869 | 0 | int i, index; |
1870 | 0 | int64_t pos, pos_min; |
1871 | 0 | AVIStream *ast; |
1872 | | |
1873 | | /* Does not matter which stream is requested dv in avi has the |
1874 | | * stream information in the first video stream. |
1875 | | */ |
1876 | 0 | if (avi->dv_demux) |
1877 | 0 | stream_index = 0; |
1878 | |
|
1879 | 0 | if (!avi->index_loaded) { |
1880 | | /* we only load the index on demand */ |
1881 | 0 | avi_load_index(s); |
1882 | 0 | avi->index_loaded |= 1; |
1883 | 0 | } |
1884 | 0 | av_assert0(stream_index >= 0); |
1885 | | |
1886 | 0 | st = s->streams[stream_index]; |
1887 | 0 | sti = ffstream(st); |
1888 | 0 | ast = st->priv_data; |
1889 | |
|
1890 | 0 | if (avi->dv_demux) { |
1891 | | // index entries are in the AVI scale/rate timebase, which does |
1892 | | // not match DV demuxer's stream timebase |
1893 | 0 | timestamp = av_rescale_q(timestamp, st->time_base, |
1894 | 0 | (AVRational){ ast->scale, ast->rate }); |
1895 | 0 | } else |
1896 | 0 | timestamp *= FFMAX(ast->sample_size, 1); |
1897 | |
|
1898 | 0 | index = av_index_search_timestamp(st, timestamp, flags); |
1899 | 0 | if (index < 0) { |
1900 | 0 | if (sti->nb_index_entries > 0) |
1901 | 0 | av_log(s, AV_LOG_DEBUG, "Failed to find timestamp %"PRId64 " in index %"PRId64 " .. %"PRId64 "\n", |
1902 | 0 | timestamp, |
1903 | 0 | sti->index_entries[0].timestamp, |
1904 | 0 | sti->index_entries[sti->nb_index_entries - 1].timestamp); |
1905 | 0 | return AVERROR_INVALIDDATA; |
1906 | 0 | } |
1907 | | |
1908 | | /* find the position */ |
1909 | 0 | pos = sti->index_entries[index].pos; |
1910 | 0 | timestamp = sti->index_entries[index].timestamp; |
1911 | |
|
1912 | 0 | av_log(s, AV_LOG_TRACE, "XX %"PRId64" %d %"PRId64"\n", |
1913 | 0 | timestamp, index, sti->index_entries[index].timestamp); |
1914 | |
|
1915 | 0 | if (CONFIG_DV_DEMUXER && avi->dv_demux) { |
1916 | | /* One and only one real stream for DV in AVI, and it has video */ |
1917 | | /* offsets. Calling with other stream indexes should have failed */ |
1918 | | /* the av_index_search_timestamp call above. */ |
1919 | |
|
1920 | 0 | if (avio_seek(s->pb, pos, SEEK_SET) < 0) |
1921 | 0 | return -1; |
1922 | | |
1923 | | /* Feed the DV video stream version of the timestamp to the */ |
1924 | | /* DV demux so it can synthesize correct timestamps. */ |
1925 | 0 | ff_dv_ts_reset(avi->dv_demux, |
1926 | 0 | av_rescale_q(timestamp, (AVRational){ ast->scale, ast->rate }, |
1927 | 0 | st->time_base)); |
1928 | |
|
1929 | 0 | avi->stream_index = -1; |
1930 | 0 | return 0; |
1931 | 0 | } |
1932 | 0 | timestamp /= FFMAX(ast->sample_size, 1); |
1933 | |
|
1934 | 0 | pos_min = pos; |
1935 | 0 | for (i = 0; i < s->nb_streams; i++) { |
1936 | 0 | AVStream *st2 = s->streams[i]; |
1937 | 0 | FFStream *const sti2 = ffstream(st2); |
1938 | 0 | AVIStream *ast2 = st2->priv_data; |
1939 | |
|
1940 | 0 | ast2->packet_size = |
1941 | 0 | ast2->remaining = 0; |
1942 | |
|
1943 | 0 | if (ast2->sub_ctx) { |
1944 | 0 | seek_subtitle(st, st2, timestamp); |
1945 | 0 | continue; |
1946 | 0 | } |
1947 | | |
1948 | 0 | if (sti2->nb_index_entries <= 0) |
1949 | 0 | continue; |
1950 | | |
1951 | | // av_assert1(st2->codecpar->block_align); |
1952 | 0 | index = av_index_search_timestamp(st2, |
1953 | 0 | av_rescale_q(timestamp, |
1954 | 0 | st->time_base, |
1955 | 0 | st2->time_base) * |
1956 | 0 | FFMAX(ast2->sample_size, 1), |
1957 | 0 | flags | |
1958 | 0 | AVSEEK_FLAG_BACKWARD | |
1959 | 0 | (st2->codecpar->codec_type != AVMEDIA_TYPE_VIDEO ? AVSEEK_FLAG_ANY : 0)); |
1960 | 0 | if (index < 0) |
1961 | 0 | index = 0; |
1962 | 0 | ast2->seek_pos = sti2->index_entries[index].pos; |
1963 | 0 | pos_min = FFMIN(pos_min,ast2->seek_pos); |
1964 | 0 | } |
1965 | 0 | for (i = 0; i < s->nb_streams; i++) { |
1966 | 0 | AVStream *st2 = s->streams[i]; |
1967 | 0 | FFStream *const sti2 = ffstream(st2); |
1968 | 0 | AVIStream *ast2 = st2->priv_data; |
1969 | |
|
1970 | 0 | if (ast2->sub_ctx || sti2->nb_index_entries <= 0) |
1971 | 0 | continue; |
1972 | | |
1973 | 0 | index = av_index_search_timestamp( |
1974 | 0 | st2, |
1975 | 0 | av_rescale_q(timestamp, st->time_base, st2->time_base) * FFMAX(ast2->sample_size, 1), |
1976 | 0 | flags | AVSEEK_FLAG_BACKWARD | (st2->codecpar->codec_type != AVMEDIA_TYPE_VIDEO ? AVSEEK_FLAG_ANY : 0)); |
1977 | 0 | if (index < 0) |
1978 | 0 | index = 0; |
1979 | 0 | while (!avi->non_interleaved && index > 0 && sti2->index_entries[index-1].pos >= pos_min) |
1980 | 0 | index--; |
1981 | 0 | ast2->frame_offset = sti2->index_entries[index].timestamp; |
1982 | 0 | } |
1983 | | |
1984 | | /* do the seek */ |
1985 | 0 | if (avio_seek(s->pb, pos_min, SEEK_SET) < 0) { |
1986 | 0 | av_log(s, AV_LOG_ERROR, "Seek failed\n"); |
1987 | 0 | return -1; |
1988 | 0 | } |
1989 | 0 | avi->stream_index = -1; |
1990 | 0 | avi->dts_max = INT_MIN; |
1991 | 0 | return 0; |
1992 | 0 | } |
1993 | | |
1994 | | static int avi_read_close(AVFormatContext *s) |
1995 | 11.0k | { |
1996 | 11.0k | int i; |
1997 | 11.0k | AVIContext *avi = s->priv_data; |
1998 | | |
1999 | 33.4k | for (i = 0; i < s->nb_streams; i++) { |
2000 | 22.3k | AVStream *st = s->streams[i]; |
2001 | 22.3k | AVIStream *ast = st->priv_data; |
2002 | 22.3k | if (ast) { |
2003 | 22.0k | if (ast->sub_ctx) { |
2004 | 21 | av_freep(&ast->sub_ctx->pb); |
2005 | 21 | avformat_close_input(&ast->sub_ctx); |
2006 | 21 | } |
2007 | 22.0k | av_buffer_unref(&ast->sub_buffer); |
2008 | 22.0k | av_packet_free(&ast->sub_pkt); |
2009 | 22.0k | } |
2010 | 22.3k | } |
2011 | | |
2012 | 11.0k | av_freep(&avi->dv_demux); |
2013 | | |
2014 | 11.0k | return 0; |
2015 | 11.0k | } |
2016 | | |
2017 | | static int avi_probe(const AVProbeData *p) |
2018 | 942k | { |
2019 | 942k | int i; |
2020 | | |
2021 | | /* check file header */ |
2022 | 5.64M | for (i = 0; avi_headers[i][0]; i++) |
2023 | 4.70M | if (AV_RL32(p->buf ) == AV_RL32(avi_headers[i] ) && |
2024 | 25.3k | AV_RL32(p->buf + 8) == AV_RL32(avi_headers[i] + 4)) |
2025 | 3.06k | return AVPROBE_SCORE_MAX; |
2026 | | |
2027 | 939k | return 0; |
2028 | 942k | } |
2029 | | |
2030 | | const FFInputFormat ff_avi_demuxer = { |
2031 | | .p.name = "avi", |
2032 | | .p.long_name = NULL_IF_CONFIG_SMALL("AVI (Audio Video Interleaved)"), |
2033 | | .p.extensions = "avi", |
2034 | | .p.priv_class = &demuxer_class, |
2035 | | .priv_data_size = sizeof(AVIContext), |
2036 | | .flags_internal = FF_INFMT_FLAG_INIT_CLEANUP, |
2037 | | .read_probe = avi_probe, |
2038 | | .read_header = avi_read_header, |
2039 | | .read_packet = avi_read_packet, |
2040 | | .read_close = avi_read_close, |
2041 | | .read_seek = avi_read_seek, |
2042 | | }; |