From 390c1d4d498d53f6bb779b339472489b57f2df55 Mon Sep 17 00:00:00 2001 From: Lukas Rusak Date: Tue, 3 Apr 2018 15:07:25 -0700 Subject: VAAPI: add vp8 support --- addons/resource.language.en_gb/resources/strings.po | 13 ++++++++++++- system/settings/linux.xml | 12 ++++++++++++ xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp | 9 +++++++++ xbmc/settings/Settings.cpp | 1 + xbmc/settings/Settings.h | 1 + 5 files changed, 35 insertions(+), 1 deletion(-) diff --git a/addons/resource.language.en_gb/resources/strings.po b/addons/resource.language.en_gb/resources/strings.po index 00c38a659d..5367b6b3e5 100644 --- a/addons/resource.language.en_gb/resources/strings.po +++ b/addons/resource.language.en_gb/resources/strings.po @@ -7121,7 +7121,18 @@ msgctxt "#13452" msgid "Enable this option to use hardware acceleration for VC-1 based codecs. If disabled the CPU will be used instead. Especially VC-1 interlaced fails hard on Intel hardware." msgstr "" -#empty strings from id 13453 to 13456 +#: system/settings/settings.xml +msgctxt "#13453" +msgid "Use VP8 VAAPI" +msgstr "" + +#. Description of setting with label #13453 "Use VP8 VAAPI" +#: system/settings/settings.xml +msgctxt "#13454" +msgid "Enable this option to use hardware acceleration for the VP8 codec. If disabled the CPU will be used instead." +msgstr "" + +#empty strings from id 13455 to 13456 #. Option for video related setting #13454: sw filter #: system/settings/settings.xml diff --git a/system/settings/linux.xml b/system/settings/linux.xml index 4e3702d16c..1a017272d1 100644 --- a/system/settings/linux.xml +++ b/system/settings/linux.xml @@ -100,6 +100,18 @@ true + + HAVE_LIBVA + false + + + true + + + 3 + true + + HAVE_LIBVA false diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp index 3420ed13ce..9b960e6e1c 100644 --- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp +++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp @@ -505,6 +505,7 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A { AV_CODEC_ID_WMV3, CSettings::SETTING_VIDEOPLAYER_USEVAAPIVC1 }, { AV_CODEC_ID_VC1, CSettings::SETTING_VIDEOPLAYER_USEVAAPIVC1 }, { AV_CODEC_ID_MPEG2VIDEO, CSettings::SETTING_VIDEOPLAYER_USEVAAPIMPEG2 }, + { AV_CODEC_ID_VP8, CSettings::SETTING_VIDEOPLAYER_USEVAAPIVP8 }, }; auto entry = settings_map.find(avctx->codec_id); @@ -595,6 +596,13 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A return false; break; } + case AV_CODEC_ID_VP8: + { + profile = VAProfileVP8Version0_3; + if (!m_vaapiConfig.context->SupportsProfile(profile)) + return false; + break; + } case AV_CODEC_ID_VP9: { if (avctx->profile == FF_PROFILE_VP9_0) @@ -1197,6 +1205,7 @@ void CDecoder::Register(IVaapiWinSystem *winSystem, bool deepColor) CServiceBroker::GetSettings().GetSetting(CSettings::SETTING_VIDEOPLAYER_USEVAAPIMPEG4)->SetVisible(true); CServiceBroker::GetSettings().GetSetting(CSettings::SETTING_VIDEOPLAYER_USEVAAPIVC1)->SetVisible(true); CServiceBroker::GetSettings().GetSetting(CSettings::SETTING_VIDEOPLAYER_USEVAAPIMPEG2)->SetVisible(true); + CServiceBroker::GetSettings().GetSetting(CSettings::SETTING_VIDEOPLAYER_USEVAAPIVP8)->SetVisible(true); } //----------------------------------------------------------------------------- diff --git a/xbmc/settings/Settings.cpp b/xbmc/settings/Settings.cpp index c746bf0fa8..1fa1b3daf8 100644 --- a/xbmc/settings/Settings.cpp +++ b/xbmc/settings/Settings.cpp @@ -167,6 +167,7 @@ const std::string CSettings::SETTING_VIDEOPLAYER_USEVAAPI = "videoplayer.usevaap const std::string CSettings::SETTING_VIDEOPLAYER_USEVAAPIMPEG2 = "videoplayer.usevaapimpeg2"; const std::string CSettings::SETTING_VIDEOPLAYER_USEVAAPIMPEG4 = "videoplayer.usevaapimpeg4"; const std::string CSettings::SETTING_VIDEOPLAYER_USEVAAPIVC1 = "videoplayer.usevaapivc1"; +const std::string CSettings::SETTING_VIDEOPLAYER_USEVAAPIVP8 = "videoplayer.usevaapivp8"; const std::string CSettings::SETTING_VIDEOPLAYER_PREFERVAAPIRENDER = "videoplayer.prefervaapirender"; const std::string CSettings::SETTING_VIDEOPLAYER_USEDXVA2 = "videoplayer.usedxva2"; const std::string CSettings::SETTING_VIDEOPLAYER_USEOMXPLAYER = "videoplayer.useomxplayer"; diff --git a/xbmc/settings/Settings.h b/xbmc/settings/Settings.h index 9825e9aca8..6d4f20a3f2 100644 --- a/xbmc/settings/Settings.h +++ b/xbmc/settings/Settings.h @@ -121,6 +121,7 @@ public: static const std::string SETTING_VIDEOPLAYER_USEVAAPIMPEG2; static const std::string SETTING_VIDEOPLAYER_USEVAAPIMPEG4; static const std::string SETTING_VIDEOPLAYER_USEVAAPIVC1; + static const std::string SETTING_VIDEOPLAYER_USEVAAPIVP8; static const std::string SETTING_VIDEOPLAYER_PREFERVAAPIRENDER; static const std::string SETTING_VIDEOPLAYER_USEDXVA2; static const std::string SETTING_VIDEOPLAYER_USEOMXPLAYER; -- cgit v1.2.3