Opened 3 years ago
Last modified 2 weeks ago
#9412 reopened defect
HEVC fails to seek on keyframe
Reported by: | SuRGeoNix | Owned by: | |
---|---|---|---|
Priority: | normal | Component: | avformat |
Version: | git-master | Keywords: | mpegts hevc seek |
Cc: | MasterQuestionable | Blocked By: | |
Blocking: | Reproduced by developer: | no | |
Analyzed by developer: | no |
Description
I'm using av_seek_frame and even if it returns 0 pb will not be at an actual keyframe. The issues seems to happen with any HEVC/mpeg-ts format container.
[Format ] MPEG-TS (MPEG-2 Transport Stream)/mpegts
[Video #0] hevc yuv420p10le 3840x2160 @ 59,94
[Audio #1-eng] aac fltp@0 48KHz stereo
I've tested also with ffplay which fails as well with the following output
C:\Users\Owner\Downloads\ffmpegmb\bin>ffplay.exe -ss 00:01:00 -analyzeduration 100000000000 -probesize 100000000000 "c:\root\down\samples\hd\LG Chess 4K Demo.ts" ffplay version N-103543-gc655a734b1-20210907 Copyright (c) 2003-2021 the FFmpeg developers built with gcc 10-win32 (GCC) 20210408 configuration: --prefix=/ffbuild/prefix --pkg-config-flags=--static --pkg-config=pkg-config --cross-prefix=x86_64-w64-mingw32- --arch=x86_64 --target-os=mingw32 --enable-gpl --enable-version3 --disable-debug --disable-w32threads --enable-pthreads --enable-iconv --enable-libxml2 --enable-zlib --enable-libfreetype --enable-libfribidi --enable-gmp --enable-lzma --enable-fontconfig --enable-libvorbis --enable-opencl --enable-libvmaf --enable-vulkan --disable-libxcb --disable-xlib --enable-amf --enable-libaom --enable-avisynth --enable-libdav1d --enable-libdavs2 --disable-libfdk-aac --enable-ffnvcodec --enable-cuda-llvm --enable-frei0r --enable-libglslang --enable-libgme --enable-libass --enable-libbluray --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvpx --enable-libwebp --enable-lv2 --enable-libmfx --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-librav1e --enable-librubberband --enable-schannel --enable-sdl2 --enable-libsoxr --enable-libsrt --enable-libsvtav1 --enable-libtwolame --enable-libuavs3d --disable-libdrm --disable-vaapi --enable-libvidstab --enable-libx264 --enable-libx265 --enable-libxavs2 --enable-libxvid --enable-libzimg --enable-libzvbi --extra-cflags=-DLIBTWOLAME_STATIC --extra-cxxflags= --extra-ldflags=-pthread --extra-ldexeflags= --extra-libs=-lgomp --extra-version=20210907 libavutil 57. 4.101 / 57. 4.101 libavcodec 59. 7.102 / 59. 7.102 libavformat 59. 5.100 / 59. 5.100 libavdevice 59. 0.101 / 59. 0.101 libavfilter 8. 7.101 / 8. 7.101 libswscale 6. 1.100 / 6. 1.100 libswresample 4. 0.100 / 4. 0.100 libpostproc 56. 0.100 / 56. 0.100 [mpegts @ 00000282a0400480] stream 0 : no PTS found at end of file, duration not set Input #0, mpegts, from 'c:\root\down\samples\hd\LG Chess 4K Demo.ts': Duration: 00:01:52.92, start: 1.066722, bitrate: 62572 kb/s Program 1 Stream #0:0[0x101]: Video: hevc (Main 10) ([36][0][0][0] / 0x0024), yuv420p10le(tv, bt2020nc/bt2020/smpte2084), 3840x2160 [SAR 1:1 DAR 16:9], 59.94 fps, 59.94 tbr, 90k tbn Stream #0:1[0x102](und): Audio: aac (LC) ([15][0][0][0] / 0x000F), 48000 Hz, stereo, fltp, 383 kb/s [aac @ 00000282a5beb040] channel element 0.0 is not allocated [hevc @ 00000282a8b2d040] Could not find ref with POC 15 0B f=0/0 [hevc @ 00000282a8b2d040] Could not find ref with POC 13 [hevc @ 00000282a8b2d040] Could not find ref with POC 17 [hevc @ 00000282a8b2d040] Could not find ref with POC 21 [hevc @ 00000282a8b2d040] Could not find ref with POC 28 0B f=0/0 62.26 A-V: -0.025 fd= 3 aq= 47KB vq=11446KB sq= 0B f=0/0
Change History (20)
comment:1 by , 3 years ago
Keywords: | mpegts added |
---|
comment:3 by , 3 years ago
Found another issue with HEVC (at least with the same LG Chess 4K Demo.ts) that might be related to this one.
I have implemented a reverse playback by decoding from keyframe until the next one and then seeking to the previous keyframe (Manually ensuring that I actually have keyframe to keyframe).
While decoding I'm draining the decoder properly but it seems that sometimes it misses some frames and I have at least 2-3 frames diff between the last draining frame and the next keyframe. I will do further testing and open a new issue if required.
comment:4 by , 3 years ago
I can give more samples... Most of them are fixed when copying to mp4! So that means the bug is in MPEG-TS part maybe in keyframes marking in TS itself.
Also you can try to revert fbb283cfefb1865375718c4a56ce608d96a4a8ed that marks Clean Random Access recovery points as keyframes.
comment:5 by , 3 years ago
I tried reverting (fbb283cfefb1865375718c4a56ce608d96a4a8ed) but did not fix the issue. I did not notice any difference at all.
comment:7 by , 3 years ago
Does this fix it? https://patchwork.ffmpeg.org/project/ffmpeg/patch/20190507032623.80375-1-ffmpeg@tmm1.net/
P.S. No, it does not (. should be changed to ->)
comment:8 by , 3 years ago
Also apparently the whole thing is so complex, it is crazy. https://patchwork.ffmpeg.org/project/ffmpeg/patch/20220218232001.345826-5-u@pkh.me/
Patset was applied, did not help.
P.S. That patch needed to be additionally fixed further: d1b96c380826c505a8c7e655b5ad4fdb0c2de167
comment:9 by , 3 years ago
Another such patch touching the same code!!
https://patchwork.ffmpeg.org/project/ffmpeg/patch/20190831101039.2179-2-fumoboy007@me.com/
There are some comments as to how seeking for a real keyframe should work: https://patchwork.ffmpeg.org/project/ffmpeg/patch/20190831101039.2179-1-fumoboy007@me.com/
The bug is that you need to continue searching for keyframes after finding one, because there may be one closer. In mp4 that all happens correctly.
comment:10 by , 2 years ago
Priority: | important → normal |
---|
Is this issue only reproducible with ffplay or also with ffmpeg, the application?
comment:11 by , 2 years ago
Maybe by trying exporting a specific frame (which will be a gray / broken as it will fail to seek on keyframe)
ffmpeg -ss 00:00:20 -analyzeduration 100000000000 -probesize 100000000000 -i "LG Chess 4K Demo.ts" -frames:v 1 out.jpg -loglevel debug
comment:12 by , 2 years ago
SuRGeoNix, I can confirm that command line produces bad image. I propose to use avif though to preserve 10 bit 420 samples losslessly (aside from top-left chroma siting flag, but that is just metadata): -crf 0 -cpu-used 0 out.avif
comment:13 by , 2 years ago
Resolution: | → duplicate |
---|---|
Status: | open → closed |
Should be tested again once #4888 is fixed - for H.264 several development iterations were necessary.
comment:14 by , 2 years ago
This is a separate issue! It looks like the artifacts happen on the corners of 4 tiles! Because this is Ateme file with 4 tiles.
comment:15 by , 2 years ago
Resolution: | duplicate |
---|---|
Status: | closed → reopened |
In other cases we do have separate issues for hevc and avc.
comment:17 by , 2 weeks ago
ffmpeg.exe -ss 00:00:20 -analyzeduration 100000000000 -probesize 100000000000 -i "LG Chess HDR.ts" -frames:v 1 -crf 0 -cpu-used 0 oufefefet.avif
now prints:
[mpegts @ 00000228db0d4640] Failed to allocate buffers for seekback
[mpegts @ 00000228db0d4640] stream 0 : no PTS found at end of file, duration not set
decrease it to -analyzeduration 1000000000 -probesize 1000000000
comment:18 by , 2 weeks ago
Cc: | added |
---|
͏ Well, could Windows CLI now even guess missing quotes of params..?
͏ “ffmpeg.exe ... -i LG Chess HDR.ts -frames:v 1 ...”
͏ [ ^ Mostly non-working. ]
comment:19 by , 2 weeks ago
Should be fixed by https://patchwork.ffmpeg.org/project/ffmpeg/patch/tencent_F0FFA7D46AAE13021C704BBEA60A508BE606@qq.com/
Although it would be better to drop as less as possible, that is check reference frame at block level.
comment:20 by , 2 weeks ago
If that is your patch then why the issue is not there when you remux the file to mp4?
I can confirm that, please see: #7950
It happens due to 4 tiles in the file.