You are not logged in.
After setting "Enable software compositing window manager" on
It enabled to VDAVideoDecoder youtube
But, screen is black. what's wrong?
Are you using the unstable version 97? you should revert to stable version 96, and enable the flags that I mentioned above. VDAVideoDecoder is working fine on it.
Offline

My current system specs:
thanks Inix.
I have my specs also working now:
Graphics:  Device-1: NVIDIA GM204GL [Quadro M5000]  driver: nvidia v: 495.44   Display: server: X.Org 1.21.1.1
Kernel: 5.10.80-1-lts x86_64 bits: 64 Distro: Arch Linux
Google-chrome stable (AUR) Version : 96.0.4664.45-1- Enabled extension
enhanced-h264ify enabled https://chrome.google.com/webstore/deta … ated?hl=en
- Flags: /home/boban/.config/chrome-flags.conf
--use-gl=desktop
--use-cmd-decoder=validating
--disable-software-rasterizer
--disable-font-subpixel-positioning
--disable-gpu-driver-bug-workarounds
--disable-gpu-driver-workarounds
--disable-gpu-vsync
--enable-accelerated-video-decode
--enable-accelerated-mjpeg-decode
--enable-features=VaapiVideoDecoder,CanvasOopRasterization
--enable-gpu-compositing
--enable-gpu-rasterization
--enable-native-gpu-memory-buffers
--enable-oop-rasterization
--canvas-oop-rasterization
--enable-raw-draw
--use-vulkan
--enable-zero-copy
--ignore-gpu-blocklist
--check-for-update-interval=604800- Result chrome://gpu
Graphics Feature Status
Canvas: Hardware accelerated
Canvas out-of-process rasterization: Enabled
Compositing: Hardware accelerated
Multiple Raster Threads: Enabled
Out-of-process Rasterization: Hardware accelerated
OpenGL: Enabled
Rasterization: Hardware accelerated on all pages
Raw Draw: Disabled
Skia Renderer: Enabled
Video Decode: Hardware accelerated
Vulkan: Enabled
WebGL: Hardware accelerated
WebGL2: Hardware accelerated
- Check in chrome with youtube video:
Last edited by boban_dj (2022-01-21 07:47:10)
Offline
Inixi wrote:My current system specs:
thanks Inix.
I have my specs also working now:
Graphics: Device-1: NVIDIA GM204GL [Quadro M5000] driver: nvidia v: 495.44 Display: server: X.Org 1.21.1.1 Kernel: 5.10.80-1-lts x86_64 bits: 64 Distro: Arch Linux Google-chrome stable (AUR) Version : 96.0.4664.45-1- Enabled extension
enhanced-h264ify enabled https://chrome.google.com/webstore/deta … ated?hl=en
Well, hardware accelerated youtube should also work without the extension. On youtube I like to have the extension disabled because some "premiere" videos without the extension have possibility to run in FHD while with extension sometimes 480p is only available option for long time.
2020 ASUS Zephyrus G14
Offline

