Jianhui Dai | aa45503 | 2023-12-05 18:06:19 | [diff] [blame] | 1 | **This document is deprecated. See |
| 2 | [vaapi.md](https://source.chromium.org/chromium/chromium/src/+/main:docs/gpu/vaapi.md) |
| 3 | instead.** |
| 4 | |
nodir | a6074d4c | 2015-09-01 04:26:45 | [diff] [blame] | 5 | # Enabling hardware <video> decode codepaths on linux |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 6 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 7 | Hardware acceleration of video decode on Linux is |
| 8 | [unsupported](https://crbug.com/137247) in Chrome for user-facing builds. During |
| 9 | development (targeting other platforms) it can be useful to be able to trigger |
| 10 | the code-paths used on HW-accelerated platforms (such as CrOS and win7) in a |
| 11 | linux-based development environment. Here's one way to do so, with details based |
| 12 | on a gprecise setup. |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 13 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 14 | * Install pre-requisites: On Ubuntu Precise, at least, this includes: |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 15 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 16 | ```shell |
| 17 | sudo apt-get install libtool libvdpau1 libvdpau-dev |
| 18 | ``` |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 19 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 20 | * Install and configure [libva](http://cgit.freedesktop.org/libva/) |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 21 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 22 | ```shell |
| 23 | DEST=${HOME}/apps/libva |
| 24 | cd /tmp |
| 25 | git clone git://anongit.freedesktop.org/libva |
| 26 | cd libva |
| 27 | git reset --hard libva-1.2.1 |
| 28 | ./autogen.sh && ./configure --prefix=${DEST} |
| 29 | make -j32 && make install |
| 30 | ``` |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 31 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 32 | * Install and configure the |
| 33 | [VDPAU](http://cgit.freedesktop.org/vaapi/vdpau-driver) VAAPI driver |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 34 | |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 35 | ```shell |
| 36 | DEST=${HOME}/apps/libva |
| 37 | cd /tmp |
| 38 | git clone git://anongit.freedesktop.org/vaapi/vdpau-driver |
| 39 | cd vdpau-driver |
| 40 | export PKG_CONFIG_PATH=${DEST}/lib/pkgconfig/:$PKG_CONFIG_PATH |
| 41 | export LIBVA_DRIVERS_PATH=${DEST}/lib/dri |
| 42 | export LIBVA_X11_DEPS_CFLAGS=-I${DEST}/include |
| 43 | export LIBVA_X11_DEPS_LIBS=-L${DEST}/lib |
| 44 | export LIBVA_DEPS_CFLAGS=-I${DEST}/include |
| 45 | export LIBVA_DEPS_LIBS=-L${DEST}/lib |
| 46 | make distclean |
| 47 | unset CC CXX |
| 48 | ./autogen.sh && ./configure --prefix=${DEST} --enable-debug |
| 49 | find . -name Makefile |xargs sed -i 'sI/usr/lib/xorg/modules/driversI${DEST}/lib/driIg' |
| 50 | sed -i -e 's/_(\(VAEncH264VUIBufferType\|VAEncH264SEIBufferType\));//' src/vdpau_dump.c |
| 51 | make -j32 && rm -f ${DEST}/lib/dri/{nvidia_drv_video.so,s3g_drv_video.so} && make install |
| 52 | ``` |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 53 | |
Daniel Bratell | f73f0df | 2018-09-24 13:52:49 | [diff] [blame] | 54 | * Add to args.gn: |
| 55 | * `target_os = "chromeos"` to link in `VaapiVideoDecodeAccelerator` |
| 56 | * `proprietary_codecs = true` and `ffmpeg_branding = "Chrome"` to |
| 57 | allow Chrome to play h.264 content, which is the only codec |
| 58 | VAVDA knows about today. |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 59 | * Rebuild chrome |
| 60 | * Run chrome with `LD_LIBRARY_PATH=${HOME}/apps/libva/lib` in the environment, |
| 61 | and with the `--no-sandbox` command line flag. |
| 62 | * If things don't work, a Debug build (to include D\*LOG's) with |
| 63 | `--vmodule=*content/common/gpu/media/*=10,gpu_video*=1` might be |
| 64 | enlightening. |
andybons | 3322f76 | 2015-08-24 21:37:09 | [diff] [blame] | 65 | |
nodir | a6074d4c | 2015-09-01 04:26:45 | [diff] [blame] | 66 | ** note |
| 67 | NOTE THIS IS AN UNSUPPORTED CONFIGURATION AND LIKELY TO BE BROKEN AT ANY |
| 68 | POINT IN TIME |
| 69 | ** |
andybons | ad92aa3 | 2015-08-31 02:27:44 | [diff] [blame] | 70 | |
| 71 | This page is purely here to help developers targeting supported HW `<video>` |
| 72 | decode platforms be more effective. Do not expect help if this setup fails to |
| 73 | work. |