Opened 12 years ago

Last modified 11 years ago

#2085 open defect

h264 remuxed from flv to mov fails on Android (duplicated SPS)

Reported by: mikhailov Owned by:
Priority: normal Component: undetermined
Version: git-master Keywords: h264 flv mov
Cc: Roman Ernstovich Arutyunyan Blocked By:
Blocking: Reproduced by developer: no
Analyzed by developer: no

Description

Summary of the bug:

We use FLV captured stream from webcam (using application build for Flash Player), h264 comes direct from the flash, but audio stream Speex should be encoded to AAC to make the streams compatible with mobile devices h264 (Baseline) + AAC.

Video stream should not be encoded again, so we use the copy method, like the following:

ffmpeg -i input.flv -c:v copy -c:a libvo_aacenc output.mp4

The resulted MP4 video files plays back well on Flash Player 11.4+ and iPhone/iPad with iOS 5+ (Baseline compatible video stream). but on Android devices and Flash Player 11.1/11.2 the playback freezes at 2-3 seconds. We also use qt-faststart, but it doesn't affect on stuck problem.

Stdout of ffmpeg encoding script:

ffmpeg version 1.0 Copyright (c) 2000-2012 the FFmpeg developers
  built on Nov 17 2012 23:45:34 with Apple clang version 4.1 (tags/Apple/clang-421.11.66) (based on LLVM 3.1svn)
  configuration: --prefix=/usr/local/Cellar/ffmpeg/1.0 --enable-shared --enable-gpl --enable-version3 --enable-nonfree --enable-hardcoded-tables --cc=cc --host-cflags= --host-ldflags= --enable-libx264 --enable-libfaac --enable-libvo-aacenc --enable-libspeex
  libavutil      51. 73.101 / 51. 73.101
  libavcodec     54. 59.100 / 54. 59.100
  libavformat    54. 29.104 / 54. 29.104
  libavdevice    54.  2.101 / 54.  2.101
  libavfilter     3. 17.100 /  3. 17.100
  libswscale      2.  1.101 /  2.  1.101
  libswresample   0. 15.100 /  0. 15.100
  libpostproc    52.  0.100 / 52.  0.100
[libspeex @ 0x7fabb902ea00] Missing Speex header, assuming defaults.
Guessed Channel Layout for  Input Stream #0.1 : mono
Input #0, flv, from '1.flv':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
  Duration: 00:00:30.25, start: 0.000000, bitrate: 212 kb/s
    Stream #0:0: Video: h264 (Baseline), yuv420p, 640x480 [SAR 1:1 DAR 4:3], 20 tbr, 1k tbn, 40 tbc
    Stream #0:1: Audio: speex, 16000 Hz, mono, s16
File '1.mp4' already exists. Overwrite ? [y/N] y
Missing Speex header, assuming defaults.
Output #0, mp4, to '1.mp4':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
    encoder         : Lavf54.29.104
    Stream #0:0: Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 640x480 [SAR 1:1 DAR 4:3], q=2-31, 1k tbn, 1k tbc
    Stream #0:1: Audio: aac ([64][0][0][0] / 0x0040), 16000 Hz, mono, s16, 96 kb/s
Stream mapping:
  Stream #0:0 -> #0:0 (copy)
  Stream #0:1 -> #0:1 (libspeex -> libvo_aacenc)
Press [q] to stop, [?] for help
[mp4 @ 0x7fabb9012800] st:0 PTS: 2139 DTS: 2139 < 2140 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 2722 DTS: 2722 < 2723 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 5440 DTS: 5440 < 5441 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 8105 DTS: 8105 < 8106 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 10772 DTS: 10772 < 10773 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 13456 DTS: 13456 < 13457 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 16127 DTS: 16127 < 16128 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 18835 DTS: 18835 < 18836 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 21675 DTS: 21675 < 21676 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 24476 DTS: 24476 < 24477 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 27283 DTS: 27283 < 27284 invalid, clipping
[mp4 @ 0x7fabb9012800] st:0 PTS: 30079 DTS: 30079 < 30080 invalid, clipping
frame=  454 fps=0.0 q=-1.0 Lsize=     978kB time=00:00:30.31 bitrate= 264.4kbits/s    
video:620kB audio:346kB subtitle:0 global headers:0kB muxing overhead 1.170369%