@Inixi, strange because in my case hardware accelerated works only with the extension enhanced-h264ify enabled. this with all youtube video's you linked in previous post.
Is there something I missed? or how to check it
Offline
Chromium 96.0.4664.45 now supports VA-API on Wayland perfectly with `--use-gl=egl` and no LIBVA_DRIVER_NAME env override. The only missing link now is MESA ANGLE sync control to provide predictable VSYNC for EGL application.
This is not just for Chromium, I think Firefox VA-API backend on Wayland also benefits from predictable VSYNC from EGL interface.
I hope ArchLinux MESA package maintainers will take the patch from MESA pending MR. Please cast your vote to have the voices in solidarity.
https://bugs.archlinux.org/task/67035
Offline
Chromium 96.0.4664.45 now supports VA-API on Wayland perfectly with `--use-gl=egl` and no LIBVA_DRIVER_NAME env override.
When you say "on Wayland" - do you mean that you are using the Wayland backend for Ozone (i.e. `--enable-features=UseOzonePlatform --ozone-platform=wayland`)
If so that's news to me, and not what the wiki sais. What flags are you running exactly? I could not get VAAPI to work with the Wayland backend.
Offline
liewkj wrote:Chromium 96.0.4664.45 now supports VA-API on Wayland perfectly with `--use-gl=egl` and no LIBVA_DRIVER_NAME env override.
When you say "on Wayland" - do you mean that you are using the Wayland backend for Ozone (i.e. `--enable-features=UseOzonePlatform --ozone-platform=wayland`)
If so that's news to me, and not what the wiki sais. What flags are you running exactly? I could not get VAAPI to work with the Wayland backend.
No, with use-gl=egl Ozone is on X11, so XWayland. Nothing has changed.
Offline
I confirm, cpu decoding on AMDGPU with
--ozone-platform=waylandflag under Wayland.
Last edited by digitalone (2021-11-29 21:45:22)
Offline
In chromium-flags.conf
--disable-gpu-driver-bug-workarounds
--enable-oop-rasterization
--use-gl=egl
From chrome://gpu Command Line
/usr/lib/chromium/chromium --disable-gpu-driver-bug-workarounds --enable-oop-rasterization --use-gl=egl --enable-crashpad --flag-switches-begin --enable-gpu-rasterization --enable-zero-copy --ignore-gpu-blocklist --enable-features=CanvasOopRasterization,VaapiVideoDecoder --flag-switches-end --origin-trial-disabled-features=CaptureHandle
Options around --flag-switches-begin/end are selected through chrome://flags. They will be saved by Chromium.
There is really nothing to mess with ozone what so ever. It has always been XWayland for Chromium and how Chromium VA-API on Wayland session has worked in the past before it was broken. In fact, EGL window system binding can be considered native for Wayland.
I have tested that it works on both Intel and AMD for both H.264 and VP9. For Intel, the H.264/VP9 video decode uses Intel i965/hybrid VA driver.
Core i3-4010U Haswell GT2
Core m3 6Y30 Skylake GT2
Ryzen 2500U Vega Graphics
The wiki isn't up-to-date. For VA-API discussion, it is crucial to include details of GPU and XDG_SESSION_TYPE. It is great to see another improvement in Wayland, the future of Linux desktop.
Offline
I'm curious if anyone else notices similar behavior to what I'm seeing, as it is a trifle annoying and I'm flummoxed on how (if it's even possible) to fix it. Background is that I'm using an Intel GPU and have VAAPI working, hardware acceleration, yada yada. Using fully branded Chrome.
Now, my specific issue is that when I leave a video paused for a short time, the paused video goes black. It sounds less annoying than it is, particularly when I pause a video intentionally because I want to read something in it (I do a lot of online classes, for example).
Anyone else seen this?
Offline
There is really nothing to mess with ozone what so ever. It has always been XWayland for Chromium and how Chromium VA-API on Wayland session has worked in the past before it was broken. In fact, EGL window system binding can be considered native for Wayland.
On Wayland compositors Ozone will default to Wayland rather than X11 in the future to avoid XWayland, so vaapi support is likely to be broken again in the next versions.
Offline
I have two systems, one running X11, and another runs Wayland. Chromium on X11 works fine with just enabling necessary flags. On Wayland though, I have to add --use-gl=egl to enable VDAVideoDecoder. However, after playing any video for a few minutes, whole of the system starts to lag, and then I have to no other option but to force shut down the system. Anyone else facing similar problem?
Offline
Hi everyone,
I've managed to make HW decoding work but encoding seem to be not working. Could you please help me to make it work?
I have a very high CPU load when I share my screen via Slack (70%-80%) and I hope to make it lower.
Hardware: Thinkpad X1 Carbon Gen6 with Intel(R) UHD Graphics 620.
I'm using these chrome flags:
--ignore-gpu-blocklist
--enable-gpu-rasterization
--enable-zero-copy
--disable-gpu-driver-bug-workarounds
--disable-features=UseSkiaRenderer
--enable-features=VaapiVideoDecoder
--use-vulkan
and this package:
intel-media-driver
Here is my vainfo output:
vainfo: VA-API version: 1.13 (libva 2.13.0)
vainfo: Driver version: Intel iHD driver for Intel(R) Gen Graphics - 21.4.3 ()
vainfo: Supported profile and entrypoints
      VAProfileNone                   :    VAEntrypointVideoProc
      VAProfileNone                   :    VAEntrypointStats
      VAProfileMPEG2Simple            :    VAEntrypointVLD
      VAProfileMPEG2Simple            :    VAEntrypointEncSlice
      VAProfileMPEG2Main              :    VAEntrypointVLD
      VAProfileMPEG2Main              :    VAEntrypointEncSlice
      VAProfileH264Main               :    VAEntrypointVLD
      VAProfileH264Main               :    VAEntrypointEncSlice
      VAProfileH264Main               :    VAEntrypointFEI
      VAProfileH264Main               :    VAEntrypointEncSliceLP
      VAProfileH264High               :    VAEntrypointVLD
      VAProfileH264High               :    VAEntrypointEncSlice
      VAProfileH264High               :    VAEntrypointFEI
      VAProfileH264High               :    VAEntrypointEncSliceLP
      VAProfileVC1Simple              :    VAEntrypointVLD
      VAProfileVC1Main                :    VAEntrypointVLD
      VAProfileVC1Advanced            :    VAEntrypointVLD
      VAProfileJPEGBaseline           :    VAEntrypointVLD
      VAProfileJPEGBaseline           :    VAEntrypointEncPicture
      VAProfileH264ConstrainedBaseline:    VAEntrypointVLD
      VAProfileH264ConstrainedBaseline:    VAEntrypointEncSlice
      VAProfileH264ConstrainedBaseline:    VAEntrypointFEI
      VAProfileH264ConstrainedBaseline:    VAEntrypointEncSliceLP
      VAProfileVP8Version0_3          :    VAEntrypointVLD
      VAProfileVP8Version0_3          :    VAEntrypointEncSlice
      VAProfileHEVCMain               :    VAEntrypointVLD
      VAProfileHEVCMain               :    VAEntrypointEncSlice
      VAProfileHEVCMain               :    VAEntrypointFEI
      VAProfileHEVCMain10             :    VAEntrypointVLD
      VAProfileHEVCMain10             :    VAEntrypointEncSlice
      VAProfileVP9Profile0            :    VAEntrypointVLD
      VAProfileVP9Profile2            :    VAEntrypointVLD
