Opened 8 years ago
Last modified 5 years ago
#6276 new defect
h264_vaapi & nvenc do not preserve aspect ratio changes
Reported by: | TomB | Owned by: | |
---|---|---|---|
Priority: | normal | Component: | avcodec |
Version: | git-master | Keywords: | vaapi nvenc aspect |
Cc: | a, linjie.fu@intel.com | Blocked By: | |
Blocking: | Reproduced by developer: | yes | |
Analyzed by developer: | no |
Description
ffmpeg output:
ffmpeg version 3.2.4 Copyright (c) 2000-2017 the FFmpeg developers
built with gcc 6.3.1 (GCC) 20170109
configuration: --prefix=/usr --disable-debug --disable-static --disable-stripping --enable-avisynth --enable-avresample --enable-fontconfig --enable-gmp --enable-gnutls --enable-gpl --enable-ladspa --enable-libass --enable-libbluray --enable-libfreetype --enable-libfribidi --enable-libgsm --enable-libiec61883 --enable-libmodplug --enable-libmp3lame --enable-libopencore_amrnb --enable-libopencore_amrwb --enable-libopenjpeg --enable-libopus --enable-libpulse --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libv4l2 --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxvid --enable-netcdf --enable-shared --enable-version3 --enable-x11grab
libavutil 55. 34.101 / 55. 34.101
libavcodec 57. 64.101 / 57. 64.101
libavformat 57. 56.101 / 57. 56.101
libavdevice 57. 1.100 / 57. 1.100
libavfilter 6. 65.100 / 6. 65.100
libavresample 3. 1. 0 / 3. 1. 0
libswscale 4. 2.100 / 4. 2.100
libswresample 2. 3.100 / 2. 3.100
libpostproc 54. 1.100 / 54. 1.100
Command:
ffmpeg -vaapi_device /dev/dri/renderD128 -hwaccel vaapi -i input.ts -y -g 30 -vf 'format=nv12,hwupload' -c:v h264_vaapi -qp 20 -sn out.ts
The input file is available at https://r.je/tmp/input.ts (apologies this is a 900mb file) with a change in aspect ratio from 16:9 to 4:3 at 3:28
When using h264_vaapi as the codec, it doens't maintain the aspect ratio change, however the aspect ratio change is maintained if using libx264
Using libx264, the aspect change is copied into the output file.
Note: The same bug happens when using h264_nvenc.
Attachments (1)
Change History (15)
comment:1 by , 6 years ago
follow-up: 3 comment:2 by , 6 years ago
Component: | ffmpeg → undetermined |
---|---|
Keywords: | ratio removed |
Looks a little invalid as two bugs are reported, neither against current FFmpeg git head...
follow-up: 4 comment:3 by , 6 years ago
Replying to cehoyos:
I test with
ffmpeg -i aspect_ratio_change_cut.ts -vf fps=1 out_%3d.jpeg
and the out_0001.jpeg out_0002.jpeg out_0003.jpeg out_0004.jpeg is 720x576 , is it means this issue persists in master?
follow-up: 5 comment:4 by , 6 years ago
Replying to zhuqingliang:
Replying to cehoyos:
I test with
ffmpeg -i aspect_ratio_change_cut.ts -vf fps=1 out_%3d.jpeg
The command line above looks different, what are you trying to test?
comment:5 by , 6 years ago
I try to reproduce this issue: "h264_vaapi & nvenc do not preserve aspect ratio changes".
follow-up: 7 comment:6 by , 6 years ago
Cc: | added |
---|---|
Component: | undetermined → avcodec |
Then why did you test with a different command line?
comment:7 by , 6 years ago
Replying to cehoyos:
Then why did you test with a different command line?
because when I tried with
ffmpeg -vaapi_device /dev/dri/renderD128 -hwaccel vaapi -i aspect_ratio_change_cut.ts -y -g 30 -vf 'format=nv12,hwupload' -c:v h264_vaapi -qp 20 -sn out.ts
failed with error message
[AVHWFramesContext @ 0x556ae298be00] Failed to sync surface 0x4: 23 (internal decoding error). [mpeg2video @ 0x556ae2707440] Failed to transfer data to output frame: -5.
comment:8 by , 5 years ago
Keywords: | amd added |
---|---|
Priority: | normal → important |
Version: | git-master → 4.1.4 |
I am having this problem with 4.1.4 version also. Using Ubuntu 19.10 and AMD POLARIS10 GPU.
Here is a 6MB test file (720x576 (AR 16:9)) (~6mb)
https://drive.google.com/file/d/1-IDAYhfj93aPJPizWKttpfGV-KVPKKSx/view
The output file ends up as (720x576) only without AR setting. (~1mb)
https://drive.google.com/file/d/1mHbzcrAbN2zHVCgEkUTlqTDyCyC6yvPw/view
Setting --aspect 16:9 does not seem to do anything. Below is sample output from ffmpeg.
/usr/bin/ffmpeg -vaapi_device /dev/dri/renderD128 -i yks.ts -vf 'yadif,format=nv12,hwupload' -c:v h264_vaapi -c:a copy out.ts ffmpeg version 4.1.4-1build2 Copyright (c) 2000-2019 the FFmpeg developers built with gcc 9 (Ubuntu 9.2.1-4ubuntu1) configuration: --prefix=/usr --extra-version=1build2 --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --arch=amd64 --enable-gpl --disable-stripping --enable-avresample --disable-filter=resample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libaom --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libjack --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-libpulse --enable-librsvg --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-lv2 --enable-omx --enable-openal --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-libx264 --enable-shared libavutil 56. 22.100 / 56. 22.100 libavcodec 58. 35.100 / 58. 35.100 libavformat 58. 20.100 / 58. 20.100 libavdevice 58. 5.100 / 58. 5.100 libavfilter 7. 40.101 / 7. 40.101 libavresample 4. 0. 0 / 4. 0. 0 libswscale 5. 3.100 / 5. 3.100 libswresample 3. 3.100 / 3. 3.100 libpostproc 55. 3.100 / 55. 3.100 [mpegts @ 0x560df48a61c0] PES packet size mismatch Input #0, mpegts, from 'yks.ts': Duration: 00:00:10.85, start: 31818.542544, bitrate: 5027 kb/s Program 1 Metadata: service_name : Liv service_provider: Nelonen Stream #0:0[0x204]: Video: mpeg2video (Main) ([2][0][0][0] / 0x0002), yuv420p(tv, bt470bg, top first), 720x576 [SAR 64:45 DAR 16:9], 25 fps, 25 tbr, 90k tbn, 50 tbc Stream #0:1[0x2b2](fin): Audio: mp2 ([4][0][0][0] / 0x0004), 48000 Hz, stereo, s16p, 192 kb/s File 'out.ts' already exists. Overwrite ? [y/N] y Stream mapping: Stream #0:0 -> #0:0 (mpeg2video (native) -> h264 (h264_vaapi)) Stream #0:1 -> #0:1 (copy) Press [q] to stop, [?] for help [h264_vaapi @ 0x560df48adc80] Driver does not support some wanted packed headers (wanted 0xd, found 0). Output #0, mpegts, to 'out.ts': Metadata: encoder : Lavf58.20.100 Stream #0:0: Video: h264 (h264_vaapi) (High), vaapi_vld, 720x576 [SAR 64:45 DAR 16:9], q=-1--1, 25 fps, 90k tbn, 25 tbc Metadata: encoder : Lavc58.35.100 h264_vaapi Stream #0:1(fin): Audio: mp2 ([4][0][0][0] / 0x0004), 48000 Hz, stereo, s16p, 192 kb/s [mpegts @ 0x560df48a61c0] PES packet size mismatch:00:10.52 bitrate=2790.9kbits/s speed=6.98x frame= 261 fps=168 q=-0.0 Lsize= 3942kB time=00:00:10.80 bitrate=2990.2kbits/s speed=6.95x video:3372kB audio:248kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 8.896013%
comment:9 by , 5 years ago
Priority: | important → normal |
---|---|
Version: | 4.1.4 → git-master |
comment:10 by , 5 years ago
Keywords: | amd removed |
---|
comment:11 by , 5 years ago
Cc: | added |
---|---|
Reproduced by developer: | set |
The sync Surface error seems to be relevant with the input clips.
The last several frames of aspect_ratio_change_cut.ts is not good.
Simply cut these frames and the reported description could be observed.
ffmpeg -i aspect_ratio_change_cut.ts -c:v copy -vframes 80 80_aspect_ratio_change_cut.h264
No aspect ratio change with vaapi encode:
ffmpeg -vaapi_device /dev/dri/renderD128 -hwaccel vaapi -i 80_aspect_ratio_change_cut.h264 -y -g 30 -vf 'format=nv12,hwupload' -c:v h264_vaapi -qp 20 -sn out.ts
Aspect ratio change observed with x264:
ffmpeg -hwaccel vaapi -i 80_aspect_ratio_change_cut.h264 -y -g 30 -c:v libx264 -qp 20 -sn out_x264.ts
In libx264, reconfig_encoder() modified the SPS during encoding procedure when sample_aspect_ratio changes.
Similar behavior could be added in VAAPI.
follow-up: 13 comment:12 by , 5 years ago
Hi yurtesen/Carl,
This patch helps to preserve the aspect ratio changes for VAAPI:
https://patchwork.ffmpeg.org/patch/16245/
Would you please help to verify?
BTW, similar issue existed in QSV. It could be addressed next.
ffmpeg -hwaccel vaapi -i 80_aspect_ratio_change_cut.h264 -y -g 30 -c:v h264_qsv -qp 20 -sn qsv.ts
comment:13 by , 5 years ago
Replying to fulinjie:
Hi yurtesen/Carl,
This patch helps to preserve the aspect ratio changes for VAAPI:
https://patchwork.ffmpeg.org/patch/16245/
Would you please help to verify?
BTW, similar issue existed in QSV. It could be addressed next.
ffmpeg -hwaccel vaapi -i 80_aspect_ratio_change_cut.h264 -y -g 30 -c:v h264_qsv -qp 20 -sn qsv.ts
Patched it and it still ends mangled [amdgpu]
sample file: [40MB] https://send.firefox.com/download/c48ebf7304f8a60f/#i5ZJ3Zdz1rjnz8lBxgjeaQ
end result: [27MB] https://send.firefox.com/download/42933b87d649abee/#2CJQHnxFiF6FV8F1PnHsIw
comment:14 by , 5 years ago
another one
sample: https://send.firefox.com/download/59da97f53074be4e/#wCPgaoWYuGNypLxrW7-NzA
output: https://send.firefox.com/download/456bfea4d1f3ef2e/#ev4es56EYiGStN7SnvQgUA
changes from x1036 to x1040 and introduces green line at the bottom
forcing size via vaapi_scale doesn't work and introduces additional glitch in the beginning
-hwaccel_output_format vaapi \
-c:v hevc_vaapi -qp 26 \
-c:a copy -c:s copy -f matroska
Posting here since it was marked as duplicate of this #8376
I try to reproduce this issue on my platform , but can't download https://r.je/tmp/input.ts , can you upload it again?