I tried different versions of ffmpeg (0.10, 0.11, 1.0, 1.01) compiled with mandatory --with-libvo-aacenc --with-speex, but the problem still not resolved.

Attachments (3)

result.mp4 (1.1 MB ) - added by Carl Eugen Hoyos 12 years ago.
302_1991_7668.flv (783.1 KB ) - added by Carl Eugen Hoyos 12 years ago.
flv-demuxer-sps-pps-fix (540 bytes ) - added by Roman Ernstovich Arutyunyan 11 years ago.
make flv demuxer always read h264 extradata

Download all attachments as: .zip

Change History (69)

comment:1 by Carl Eugen Hoyos, 12 years ago

Component: FFmpegundetermined
Keywords: mov added

Are you sure you are reporting this on the right bug tracker?

Please test current git head.

Is this only reproducible with -acodec libvo_aacenc or also with -acodec libfaac and -strict -2 -acodec aac? What about -an?

comment:2 by mikhailov, 12 years ago

I would be happy if you can advice me another right ffmpeg bug tracker.

Yes, I tried multiple audio codecs and even delete audio stream while remuxing (-an), the result is the same.
The problem with demux process from FLV to MP4 container (Video stream still untouchable).

Last edited 12 years ago by mikhailov (previous) (diff)

in reply to:  2 comment:3 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

I would be happy if you can advice me another right ffmpeg bug tracker.

I meant if the video plays on an iPhone but not on Android devices, this may indicate that the problem can only be fixed on the Android devices.

Please test current git head and -an (and post console output). If the resulting video is not played, I wonder if this wouldn't indicate that the bitrate (level) of the stream is too high.

comment:4 by mikhailov, 12 years ago

test file with FLV container (h264 + Speex) http://yadi.sk/d/75d7DWh01YPxf

comment:5 by Carl Eugen Hoyos, 12 years ago

Please run "ffmpeg -i 302_1991_7668.flv -vcodec copy -an out.mp4" using current git head and test the resulting file on your Android device.

comment:6 by mikhailov, 12 years ago

yes, I'll fetch git HEAD, compile ffmpeg and perform the encoding with it very soon

comment:7 by mikhailov, 12 years ago

I've got the git HEAD:

git clone --depth=1 git://source.ffmpeg.org/ffmpeg.git
./configure --enable-gpl --enable-libx264 --enable-libmp3lame --enable-nonfree --enable-libvo-aacenc --enable-libspeex --enable-version3
make

then tried to remux the container:

ffmpeg -i 1.flv -vcodec copy -an out.mp4

the result the same: playback fine on OS X and iPhone/iPad, but stuck on 2sec. when you try to playback on Flash 11.1 (flowplayer) or Android devices:

http://yadi.sk/d/YQux1bCq1YVJV

How can I check the MP4 container, is it valid or not?

ffmpeg -i 1.flv -vcodec copy -an out.mp4
ffmpeg version git-2012-12-31-9827528 Copyright (c) 2000-2012 the FFmpeg developers
  built on Dec 31 2012 13:16:36 with llvm-gcc 4.2.1 (LLVM build 2336.11.00)
  configuration: --enable-gpl --enable-libx264 --enable-libmp3lame --enable-nonfree --enable-libvo-aacenc --enable-libspeex --enable-version3
  libavutil      52. 13.100 / 52. 13.100
  libavcodec     54. 85.100 / 54. 85.100
  libavformat    54. 58.100 / 54. 58.100
  libavdevice    54.  3.102 / 54.  3.102
  libavfilter     3. 30.102 /  3. 30.102
  libswscale      2.  1.103 /  2.  1.103
  libswresample   0. 17.102 /  0. 17.102
  libpostproc    52.  2.100 / 52.  2.100