chrome://gpu "Video Acceleration Information" section:
Decoding (VideoDecoder)    
Decode h264 baseline    16x16 to 4096x4096 pixels
Decode h264 main    16x16 to 4096x4096 pixels
Decode h264 high    16x16 to 4096x4096 pixels
Decode vp8    16x16 to 4096x4096 pixels
Decode vp9 profile0    16x16 to 8192x8192 pixels
Decoding (Legacy VideoDecodeAccelerator)    
Decode h264 baseline    16x16 to 4096x4096 pixels
Decode h264 main    16x16 to 4096x4096 pixels
Decode h264 high    16x16 to 4096x4096 pixels
Decode vp8    16x16 to 4096x4096 pixels
Decode vp9 profile0    16x16 to 8192x8192 pixels
Encoding
(Nothing here)
Offline
Hey friends, following up on my previous post where I asked if anyone had issues with paused videos going blank, I think I've stumbled on a fix. I've added the following to my chrome flags:
--use-gl=desktopHopefully this helps. Cheers.
Offline
Side note: the VDAVideoDecoder problem will persist if your browser uses Mesa driver version 21.2.4 or less. You should update it to at lease 21.2.5 or the latest 21.3.1.
Last edited by moturhead (2021-12-09 13:13:35)
Offline
@Inixi, strange because in my case hardware accelerated works only with the extension enhanced-h264ify enabled. this with all youtube video's you linked in previous post.
Is there something I missed? or how to check it
There are few clarifications needed:
1. In fact, not all videos on youtube are hardware accelerated without the extension, some of them are software rendered even with the flags I recently mentioned. Enhanced-h264ify makes all of them hardware accelerated on youtube. Why is that? I don't know, probably because proprietary support for x265 is still limited.
2. Following flags make chromium unstable, meaning that browser can freeze, reload, invoke core dump or hang the desktop manager. I'm still figuring out which of them can be applied safely.
--use-gl=desktop
--enable-features=VaapiVideoDecoder
--enable-zero-copy
--enable-accelerated-video-decode2020 ASUS Zephyrus G14
Offline
1. In fact, not all videos on youtube are hardware accelerated without the extension, some of them are software rendered even with the flags I recently mentioned. Enhanced-h264ify makes all of them hardware accelerated on youtube. Why is that?
My guess is that those are served in AV1 codec, which your card doesn't support according to the table on the wiki page.
In one of your previous posts you mentioned this "strange" YT video 8K Sample Video | Alpha 1 | Sony | α. If we RMB click on the video and choose "Stats for nerds", we can see what codec is being served. For this video 8k and 1080p are served in AV1, and are not accelerated, but 4k and 1440p --- in VP9 --- are. This is consistent with what the above table tells about codec support. So no HW accel for AV1 if you have NVIDIA card lower than the current gen GTX 30** series.
Offline
Thanks @temkyn ! 
I recently played with ffmpeg encoding and I just realized that not all codecs can be hardware decoded by nvidia cards, but I did not know how to check youtube.
2020 ASUS Zephyrus G14
Offline
does 97 improve --enable-features=UseOzonePlatform --ozone-platform=wayland?
Offline
does 97 improve --enable-features=UseOzonePlatform --ozone-platform=wayland?
there is 'Preferred Ozone platform' flag, so no longer necessary set --enable, btw.
Offline
I have new data on 97.0.4692.71-2 version
GPU: RTX 2060 Max-Q
desktop: Gnome on Xorg
nvidia drivers: 495.46-7
kernel: 5.15.10-xanmod1-rog-1
My current flags:
--use-vulkan
--use-gl=desktop
--enable-zero-copy
--enable-hardware-overlays
--enable-features=VaapiVideoDecoder,CanvasOopRasterization
--disable-features=UseSkiaRenderer
--ignore-gpu-blocklistWhich gives me:
Canvas: Hardware accelerated
Canvas out-of-process rasterization: Disabled
Compositing: Hardware accelerated
Multiple Raster Threads: Enabled
Out-of-process Rasterization: Hardware accelerated
OpenGL: Enabled
Rasterization: Software only. Hardware acceleration disabled
Raw Draw: Disabled
Skia Renderer: Disabled
Video Decode: Hardware accelerated
Video Encode: Software only. Hardware acceleration disabled
Vulkan: Enabled
WebGL: Hardware accelerated
WebGL2: Hardware accelerated
All of my videos in browser except AV1 are hardware accelerated, but that comes with some caveats:
My monitor has 120Hz refresh rate and using --use-gl=desktop makes possible to use only 60fps. When I don't use this option then all my accelerated videos are black.
Enabling --use-gl=desktop makes chromium unstable even when not using --disable-gpu-driver-bug-workarounds or --ignore-gpu-blocklist switches. When chromium is unstable it can freeze and then the only way is to SIGKILL whole browser or it can restart itself generating segfault error 4 in libnvidia-glcore.so.495.46..
libva-vdpau-driver-vp9-git enables encoding not only h264 videos, but also VP9 videos as well.
--enable-gpu-rasterization is only available when you want to use with Skia renderer. If you disable Skia renderer and enable GPU rasterization then you will be having a lot of errors regarding Skia renderer failing to compile. In practice this can lead to make Rasterization status in chrome:///gpu green but you won't feel any difference. This means that Skia renderer is still incompatible with Hardware Video Decode.
--ignore-gpu-blocklist makes browser even more unstable, but in exchange you cna watch 4K VP9 videos on nvidia (probably other video cards as well).
Last edited by Inixi (2022-01-14 02:27:23)
2020 ASUS Zephyrus G14
Offline
So... it's broken again in version 98. They have a new item in the list at chrome://gpu:
Direct Rendering Display Compositor: Disabled
Maybe that has something to do with it...
Offline
this is my vainfo output:
vainfo: VA-API version: 1.13 (libva 2.13.0)
vainfo: Driver version: Intel i965 driver for Intel(R) Broadwell - 2.4.1
vainfo: Supported profile and entrypoints
      VAProfileMPEG2Simple            : VAEntrypointVLD
      VAProfileMPEG2Simple            : VAEntrypointEncSlice
      VAProfileMPEG2Main              : VAEntrypointVLD
      VAProfileMPEG2Main              : VAEntrypointEncSlice
      VAProfileH264ConstrainedBaseline: VAEntrypointVLD
      VAProfileH264ConstrainedBaseline: VAEntrypointEncSlice
      VAProfileH264Main               : VAEntrypointVLD
      VAProfileH264Main               : VAEntrypointEncSlice
      VAProfileH264High               : VAEntrypointVLD
      VAProfileH264High               : VAEntrypointEncSlice
      VAProfileH264MultiviewHigh      : VAEntrypointVLD
      VAProfileH264MultiviewHigh      : VAEntrypointEncSlice
      VAProfileH264StereoHigh         : VAEntrypointVLD
      VAProfileH264StereoHigh         : VAEntrypointEncSlice
      VAProfileVC1Simple              : VAEntrypointVLD
      VAProfileVC1Main                : VAEntrypointVLD
      VAProfileVC1Advanced            : VAEntrypointVLD
      VAProfileNone                   : VAEntrypointVideoProc
      VAProfileJPEGBaseline           : VAEntrypointVLD
      VAProfileVP8Version0_3          : VAEntrypointVLDin my chromium (from extra repo), there are this gpu config:
