[FFmpeg-user] Use of -hls_flags iframes_only results in incorrect EXT-X-VERSION value
"zhilizhao(赵志立)"
quinkblack at foxmail.com
Tue Jan 19 14:11:42 EET 2021
> On Jan 19, 2021, at 6:57 PM, Bruce Roberts <roberb04 at gmail.com> wrote:
>
> Hello,
>
> I'm trying to generate Apple mediastreamvalidator compliant HLS using
> ffmpeg and have very nearly achieved that.
>
> The only remaining problem is that use of " -hls_flags iframes_only"
> correctly adds the #EXT-X-I-FRAMES-ONLY tag to my trickplay m3u8 but it
> doesn't increment the #EXT-X-VERSION value from 3 to 4.
Current implementation of I-FRAMES-ONLY is very limited.
http://ffmpeg.org/pipermail/ffmpeg-devel/2021-January/274698.html
>
> The validator then complains as follows:
>
> --------------------------------------------------------------------------------
>
> MUST fix issues
>
> --------------------------------------------------------------------------------
>
>
>
> Error: incorrect version number for feature
>
> --> Detail: Line: (null)
>
> --> Source: output_TrickPlay_Video_8bit.m3u8
>
> If I manually edit the file and change the version value to 4, validation
> is successful.
>
> I have upgraded ffmpeg to the latest version but the problem remains.
>
> Is there a way for me to force #EXT-X-VERSION:4 ?
>
> Here is my command and the console output:
>
> ffmpeg \
> -ss 00:00:00.000 -t 00:00:30.000 -i input_23.98fps.mxf \
> -filter_complex \
> "[0:v:0]format=pix_fmts=yuv420p[vconcat420p8bit]; \
> [vconcat420p8bit]split=3[vconcat1][vconcat2][vconcat3]; \
> [vconcat3]fps=1.001000[vconcat1fps]; \
> [0:a:0][0:a:1]join=inputs=2:channel_layout=stereo[stereo]" \
> -map "[vconcat1]" -f hls -hls_list_size 0 -hls_time 6.006
> -hls_playlist_type vod -an -vcodec libx264 -flags +cgop -g 48 -b:v 2500k
> -maxrate 2500k -bufsize 2500k -x264opts
> nal-hrd=cbr:bframes=0:keyint=48:min-keyint=48:scenecut=-1 \
> output_T0_Video_8bit.m3u8 \
> -map "[vconcat2]" -f hls -hls_list_size 0 -hls_time 6.006
> -hls_playlist_type vod -an -vcodec libx264 -flags +cgop -g 48 -b:v 250k
> -maxrate 250k -bufsize 250k -x264opts
> nal-hrd=cbr:bframes=0:keyint=48:min-keyint=48:scenecut=-1 \
> output_T1_Video_8bit.m3u8 \
> -map "[stereo]" -f hls -hls_list_size 0 -hls_time 6.006 -hls_playlist_type
> vod -vn -acodec libfdk_aac -b:a 120k -ar 48000 NEW_output_T1_Audio.m3u8 \
> -map "[vconcat1fps]" -f hls -hls_list_size 0 -hls_time 6.006
> -hls_playlist_type vod -hls_flags iframes_only -an -vcodec libx264 -intra
> -b:v 250k -maxrate 250k -bufsize 250k \
> output_TrickPlay_Video_8bit.m3u8 \
>
> ffmpeg version git-2021-01-13-f6477ac9 Copyright (c) 2000-2021 the FFmpeg
> developers
> built with Apple clang version 12.0.0 (clang-1200.0.32.28)
> configuration: --prefix=/usr/local/Cellar/ffmpeg/HEAD-f6477ac_6
> --enable-shared --cc=clang --host-cflags= --host-ldflags= --enable-gpl
> --enable-libaom --enable-libdav1d --enable-libmp3lame --enable-libopus
> --enable-libsnappy --enable-libtheora --enable-libvorbis --enable-libvpx
> --enable-libx264 --enable-libx265 --enable-libfontconfig
> --enable-libfreetype --enable-frei0r --enable-libass --enable-demuxer=dash
> --disable-libjack --disable-indev=jack --enable-opencl
> --enable-videotoolbox --disable-htmlpages --enable-libfdk-aac
> --enable-nonfree
> libavutil 56. 63.101 / 56. 63.101
> libavcodec 58.117.100 / 58.117.100
> libavformat 58. 65.101 / 58. 65.101
> libavdevice 58. 11.103 / 58. 11.103
> libavfilter 7. 95.100 / 7. 95.100
> libswscale 5. 8.100 / 5. 8.100
> libswresample 3. 8.100 / 3. 8.100
> libpostproc 55. 8.100 / 55. 8.100
> Guessed Channel Layout for Input Stream #0.2 : mono
> Guessed Channel Layout for Input Stream #0.3 : mono
> Input #0, mxf, from 'input_23.98fps.mxf':
> Metadata:
> operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
> uid : ec3f5416-a722-1dcc-8f60-d4f34e4a603d
> generation_uid : 296bd6eb-2ca9-1321-bbef-5f5f4cfc10ec
> company_name : Telestream Inc.
> product_name : Telestream Media Framework - Release TXGP
> product_version : 2016.30.183822
> modification_date: 2020-12-15T15:24:55.000000Z
> product_uid : 11350ec5-148a-1010-aaca-d2c1000f040a
> material_package_umid:
> 0x060A2B340101010501010F1213296BD6EB2CA90321BB1F5F9F4CFC10ECBED4ED
> timecode : 00:58:30:00
> Duration: 00:45:07.12, start: 0.000000, bitrate: 93297 kb/s
> Stream #0:0: Data: none
> Metadata:
> file_package_umid:
> 0x060A2B340101010501010F12135106454D99258E516513059C33EC3F5416A722
> data_type : vbi_vanc_smpte_436M
> Stream #0:1: Video: h264 (High 4:2:2 Intra), yuv422p10le(pc, bt709,
> progressive), 1920x1080 [SAR 1:1 DAR 16:9], 23.98 fps, 23.98 tbr, 23.98
> tbn, 47.95 tbc
> Metadata:
> file_package_umid:
> 0x060A2B340101010501010F12135106454D99258E516513059C33EC3F5416A722
> Stream #0:2: Audio: pcm_s24le, 48000 Hz, mono, s32 (24 bit), 1152 kb/s
> Metadata:
> file_package_umid:
> 0x060A2B340101010501010F12135106454D99258E516513059C33EC3F5416A722
> Stream #0:3: Audio: pcm_s24le, 48000 Hz, mono, s32 (24 bit), 1152 kb/s
> Metadata:
> file_package_umid:
> 0x060A2B340101010501010F12135106454D99258E516513059C33EC3F5416A722
> Stream mapping:
> Stream #0:1 (h264) -> format
> Stream #0:2 (pcm_s24le) -> join:input0
> Stream #0:3 (pcm_s24le) -> join:input1
> split:output0 -> Stream #0:0 (libx264)
> split:output1 -> Stream #1:0 (libx264)
> join -> Stream #2:0 (libfdk_aac)
> fps -> Stream #3:0 (libx264)
> Press [q] to stop, [?] for help
> [libx264 @ 0x7fb52d814800] using SAR=1/1
> [libx264 @ 0x7fb52d814800] using cpu capabilities: MMX2 SSE2Fast SSSE3
> SSE4.2 AVX FMA3 BMI2 AVX2
> [libx264 @ 0x7fb52d814800] profile High, level 4.0
> [libx264 @ 0x7fb52d814800] 264 - core 155 r2917 0a84d98 - H.264/MPEG-4 AVC
> codec - Copyleft 2003-2018 - http://www.videolan.org/x264.html - options:
> cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1
> psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1
> cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=24
> lookahead_threads=4 sliced_threads=0 nr=0 decimate=1 interlaced=0
> bluray_compat=0 constrained_intra=0 bframes=0 weightp=2 keyint=48
> keyint_min=25 scenecut=0 intra_refresh=0 rc_lookahead=40 rc=cbr mbtree=1
> bitrate=2500 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4
> vbv_maxrate=2500 vbv_bufsize=2500 nal_hrd=cbr filler=1 ip_ratio=1.40
> aq=1:1.00
> Output #0, hls, to 'output_T0_Video_8bit.m3u8':
> Metadata:
> operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
> uid : ec3f5416-a722-1dcc-8f60-d4f34e4a603d
> generation_uid : 296bd6eb-2ca9-1321-bbef-5f5f4cfc10ec
> company_name : Telestream Inc.
> product_name : Telestream Media Framework - Release TXGP
> product_version : 2016.30.183822
> modification_date: 2020-12-15T15:24:55.000000Z
> product_uid : 11350ec5-148a-1010-aaca-d2c1000f040a
> material_package_umid:
> 0x060A2B340101010501010F1213296BD6EB2CA90321BB1F5F9F4CFC10ECBED4ED
> timecode : 00:58:30:00
> encoder : Lavf58.65.101
> Stream #0:0: Video: h264, yuv420p(tv, bt709, progressive), 1920x1080
> [SAR 1:1 DAR 16:9], q=2-31, 2500 kb/s, 23.98 fps, 90k tbn (default)
> Metadata:
> encoder : Lavc58.117.100 libx264
> Side data:
> cpb: bitrate max/min/avg: 2500000/0/2500000 buffer size: 2500000
> vbv_delay: N/A
> [libx264 @ 0x7fb52d818800] using SAR=1/1
> [libx264 @ 0x7fb52d818800] using cpu capabilities: MMX2 SSE2Fast SSSE3
> SSE4.2 AVX FMA3 BMI2 AVX2
> [libx264 @ 0x7fb52d818800] profile High, level 4.0
> [libx264 @ 0x7fb52d818800] 264 - core 155 r2917 0a84d98 - H.264/MPEG-4 AVC
> codec - Copyleft 2003-2018 - http://www.videolan.org/x264.html - options:
> cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1
> psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1
> cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=24
> lookahead_threads=4 sliced_threads=0 nr=0 decimate=1 interlaced=0
> bluray_compat=0 constrained_intra=0 bframes=0 weightp=2 keyint=48
> keyint_min=25 scenecut=0 intra_refresh=0 rc_lookahead=40 rc=cbr mbtree=1
> bitrate=250 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4
> vbv_maxrate=250 vbv_bufsize=250 nal_hrd=cbr filler=1 ip_ratio=1.40 aq=1:1.00
> Output #1, hls, to 'output_T1_Video_8bit.m3u8':
> Metadata:
> operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
> uid : ec3f5416-a722-1dcc-8f60-d4f34e4a603d
> generation_uid : 296bd6eb-2ca9-1321-bbef-5f5f4cfc10ec
> company_name : Telestream Inc.
> product_name : Telestream Media Framework - Release TXGP
> product_version : 2016.30.183822
> modification_date: 2020-12-15T15:24:55.000000Z
> product_uid : 11350ec5-148a-1010-aaca-d2c1000f040a
> material_package_umid:
> 0x060A2B340101010501010F1213296BD6EB2CA90321BB1F5F9F4CFC10ECBED4ED
> timecode : 00:58:30:00
> encoder : Lavf58.65.101
> Stream #1:0: Video: h264, yuv420p(tv, bt709, progressive), 1920x1080
> [SAR 1:1 DAR 16:9], q=2-31, 250 kb/s, 23.98 fps, 90k tbn (default)
> Metadata:
> encoder : Lavc58.117.100 libx264
> Side data:
> cpb: bitrate max/min/avg: 250000/0/250000 buffer size: 250000
> vbv_delay: N/A
> [mpegts @ 0x7fb52c214400] frame size not set
> Output #2, hls, to 'NEW_output_T1_Audio.m3u8':
> Metadata:
> operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
> uid : ec3f5416-a722-1dcc-8f60-d4f34e4a603d
> generation_uid : 296bd6eb-2ca9-1321-bbef-5f5f4cfc10ec
> company_name : Telestream Inc.
> product_name : Telestream Media Framework - Release TXGP
> product_version : 2016.30.183822
> modification_date: 2020-12-15T15:24:55.000000Z
> product_uid : 11350ec5-148a-1010-aaca-d2c1000f040a
> material_package_umid:
> 0x060A2B340101010501010F1213296BD6EB2CA90321BB1F5F9F4CFC10ECBED4ED
> timecode : 00:58:30:00
> encoder : Lavf58.65.101
> Stream #2:0: Audio: aac, 48000 Hz, stereo, s16, 120 kb/s (default)
> Metadata:
> encoder : Lavc58.117.100 libfdk_aac
> [libx264 @ 0x7fb52d820200] using SAR=1/1
> [libx264 @ 0x7fb52d820200] using cpu capabilities: MMX2 SSE2Fast SSSE3
> SSE4.2 AVX FMA3 BMI2 AVX2
> [libx264 @ 0x7fb52d820200] profile High, level 4.0
> [libx264 @ 0x7fb52d820200] 264 - core 155 r2917 0a84d98 - H.264/MPEG-4 AVC
> codec - Copyleft 2003-2018 - http://www.videolan.org/x264.html - options:
> cabac=1 ref=1 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1
> psy_rd=1.00:0.00 mixed_ref=0 me_range=16 chroma_me=1 trellis=1 8x8dct=1
> cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=24
> lookahead_threads=4 sliced_threads=0 nr=0 decimate=1 interlaced=0
> bluray_compat=0 constrained_intra=0 bframes=0 weightp=0 keyint=1
> keyint_min=1 scenecut=40 intra_refresh=0 rc_lookahead=1 rc=cbr mbtree=0
> bitrate=250 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4
> vbv_maxrate=250 vbv_bufsize=250 nal_hrd=none filler=0 ip_ratio=1.40
> aq=1:1.00
> Output #3, hls, to 'output_TrickPlay_Video_8bit.m3u8':
> Metadata:
> operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
> uid : ec3f5416-a722-1dcc-8f60-d4f34e4a603d
> generation_uid : 296bd6eb-2ca9-1321-bbef-5f5f4cfc10ec
> company_name : Telestream Inc.
> product_name : Telestream Media Framework - Release TXGP
> product_version : 2016.30.183822
> modification_date: 2020-12-15T15:24:55.000000Z
> product_uid : 11350ec5-148a-1010-aaca-d2c1000f040a
> material_package_umid:
> 0x060A2B340101010501010F1213296BD6EB2CA90321BB1F5F9F4CFC10ECBED4ED
> timecode : 00:58:30:00
> encoder : Lavf58.65.101
> Stream #3:0: Video: h264, yuv420p(tv, bt709, progressive), 1920x1080
> [SAR 1:1 DAR 16:9], q=2-31, 250 kb/s, 1 fps, 90k tbn (default)
> Metadata:
> encoder : Lavc58.117.100 libx264
> Side data:
> cpb: bitrate max/min/avg: 250000/0/250000 buffer size: 250000
> vbv_delay: N/A
>
> Here is the complete unedited output_TrickPlay_Video_8bit.m3u8:
>
> #EXTM3U
> #EXT-X-VERSION:3
> #EXT-X-TARGETDURATION:7
> #EXT-X-MEDIA-SEQUENCE:0
> #EXT-X-PLAYLIST-TYPE:VOD
> #EXT-X-I-FRAMES-ONLY
> #EXTINF:6.993011,
> output_TrickPlay_Video_8bit0.ts
> #EXTINF:5.994000,
> output_TrickPlay_Video_8bit1.ts
> #EXTINF:5.994011,
> output_TrickPlay_Video_8bit2.ts
> #EXTINF:5.994000,
> output_TrickPlay_Video_8bit3.ts
> #EXTINF:4.995000,
> output_TrickPlay_Video_8bit4.ts
> #EXT-X-ENDLIST
>
> Many thanks!
> Bruce.
> _______________________________________________
> ffmpeg-user mailing list
> ffmpeg-user at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-user
>
> To unsubscribe, visit link above, or email
> ffmpeg-user-request at ffmpeg.org with subject "unsubscribe".
More information about the ffmpeg-user
mailing list