Input #0, flv, from '1.flv':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
  Duration: 00:00:30.25, start: 0.000000, bitrate: 212 kb/s
    Stream #0:0: Video: h264 (Baseline), yuv420p, 640x480 [SAR 1:1 DAR 4:3], 20 tbr, 1k tbn, 40 tbc
    Stream #0:1: Audio: speex, 16000 Hz, mono, s16
Output #0, mp4, to 'out.mp4':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
    encoder         : Lavf54.58.100
    Stream #0:0: Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 640x480 [SAR 1:1 DAR 4:3], q=2-31, 16k tbn, 1k tbc
Stream mapping:
  Stream #0:0 -> #0:0 (copy)
Press [q] to stop, [?] for help
[mp4 @ 0x7f9d13837600] st:0 PTS: 34224 DTS: 34224 < 34225 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 43552 DTS: 43552 < 43553 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 87040 DTS: 87040 < 87041 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 129680 DTS: 129680 < 129681 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 172352 DTS: 172352 < 172353 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 215296 DTS: 215296 < 215297 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 258032 DTS: 258032 < 258033 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 301360 DTS: 301360 < 301361 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 346800 DTS: 346800 < 346801 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 391616 DTS: 391616 < 391617 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 436528 DTS: 436528 < 436529 invalid, clipping
[mp4 @ 0x7f9d13837600] st:0 PTS: 481264 DTS: 481264 < 481265 invalid, clipping
frame=  454 fps=0.0 q=-1.0 Lsize=     626kB time=00:00:30.25 bitrate= 169.6kbits/s    
video:620kB audio:0kB subtitle:0 global headers:0kB muxing overhead 0.985025%
Last edited 12 years ago by mikhailov (previous) (diff)

comment:8 by mikhailov, 12 years ago

Each video file we put into the queue through ffmpeg and qt-faststart, everything with according to documentation. But the MP4 container becomes not full compatible, I don't know the reason why Flash Player < 11.1 and Android devices can't play back it well (normally h264 works with Flash Player 9.0+).

When we use libx264 to transcode the video stream (h264+AAC) plays back fine on every Flash Player and Android devices(!), but when remux problem is starting to happen.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:9 by mikhailov, 12 years ago

What would you advice me to try? I can provide more file samples if necessary.

in reply to:  8 comment:10 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

When we use libx264 to transcode the video stream (h264+AAC) plays back fine on every Flash Player and Android devices(!), but when remux problem is starting to happen.

Could you provide a x264-encoded sample that plays fine with Flash and Android, and show the ffmpeg remuxing command line (together with complete, uncut console output) that produces a failing sample?

comment:11 by mikhailov, 12 years ago

x264 sample to playback fine on Androids is able to get through encdoding with libx264, but not remuxing. I can apply libx264 result file, but it's a normal valid h264+AAC file.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:12 by mikhailov, 12 years ago

Just take the test file with FLV container (h264 + Speex) http://yadi.sk/d/75d7DWh01YPxf
and run

ffmpeg -i test.flv -c:v libx264 -profile:v baseline -c:a libvo_aacenc -ab 96k -ac 1 result.mp4

It will produce correct MP4+AAC file can be played back on any devices.

comment:13 by Carl Eugen Hoyos, 12 years ago

How can this sample be used to produce a file that does not work on your device?

in reply to:  13 comment:14 by mikhailov, 12 years ago

Replying to cehoyos:

How can this sample be used to produce a file that does not work on your device?

via remux:

ffmpeg -i 1.flv -vcodec copy -an out.mp4

comment:15 by Carl Eugen Hoyos, 12 years ago

If result.mp4 plays fine, does the following command produce an output file that can be played with your device?
$ ffmpeg -i result.mp4 -acodec copy -vcodec copy out.mp4

in reply to:  15 comment:16 by mikhailov, 12 years ago

Replying to cehoyos:

If result.mp4 plays fine, does the following command produce an output file that can be played with your device?
$ ffmpeg -i result.mp4 -acodec copy -vcodec copy out.mp4

I wrote about it before, copy (container remux) broke the file. MP4Box manually demux-mux works fine, but MP4Box is very complex and out-of-date software and it's very hard to compile on CentOS.