Graphics Feature Status
Canvas: Hardware accelerated
Canvas out-of-process rasterization: Enabled
Compositing: Hardware accelerated
Multiple Raster Threads: Enabled
Out-of-process Rasterization: Hardware accelerated
OpenGL: Enabled
Rasterization: Hardware accelerated on all pages
Raw Draw: Enabled
Skia Renderer: Enabled
Video Decode: Hardware accelerated
Video Encode: Software only. Hardware acceleration disabled
Vulkan: Enabled
WebGL: Hardware accelerated
WebGL2: Hardware acceleratedi used only 3 flags in config file:
--enable-gpu-rasterization
--ignore-gpu-backlist
--disable-gpu-driver-workaroundsi have activated any flags in the browser for enable all gpu option...i don't find option for enable video encode...so..intel_gpu_top give me always 0% on video
i have installed the plugin for h264 codec, but nothing...: https://imgbb.com/tMQf6Ld
Last edited by sephiroth986 (2022-01-20 13:07:57)
Offline

Please use code tags, don't crosspost and reply to https://bbs.archlinux.org/viewtopic.php … 9#p2016819 about what video you're actually being handed by youtube - the screenshot you keep posting isn't helpful.
Offline
Can hardware acceleration work on Youtube without NotYetAV1 or enhanced-h264ify extension?
Thanks.
Offline