Intel-media-driver и libva-intel-driver
Приветствую. Перейду сразу к сути: может кто-нибудь, пожалуйста, мне объяснить различия двух реализаций VA-API для интела? Есть машина с графикой HD Graphics (Kaby Lake) — обе реализации работают, но зачем-то же интел создал и поддерживает обе. Перелопатил весь гугл, но вразумительного ничего не нашёл (может плохо искал).
Одна (libva-intel-driver) является частью mesa, вторую (intel-media-driver) Intel написал и поддерживает с нуля.
В последней есть проприетарный код (его можно не использовать, но тогда фич будет меньше (1, 2).
Вот оно как. Спасибо. в техническом плане — те же яйца, только в профиль или всё-таки блоб будет лучше для того же Kabe Lake?
Одна (libva-intel-driver) является частью mesa, вторую (intel-media-driver) Intel написал и поддерживает с нуля.
Оба драйвера в Intel делали, и они частью Mesa не были.
В последней есть проприетарный код
В обоих есть. В intel/intel-vaapi-driver в какой-то момент забили на исходники и для более новых чипов стали класть просто уже скомпилированные шейдеры.
Если ты на практике разницы не видишь — монетку подбрось. А когда сломается — переключишься на другую реализацию.
вот я и хочу один раз переключиться и забыть. Думал, раз уж их разделили, то в этом был какой-то смысл. А тут выходит…
intel-media-driver однозначно лучше. В частности, с ним работает кодирование видео с помощью QuickSync — в 2 раза более лучшее качество по сравнению с libva-intel-driver и vaapi.
Ну тогда предположи что реализация из mesa переживёт посконно-супостатную из Интел и используй её.
ноут всё-равно менять скоро — поэтому решено — пусть на блобах остаток свой доживает!
а на какой чёрт они вообще этим занимаются? если оба блоба, оба от интела — ну сделали бы один драйвер, а не распылялись на всё подряд.
Вот это поворот. Мне всегда казалось, что один из Mesa, но да, действительно, ты прав, а я чушь спорол.
А нафига тогда эта чехарда?
Ооо вот это поворот. только сейчас обнаружил, что в Ubuntu 20.04 есть вообще 4 варианта:
Вот и попробуй разберись потом без ста грамм. Зоопарк развели какой-то…
Мне всегда казалось, что …, но да, действительно, ты прав, а я чушь спорол
да не, с абсолютной уверенностью пороть чушь для тебя это довольно обычное дело
ещё как мне кажется, при просмотре 4K на ютубе, вариант
export LIBVA_DRIVER_NAME=i965 chromium-browser export LIBVA_DRIVER_NAME=iHD chromium-browser ★★★★ ( 08.07.20 20:48:53 MSK )
Последнее исправление: superuser 08.07.20 20:54:16 MSK (всего исправлений: 6)
если оба блоба, оба от интела
Это не целиком блобы. Основная часть там с открытым кодом. Блобы там это как-бы прошивки для GPU. Для части шейдеров там исходники есть, для части нет.
Он и был долгое время один. Поддерживал почти что все железки, которые умели декодировать видео, кроме GMA 4500 и основанных на powervr. Проект по компьютерным меркам древний, ему скоро 11 лет уже будет.
Второй драйвер появился не так давно, в самом конце 2017, и в нём поддерживаются только чипы начиная с Broadwell и Skylake. Такое ощущение, что они заопенсорсили код, который делала команда драйверов под Windows. Похоже, у них в этих драйверах большей частью общий код. Поддержку новых чипов добавляют только в этот драйвер, а поддержку старых даже не завозили.
Старый драйвер с 2019 почти что не трогают, разве что какие-то багфиксы. Так что можно считать, что для новых чипов драйвер снова только один.
/cc intelfx
Благодаря за пояснения! Интел бы тоже мог на гитхабе об этом написать, но фиг вам, как говорится.
Name already in use
media-driver / README.md
- Go to file T
- Go to line L
- Copy path
- Copy permalink
Copy raw contents
Copy raw contents
Intel(R) Media Driver for VAAPI
The Intel(R) Media Driver for VAAPI is a new VA-API (Video Acceleration API) user mode driver supporting hardware accelerated decoding, encoding, and video post processing for GEN based graphics hardware.
The Intel(R) Media Driver for VAAPI is distributed under the MIT license with portions covered under the BSD 3-clause «New» or «Revised» License. You may obtain a copy of the License at MIT & BSD-3-Clause
For Ubuntu 16.04+
Equivalents for other distributions should work.
- Build and install LibVA
- Build and install GmmLib following GmmLib compatibility
- Get media repo and format the workspace folder as below (suggest the workspace to be a dedicated one for media driver build):
- Create build_media new folder under your workspace
then the workspace looks like below
This will install the following files (e.g. on Ubuntu):
For iHD_drv_video.so please export related LIBVA environment variables.
- BDW (Broadwell)
- SKL (Skylake)
- BXTx (BXT: Broxton, APL: Apollo Lake, GLK: Gemini Lake)
- KBLx (KBL: Kaby Lake, CFL: Coffe Lake, WHL: Whiskey Lake, CML: Comet Lake, AML: Amber Lake)
- ICL (Ice Lake)
- JSL (Jasper Lake) / EHL (Elkhart Lake)
- TGLx (TGL: Tiger Lake, RKL: Rocket Lake, ADL-S/P/N: Alder Lake, RPL-S/P: Raptor Lake)
- DG1/SG1
- Alchemist(DG2)/ATSM
Components and Features
Media driver contains three components as below
- Video decoding calls hardware-based decoder(VDBox) which provides fully-accelerated hardware video decoding to release the graphics engine for other operations.
- Video encoding supports two modes, one calls hardware-based encoder(VDEnc/Huc) to provide low power encoding, another one is hardware(PAK)+shader(media kernel+VME) based encoding. User could choose the mode through VA-API.
- Video processing supports several popular features by hardware-based video processor(VEBox/SFC) and shader(media kernel) based solution together.
Media driver supports two build types as below
- Full Feature Build is default driver build, which supports all feature by hardware accelerator and close source shaders(media kernel binaries). Ubuntu intel-media-va-driver-non-free package is generated from this build type.
- Free Kernel Build, enables fully open source shaders(media kernels) and hardware features but the features would be limited. Ubuntu intel-media-va-driver package is generated from this build type.
CODEC | Build Types | DG2/ATSM | DG1/SG1 | TGLx | EHL/JSL | ICL | KBLx | BXTx | SKL | BDW |
---|---|---|---|---|---|---|---|---|---|---|
AVC | Full-Feature Free-Kernel | D/E D/E | D/E/Es D/E | D/E/Es D/E | D/E D/E | D/E/Es D/E | D/E/Es D/E | D/E/Es D/E | D/E/Es D/E | D/Es D |
MPEG-2 | Full-Feature Free-Kernel | D D | D/Es D | D/Es D | D D | D/Es D | D/Es D | D D | D/Es D | D/Es D |
VC-1 | Full-Feature Free-Kernel | D | D | D | D | D | D | D | D | |
JPEG | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D D |
VP8 | Full-Feature Free-Kernel | D* D* | D D | D/Es D | D/Es D | D D | D D | D D | ||
HEVC 8bit | Full-Feature Free-Kernel | D/E D/E | D/E/Es D/E | D/E/Es D/E | D/E D/E | D/E/Es D/E | D/Es D | D/Es D | D/Es D | |
HEVC 8bit 422 | Full-Feature Free-Kernel | D/E D | D/Es D | D/Es D | D D | D/Es D | ||||
HEVC 8bit 444 | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | ||||
HEVC 10bit | Full-Feature Free-Kernel | D/E D/E | D/E/Es D/E | D/E/Es D/E | D/E D/E | D/E/Es D/E | D/Es D | D D | ||
HEVC 10bit 422 | Full-Feature Free-Kernel | D/E D | D/Es D | D/Es D | D D | D/Es D | ||||
HEVC 10bit 444 | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | ||||
HEVC 12bit | Full-Feature Free-Kernel | D D | D/Es D | D/Es D | ||||||
HEVC 12bit 422 | Full-Feature Free-Kernel | D D | D D | D D | ||||||
HEVC 12bit 444 | Full-Feature Free-Kernel | D D | D D | D D | ||||||
VP9 8bit | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D D | D D | ||
VP9 8bit 444 | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | ||||
VP9 10bit | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D D | |||
VP9 10bit 444 | Full-Feature Free-Kernel | D/E D/E | D/E D/E | D/E D/E | D/E D/E | D/E D/E | ||||
VP9 12bit | Full-Feature Free-Kernel | D D | D D | D D | ||||||
VP9 12bit 444 | Full-Feature Free-Kernel | D D | D D | D D | ||||||
AV1 8bit | Full-Feature Free-Kernel | D/E D/E | D D | D D | ||||||
AV1 10bit | Full-Feature Free-Kernel | D/E D/E | D D | D D |
- * VP8 decoding is only supported on TGL platform
- D — Hardware Decoding
- E — Hardware Encoding, Low Power Encoding(VDEnc/Huc)
- Es — Hardware(PAK) + Shader(media kernel+VME) Encoding
For more decoding and encoding features information, please refer to
Video Processing Features
CODEC | Build Types | DG2/ATSM | DG1/SG1 | TGLx | EHL/JSL | ICL | KBLx | BXTx | SKL | BDW |
---|---|---|---|---|---|---|---|---|---|---|
Blending | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
CSC | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
De-interlace | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes* Yes* | Yes Yes | Yes | Yes | Yes | Yes |
De-noise | Full-Feature Free-Kernel | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | |
Luma Key | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
Mirroring | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
ProcAmp | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
Rotation | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
Scaling | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
Sharpening | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
STD/E | Full-Feature Free-Kernel | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | |
TCC | Full-Feature Free-Kernel | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | |
Color fill | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | Yes |
Chroma Siting | Full-Feature Free-Kernel | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes Yes | Yes | Yes | Yes | |
HDR10 TM | Full-Feature Free-Kernel | Yes | Yes | Yes | Yes | |||||
3DLUT | Full-Feature Free-Kernel | Yes | Yes | Yes |
- * EHL/JSL only support BOB DI
- CSC: Color Space Conversion
- ProcAmp: brightness,contrast,hue,saturation
- STD/E: Skin Tone Detect & Enhancement
- TCC: Total Color Control
- HDR10 TM: HDR10 Tone Mapping
- 3DLUT: Three Dimensional Look Up Table
For more feature information, please refer to Supported video processing csc/scaling format
Media-driver supports few build types as described below. You could refer to the following settings to enable them.
- Full Feature Build: ENABLE_KERNELS=ON(Default) ENABLE_NONFREE_KERNELS=ON(Default)
- Free Kernel Build: ENABLE_KERNELS=ON ENABLE_NONFREE_KERNELS=OFF
- If trying to use pre-built open source kernel binaries, please add BUILD_KERNELS=OFF(Default).
- If trying to rebuild open source kernel from source code, please add BUILD_KERNELS=ON.
Media-driver requires special i915 kernel mode driver (KMD) version to support the following new platforms since upstream version of i915 KMD does not fully support them (pending patches upstream):
By default, media-driver builds against upstream i915 KMD and will miss support for the platforms listed above. To enable new platforms which require special i915 KMD and specify ENABLE_PRODUCTION_KMD=ON (default: OFF ) build configuration option.
Known Issues and Limitations
Intel(R) Media Driver for VAAPI is recommended to be built against gcc compiler v6.1 or later, which officially supported C++11.
SKL: Green or other incorrect color will be observed in output frames when using YV12/I420 as input format for csc/scaling/blending/rotation, etc. on Ubuntu 16.04 stock (with kernel 4.10). The issue can be addressed with the kernel patch: WaEnableYV12BugFixInHalfSliceChicken7
HuC firmware is necessary for AVC/HEVC/VP9 low power encoding bitrate control, including CBR, VBR, etc. As of now, HuC firmware support is disabled in Linux kernels by default. kernel command line option «i915.enable_guc=2» for HuC loading can be set e.g. by doing echo «options i915 enable_guc=2» > /etc/modprobe.d/i915.conf (as root). Mind that HuC firmware support presents in the following kernels for the specified platforms:
- APL/KBL: starting from kernel 4.11
- CFL: starting from kernel 4.15
- ICL: starting from kernel 5.2
- EHL/JSL: starting from kernel 5.8
- TGL: starting from kernel 5.9
- RKL/ADL-S/ADL-P: starting from kernel 5.17
- ADL-N/RPL-S/RPL-P: drm-tip
- DG1/SG1/Alchemist(DG2)/ATSM: intel-gpu/intel-gpu-i915-backports
(*) Other names and brands may be claimed as property of others.