comment:17 by Carl Eugen Hoyos, 12 years ago

(Assuming that non-native speakers may read this ticket, one could argue that you failed to answer the question.)

Please provide result.mp4.

comment:18 by mikhailov, 12 years ago

here you go:

http://yadi.sk/d/70msco_v1t3zk

ffmpeg -i 1.flv -c:v libx264 -profile:v baseline -c:a libvo_aacenc -ab 96k -ac 1 result.mp4
ffmpeg version 1.0 Copyright (c) 2000-2012 the FFmpeg developers
  built on Nov 17 2012 23:45:34 with Apple clang version 4.1 (tags/Apple/clang-421.11.66) (based on LLVM 3.1svn)
  configuration: --prefix=/usr/local/Cellar/ffmpeg/1.0 --enable-shared --enable-gpl --enable-version3 --enable-nonfree --enable-hardcoded-tables --cc=cc --host-cflags= --host-ldflags= --enable-libx264 --enable-libfaac --enable-libvo-aacenc --enable-libspeex
  libavutil      51. 73.101 / 51. 73.101
  libavcodec     54. 59.100 / 54. 59.100
  libavformat    54. 29.104 / 54. 29.104
  libavdevice    54.  2.101 / 54.  2.101
  libavfilter     3. 17.100 /  3. 17.100
  libswscale      2.  1.101 /  2.  1.101
  libswresample   0. 15.100 /  0. 15.100
  libpostproc    52.  0.100 / 52.  0.100
[libspeex @ 0x7f8bf982ea00] Missing Speex header, assuming defaults.
Guessed Channel Layout for  Input Stream #0.1 : mono
Input #0, flv, from '1.flv':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
  Duration: 00:00:30.25, start: 0.000000, bitrate: 212 kb/s
    Stream #0:0: Video: h264 (Baseline), yuv420p, 640x480 [SAR 1:1 DAR 4:3], 20 tbr, 1k tbn, 40 tbc
    Stream #0:1: Audio: speex, 16000 Hz, mono, s16
[libx264 @ 0x7f8bf9818a00] using SAR=1/1
[libx264 @ 0x7f8bf9818a00] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.1 Cache64
[libx264 @ 0x7f8bf9818a00] profile Constrained Baseline, level 3.0
[libx264 @ 0x7f8bf9818a00] 264 - core 125 - H.264/MPEG-4 AVC codec - Copyleft 2003-2012 - http://www.videolan.org/x264.html - options: cabac=0 ref=3 deblock=1:0:0 analyse=0x1:0x111 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=0 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=3 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=0 weightp=0 keyint=250 keyint_min=20 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
[libspeex @ 0x7f8bf982ea00] Missing Speex header, assuming defaults.
Output #0, mp4, to 'result.mp4':
  Metadata:
    creationdate    : Thu Nov 22 09:46:36
    duration2       : 29964
    encoder         : Lavf54.29.104
    Stream #0:0: Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 640x480 [SAR 1:1 DAR 4:3], q=-1--1, 20 tbn, 20 tbc
    Stream #0:1: Audio: aac ([64][0][0][0] / 0x0040), 16000 Hz, mono, s16, 96 kb/s
Stream mapping:
  Stream #0:0 -> #0:0 (h264 -> libx264)
  Stream #0:1 -> #0:1 (libspeex -> libvo_aacenc)
