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 SuRGeoNix, 3 years ago

Keywords: mpegts added

comment:2 by Balling, 3 years ago

Status: newopen

I can confirm that, please see: #7950

It happens due to 4 tiles in the file.

Last edited 3 years ago by Balling (previous) (diff)

comment:3 by SuRGeoNix, 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 Balling, 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.

Version 0, edited 3 years ago by Balling (next)

comment:5 by SuRGeoNix, 3 years ago

I tried reverting (fbb283cfefb1865375718c4a56ce608d96a4a8ed) but did not fix the issue. I did not notice any difference at all.

comment:7 by Balling, 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 ->)

Last edited 3 years ago by Balling (previous) (diff)

comment:8 by Balling, 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

Last edited 2 weeks ago by Balling (previous) (diff)

comment:9 by Balling, 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.

Last edited 3 years ago by Balling (previous) (diff)

comment:10 by Carl Eugen Hoyos, 2 years ago

Priority: importantnormal

Is this issue only reproducible with ffplay or also with ffmpeg, the application?

comment:11 by SuRGeoNix, 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 Balling, 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 Carl Eugen Hoyos, 2 years ago

Resolution: duplicate
Status: openclosed

Should be tested again once #4888 is fixed - for H.264 several development iterations were necessary.

comment:14 by Balling, 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.

Last edited 2 years ago by Balling (previous) (diff)

comment:15 by Balling, 2 years ago

Resolution: duplicate
Status: closedreopened

In other cases we do have separate issues for hevc and avc.

comment:16 by Balling, 15 months ago

Still happens

comment:17 by Balling, 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

Last edited 2 weeks ago by Balling (previous) (diff)

comment:18 by MasterQuestionable, 2 weeks ago

Cc: MasterQuestionable 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 quinkblack, 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 Balling, 2 weeks ago

If that is your patch then why the issue is not there when you remux the file to mp4?

Note: See TracTickets for help on using tickets.