Opened 11 years ago
Closed 11 years ago
#3769 closed defect (fixed)
-moov_size option causes MOV file structure to be corrupted
Reported by: | rling | Owned by: | |
---|---|---|---|
Priority: | normal | Component: | avformat |
Version: | git-master | Keywords: | mov |
Cc: | Blocked By: | ||
Blocking: | Reproduced by developer: | no | |
Analyzed by developer: | no |
Description
Summary of the bug:
Using the -moov_size option causes a 'free' atom to be added to the MOV file immediately after the 'moov' atom. The 'free' atom's size field is wrong, corrupting the file.
How to reproduce:
- Encode a MOV file, determine required size of 'moov' atom by using a very small -moov_size:
% ffmpeg -y -i input.MOV -moov_size 1 output.MOV ffmpeg version N-64667-gd595361 Copyright (c) 2000-2014 the FFmpeg developers built on Jul 14 2014 22:02:04 with gcc 4.8.3 (GCC) [...] [mov @ 04865620] reserved_moov_size is too small, needed 6135 additional. [...]
- Required size is thus 6136 bytes. Use -moov_size option to require 'moov' atom to be 20 bytes larger than required size:
% ffmpeg -y -i input.MOV -moov_size 6156 output.MOV
- Examine output.MOV with a hex editor and look for the 'free' atom between the 'moov' and 'mdat' atoms:
017e00a 5d 6e 00 00 00 21 75 64 74 61 00 00 00 19 a9 .]n...!udta....© 017f073 77 72 00 0d 55 c4 4c 61 76 66 35 35 2e 34 37 swr..UÄLavf55.47 018002e 31 30 30 00 00 00 1c 66 72 65 65 00 00 00 00 .100....free.... 0181000 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0182000 00 00 00 00 00 00 00 00 0a 4a 9b 6d 64 61 74 ..........J.mdat 0183000 00 02 ae 06 05 ff ff aa dc 45 e9 bd e6 d9 48 ...®..ÿÿªÜEé½æÙH
The atom's size field has been set to the size of the content only (28 empty bytes), NOT including the 8 bytes for the header itself. The size should include the 8 bytes for the atom header. The MOV file is thus corrupt and cannot be parsed correctly with normal tools.
Change History (6)
comment:1 by , 11 years ago
comment:2 by , 11 years ago
Component: | undetermined → avformat |
---|---|
Keywords: | mov added |
Are you planning to send a patch created with git format-patch
to the ffmpeg-devel mailing list?
comment:3 by , 11 years ago
Sorry, I don't have a checkout and am too time poor to contribute. I'm also not sure whether the fix is to increase the size field by 8 or to reduce the number of bytes written by 8. Will have to leave it to the experts.
comment:4 by , 11 years ago
Version: | unspecified → git-master |
---|
Which tool cannot parse the output file with the incorrect free atom?
comment:5 by , 11 years ago
It's my very simple in-house tool. My tool correctly parses input.MOV, which is direct from a Canon G15 camera and also contains a 'free' atom, but fails on the output.MOV generated with the command line above.
WMP and MPC-HC were able to play output.MOV, and Windows displayed a normal thumbnail for it. I think many media players may only read up to the 'moov' atom, which itself contains absolute file offsets into the 'mdat' atom, which allows them to display and play the file without ever reading the 'free' atom. So I'm not surprised this bug could hide for a long time.
comment:6 by , 11 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
Should be fixed in 0e70266b - thank you for the report!
Appears to be related to these lines near 4394-4402 of libavformat/movenc.c:
The code appears to write size as the atom's size, then write 'free' as the tag, then write size bytes as the atom content. This is a violation of atom structure.