Press [q] to stop, [?] for help
frame=  606 fps= 66 q=-1.0 Lsize=    1147kB time=00:00:30.31 bitrate= 310.0kbits/s dup=163 drop=0    
video:790kB audio:346kB subtitle:0 global headers:0kB muxing overhead 0.906209%
[libx264 @ 0x7f8bf9818a00] frame I:3     Avg QP:17.11  size: 14229
[libx264 @ 0x7f8bf9818a00] frame P:603   Avg QP:21.38  size:  1270
[libx264 @ 0x7f8bf9818a00] mb I  I16..4: 47.6%  0.0% 52.4%
[libx264 @ 0x7f8bf9818a00] mb P  I16..4:  1.9%  0.0%  0.9%  P16..4: 16.0%  2.8%  0.6%  0.0%  0.0%    skip:77.7%
[libx264 @ 0x7f8bf9818a00] coded y,uvDC,uvAC intra: 32.3% 48.5% 12.4% inter: 2.8% 6.4% 0.3%
[libx264 @ 0x7f8bf9818a00] i16 v,h,dc,p: 36% 15%  8% 42%
[libx264 @ 0x7f8bf9818a00] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 33% 18% 20%  5%  5%  6%  5%  5%  3%
[libx264 @ 0x7f8bf9818a00] i8c dc,h,v,p: 46% 20% 23% 11%
[libx264 @ 0x7f8bf9818a00] ref P L0: 88.8%  7.5%  3.7%
[libx264 @ 0x7f8bf9818a00] kb/s:213.44
Last edited 12 years ago by mikhailov (previous) (diff)

comment:19 by mikhailov, 12 years ago

Keywords: mp4 mux remux container added; mov removed

comment:20 by mikhailov, 12 years ago

Could you explain a bit more about 'invalid, clipping' please? Might it be the reason?

The MP4 file (copied video stream) container plays back fine during first 2-3 seconds, afteward it freezes, but sound still goes on!

comment:21 by mikhailov, 12 years ago

FFMPEG 0.8-0.9 might work fine with container remux, just remember that found it in mailing-list, but can't find it again... Anything been changed over the last few minor releases?

comment:22 by mikhailov, 12 years ago

Maybe I should try MP4Box or alternatives to solve the container remux issue...

comment:23 by mikhailov, 12 years ago

any plan to fix the Mux-Demux in FFMPEG?

comment:24 by mikhailov, 12 years ago

Version: 1.0.1git-master

in reply to:  21 ; comment:25 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

FFMPEG 0.8-0.9 might work fine with container remux

Sorry, I have missed this message:
Could you test FFmpeg 0.8 and 0.9? If it works with one of them, it will be relatively easy to fix your problem.

in reply to:  25 comment:26 by mikhailov, 12 years ago

Replying to cehoyos:

Replying to mikhailov:

FFMPEG 0.8-0.9 might work fine with container remux

Sorry, I have missed this message:
Could you test FFmpeg 0.8 and 0.9? If it works with one of them, it will be relatively easy to fix your problem.

It seems the Wowza Media Server bug, wrong meta-data in the files within MP4 container, reference to:
http://www.wowza.com/forums/showthread.php?20328-Wowza-2-can-t-save-file-to-mp4!/page2

But there is a bug on FFMPEG side with FLV container, with F4V everything is ok.

Last edited 12 years ago by mikhailov (previous) (diff)

by Carl Eugen Hoyos, 12 years ago

Attachment: result.mp4 added

comment:27 by mikhailov, 12 years ago

The bug is still around, any plan to fix it?

Version 0, edited 12 years ago by mikhailov (next)

in reply to:  27 ; comment:28 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

The bug with FLV container demuxing is still around, any plan to fix it?

You wrote above that you believe it works fine with an older version of FFmpeg (0.8 iiuc), if you can confirm which change introduced the bug it should be easy to fix.

in reply to:  28 comment:29 by mikhailov, 12 years ago

Replying to cehoyos:

Replying to mikhailov:

The bug with FLV container demuxing is still around, any plan to fix it?

You wrote above that you believe it works fine with an older version of FFmpeg (0.8 iiuc), if you can confirm which change introduced the bug it should be easy to fix.

It was some post over the Internet, we tried 0.8.4 and the ffmpeg doesn't work with our files (attached before) at all. There is the same problem as we have: http://ffmpeg.org/pipermail/ffmpeg-user/2012-December/012220.html But we can't use libx264, it's overkill and our source files are already h264 as video stream. By the way we have constant bitrate, please look at throught the attached files.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:30 by mikhailov, 12 years ago

I do believe this is absolutely the same problem: http://ffmpeg.org/pipermail/ffmpeg-user/2012-December/012119.html

in reply to:  30 comment:31 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

I do believe this is absolutely the same problem: http://ffmpeg.org/pipermail/ffmpeg-user/2012-December/012119.html

Could you elaborate?
Iiuc, your problem is only reproducible with -vcodec copy while this mail is about a problem with -vcodec libx264 (only reproducible with an ancient and unsupported version of FFmpeg).

by Carl Eugen Hoyos, 12 years ago

Attachment: 302_1991_7668.flv added

comment:32 by Carl Eugen Hoyos, 12 years ago

Keywords: mov h264 flv added; mp4 mux remux container removed

comment:33 by Carl Eugen Hoyos, 12 years ago

Rereading the ticket, I am not sure if I understand:
Could you confirm that result.mp4 plays fine on your Android device?
If it does play fine and you remux result.mp4:
$ ffmpeg -i result.mp4 -vcodec copy -an out.mp4
Does out.mp4 play on the Android device?

comment:34 by mikhailov, 12 years ago

Yes, you are right, comment 30th is not valid, it's not our use-case, but please take a look comment 29th again. He ended up with Wowza streaming but it's impossible for us to do the same, MP4 files should be valid and playable from anywhere.

http://ffmpeg.org/pipermail/ffmpeg-user/2012-December/012220.html
After PTS/DTS Invalid clipping error, it makes video stream duration a little bit longer and probably audio and video lose synchronisation. It does not matter if there is sound stream or no sound stream (for out.mp4), the file does not play if we use the copy h.264 (demux) encoded video stream instead of transcoding with libx264 (transcoding makes the file playable always).

The brief explanation: the file comes from flash already contains h.264, but wrapped into FLV container, so we use copy by doing remux.

I've attached 3 files:

The last one is playable on every device, the second one is not playable on Androids.
Out.mp4 file is demuxed and muxed into MP4 container.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:35 by Carl Eugen Hoyos, 12 years ago

What happens if you remux result.mp4 with ffmpeg - does the file play on your Android device?

in reply to:  35 comment:36 by mikhailov, 12 years ago

Replying to cehoyos:

What happens if you remux result.mp4 with ffmpeg - does the file play on your Android device?

yes, it does, but why are we taking about encoding? Please forget about libx264, we don't use it, but WE DO DEMUX AND MUX BACK via video stream copy.

comment:37 by mikhailov, 12 years ago

Sorry, does any other developer can help please?

Last edited 12 years ago by mikhailov (previous) (diff)

comment:38 by mikhailov, 12 years ago

Keywords: mux demux added; mov removed
Priority: normalimportant

comment:39 by Carl Eugen Hoyos, 12 years ago

Keywords: mov added; mux demux removed
Priority: importantnormal

If out.mp4 (created by FFmpeg) is the file that does not play on your Android device, does it help if you remux that file with MP4Box?

Please do not edit keywords and priority, this is not welcome!

in reply to:  39 comment:40 by mikhailov, 12 years ago

Replying to cehoyos:

If out.mp4 (created by FFmpeg) is the file that does not play on your Android device, does it help if you remux that file with MP4Box?

Yes, it does

comment:41 by mikhailov, 12 years ago

@cehoyos please take a look this ticket https://ffmpeg.org/trac/ffmpeg/ticket/2096

comment:42 by Carl Eugen Hoyos, 12 years ago

I am not used to MP4Box: Could you add the command line that "fixes" out.mp4?

in reply to:  42 comment:43 by mikhailov, 12 years ago

Replying to cehoyos:

I am not used to MP4Box: Could you add the command line that "fixes" out.mp4?

MP4Box -raw 1 out.mp4
MP4Box -raw 2 out.mp4
MP4Box -add output_track1.h264:fps=15 -add output_track2.aac out.mp4
MP4Box -hint out.mp4
rm output_track1.h264
rm output_track2.aac

Last edited 12 years ago by mikhailov (previous) (diff)

comment:44 by mikhailov, 12 years ago

Reference to #2096, the regression has been fixed for F4V only, but still there for FLV container

comment:45 by Carl Eugen Hoyos, 12 years ago

What is the effect of fps=15 in your MP4Box command line? Is -hint necessary to produce a file that is playable on Android?

Please note that ticket #2096 is a ticket about an audio decoding regression while this ticket is (also) reproducible with -an iiuc.

Last edited 12 years ago by Carl Eugen Hoyos (previous) (diff)

in reply to:  45 ; comment:46 by mikhailov, 12 years ago

Replying to cehoyos:

What is the effect of fps=15 in your MP4Box command line? Is -hint necessary to produce a file that is playable on Android?

even without any extra options it produces valid MP4 files playable on Androids and Flash Players older than 11.2. Hints does almost the same as qt-faststart.

Please note that ticket #2085 is a ticket about an audio decoding regression while this ticket is (also) reproducible with -an iiuc.

Do you mean #2096?

in reply to:  46 ; comment:47 by Carl Eugen Hoyos, 12 years ago

Replying to mikhailov:

Replying to cehoyos:

What is the effect of fps=15 in your MP4Box command line? Is -hint necessary to produce a file that is playable on Android?

even without any extra options it produces valid MP4 files playable on Androids and Flash Players older than 11.2. Hints does almost the same as qt-faststart.

Does that mean that there is a simpler MP4Box command that allows to produce a file that works on your Android device from out.mp4 ?

Please note that ticket #2085 is a ticket about an audio decoding regression while this ticket is (also) reproducible with -an iiuc.

Do you mean #2096?

Of course.

in reply to:  47 comment:48 by mikhailov, 12 years ago

Replying to cehoyos:

Replying to mikhailov:

Replying to cehoyos:

What is the effect of fps=15 in your MP4Box command line? Is -hint necessary to produce a file that is playable on Android?

even without any extra options it produces valid MP4 files playable on Androids and Flash Players older than 11.2. Hints does almost the same as qt-faststart.

Does that mean that there is a simpler MP4Box command that allows to produce a file that works on your Android device from out.mp4 ?

It doesn't mean this, because F4V container file produced by Wowza Media Server (FMS the same way) passed through ffmpeg works on Android successfully, as well as on Androids. MP4Box is not possible to compile on CentOS 6.*

Please note that ticket #2085 is a ticket about an audio decoding regression while this ticket is (also) reproducible with -an iiuc.

Do you mean #2096?

Of course.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:49 by mikhailov, 12 years ago

I tried older version ffmpeg (0.11.2) and got the same error as in #1154. The issues remains

Last edited 12 years ago by mikhailov (previous) (diff)

comment:50 by mikhailov, 12 years ago

I've just encoded the original file with ffmpeg 1.0, the file playback stuck on 2nd second even on Flash Player 11.7. Newer ffmpeg versions (1.1.2, 1.2.1) produce more correct MP4 files that are playable for Flash Player 11.2+. We will do tests on Androids tomorrow.

Probably it can help you to identify the issue.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:51 by mikhailov, 12 years ago

@cehoyos 5 months later with full explanation and file samples the bug still no reproduced by developer? I can see the other tickets with "invalid clipping" were reproduced by developer at least.

Last edited 12 years ago by mikhailov (previous) (diff)

comment:52 by Carl Eugen Hoyos, 12 years ago

Sorry, I do not own an Android device so I cannot reproduce the problem.
If you want to help, please try to find a minimal (as short as possible) command line for MP4Box that uses a (video-only) input file produced with FFmpeg that does not play on your Android device and outputs a file that plays fine on the device.

comment:53 by Carl Eugen Hoyos, 12 years ago

And please confirm that the problem is reproducible with current git head.

in reply to:  52 comment:54 by mikhailov, 12 years ago

Replying to cehoyos:

Sorry, I do not own an Android device so I cannot reproduce the problem.
If you want to help, please try to find a minimal (as short as possible) command line for MP4Box that uses a (video-only) input file produced with FFmpeg that does not play on your Android device and outputs a file that plays fine on the device.

It can be reproduced not only on Android, but Flash Player less than 11.2 as well. The resulted files are corrupted.
We won't more waste our and your time with it. We go use F4V container (it's not broken in ffmpeg yet) instead of FLV.

in reply to:  53 comment:55 by mikhailov, 12 years ago

Replying to cehoyos:

And please confirm that the problem is reproducible with current git head.

still reproducible with latest git HEAD

comment:56 by Carl Eugen Hoyos, 12 years ago

Great that you changed your opinion, I am always unhappy if tickets remain unresolved!

If you want to help fixing this problem, please find a minimal (that is an as-short-as-possible) MP4Box command line that fixes an input file produced by FFmpeg that does not play on your Android device by outputting a file that plays fine on the same device.

in reply to:  56 comment:57 by mikhailov, 12 years ago

Replying to cehoyos:

Great that you changed your opinion, I am always unhappy if tickets remain unresolved!

If you want to help fixing this problem, please find a minimal (that is an as-short-as-possible) MP4Box command line that fixes an input file produced by FFmpeg that does not play on your Android device by outputting a file that plays fine on the same device.

MP4Box is very difficult to build on newere Linuxes such Red Hat 4.6.3-2, but on old Ubuntu this minimal command lines could fix the problem:

$ ffmpeg -y -i input.flv -vcodec copy -acodec libvo_aacenc -ac 1 -ar 22050 -ab 64k output.mp4 # Change container to MP4 because MP4Box doesn't work with FLV container
$ MP4Box -raw 1 output.mp4 # Demux stream
$ MP4Box -raw 2 output.mp4 # Demux stream
$ MP4Box -add output_track1.h264:fps=15 -add output_track2.aac output.mp4 # Mux two streams back
$ MP4Box -hint output.mp4 # Moov atom place to the file beginning, qt-faststart does the same
$ rm output_track1.h264 && rm output_track2.aac

by Roman Ernstovich Arutyunyan, 11 years ago

Attachment: flv-demuxer-sps-pps-fix added

make flv demuxer always read h264 extradata

comment:58 by Roman Ernstovich Arutyunyan, 11 years ago

I've attached a simple patch "flv-demuxer-sps-pps-fix" fixing the problem.

The flv has repeated h264 extradata packets. They are returned as usual h264 nals and passed to muxer which produces totally broken video packet.

comment:59 by Carl Eugen Hoyos, 11 years ago

Cc: Roman Ernstovich Arutyunyan added

Please consider sending patches to the ffmpeg-devel mailing list, they receive more attention there.

comment:60 by mikhailov, 11 years ago

@arut yay, that's fantastic! thank you so much, it works now!

comment:61 by mikhailov, 11 years ago

@cehoyos any plan to merge it with master?

in reply to:  61 comment:62 by Carl Eugen Hoyos, 11 years ago

Replying to mikhailov:

@cehoyos any plan to merge it with master?

It appears the patch is not yet ready for merging:
http://thread.gmane.org/gmane.comp.video.ffmpeg.devel/167587

comment:63 by mikhailov, 11 years ago

@cehoyos this is another commit, any reason why the original commit by @arut is not merged yet?

in reply to:  63 comment:64 by Roman Ernstovich Arutyunyan, 11 years ago

Replying to mikhailov:

@cehoyos this is another commit, any reason why the original commit by @arut is not merged yet?

That patch does the same but it's slightly more specific. Anyway Michael Niedermayer thinks it breaks some stuff in ffmpeg.

The original code checking RTMP packet type byte for zero was very strange. It handled all AAC decoder configs but ONLY FIRST H264 decoder config and let others pass as H264 NALs to the caller. I've fixed that but the old behavior certainly makes sense in certain situations since it looks very much like a workaround.

comment:65 by Roman Ernstovich Arutyunyan, 11 years ago

I've realized just now I know the reason. Successive H264 decoder configs may contain new SPS for new picture resolution. That's why it's important to send every new config when remuxing from one streaming format to another streaming format. Mp4 muxer does not expect those. It uses extradata only once when writing mp4 moov atom and does not make any use of successive H264 configs.

comment:66 by Carl Eugen Hoyos, 11 years ago

Status: newopen
Summary: MP4 remux with playback stuck at 2nd secondsh264 remuxed from flv to mov fails on Android (duplicated SPS)
Note: See TracTickets for help on using tickets.