验证VP8 HW编码/解码是否真的在Linux上运行

时间:2016-01-30 15:17:29

标签: linux google-chrome video hardware-acceleration vp8

我有“华擎”中的“Beebox”。该机器的处理器是Intel Celeron N3150,支持VP8视频流的硬件编码和解码。我想在Google Chrome(在Debian Linux上)中使用此功能来进行WebRTC调用。但我不确定如何证明Chrome实际上正在使用硬件编码/解码。

到目前为止我的调查结果

不幸的是,Linux上的情况非常令人困惑。除了不同的加速API(VAAPI,VDPAU等),其中我不知道Chrome实际上使用了哪些,Chrome通过以下方式增加了额外的混淆:

视频解码:仅限软件,硬件加速不可用

视频编码:硬件加速

在“ chrome:// gpu ”页面上。

编码尽管ist表示加速编码,但在将高清视频编码为VP8流时,我的CPU负载为60-70%。这对我来说看起来不像HW编码。

解码:就我在网上看到的情况而言,Linux下的Chrome上似乎根本不支持硬件解码。有一个名为 - ignore-gpu-blacklist 的Chrome开关确实将“视频解码”行改为“仅限软件... “to”硬件加速“,但这并没有改变任何东西。我还与Kodi和VLC等不同的媒体播放器进行了一些研究。这些播放器在播放VP8时显示CPU负载约为25-30%,这确实可能是硬件解码,但令人惊讶的是,当我关闭这些播放器中的硬件编码时,根本没有任何变化。这反过来让我相信即使这些也不会在HW中解码。

工具:我发现了一些工具,甚至是英特尔,但大多数都是指GPU负载(这意味着3D加速)。我还尝试了 mesa-utils 中的 glxinfo ,其中说:“直接呈现:是”并根据this线程确认硬件支持解码(?)。但这只是说支持是可用的,而不是当前是否有任何应用程序真正使用它。

问题

当在Linux上编码或解码VP8视频流时,有没有办法清楚地验证硬件编码器和/或解码器是否正常工作?

非常感谢你的帮助!

1 个答案:

答案 0 :(得分:4)

1)这里有一个更具体的旗帜。在Chrome://gpu中,您应该看到VPx Video Decode:

是说硬件还是软件?

2)相关地,尝试一下:在Chrome中转到YouTube,播放任何视频。在播放视频时右键单击该视频,然后从上下文菜单中选择Stats for Nerds

这将告诉您YouTube是否为您提供VP8,VP9或H.264。这可能是一个有用的线索,特别是如果您获得H.264。 (这对笔记本电脑更有帮助,因为如果Chrome就像MS Edge,当笔记本电脑处于电池供电状态时,它会停止宣传VPx支持,迫使YouTube给它提供H.264,因为VPx消耗的电量比H大得多.264即使它的硬件被解码.H.264是一个低得多的编解码器,其硬件解码比VPx硬件解码更有效.Kaby Lake可能最终缩小差距。)

3)还有一些其他问题。 Chrome软件渲染列表包含一些有趣的条目,表明Chrome可能会忽略甚至相当新的英特尔GPU,包括您的Braswell芯片。看看here。请注意,有一个条目是:"在Broadwell,Skylake和CherryView" 上,VPx解码速度太慢。

我不完全理解列表的语法。这个列表中提到的是否意味着对Broadwell和Skylake等整个处理器系列的硬件加速禁用?我不确定。在该条目和其他条目下有一堆十六进制形式的设备ID,因此你可以弄清楚你的是否在那里。另请注意其他条目,其中一些提及特定的Intel驱动程序版本,以及特定的Linux内核版本。

4)确保您的Chrome://flags页面实际上表明软件渲染列表被覆盖(它是第一个标志)。你提到了命令行语法,旧的"黑名单"这个标志近年来有一些错误,基本上不适用于某些人和其他问题。我只是仔细检查一下,无论你设置这个标志,它实际上都会在flags页面中显示正确的设置。如果没有,显然在该页面中正确设置。请注意,存在可能与您的问题有关的错误 - 覆盖软件呈现列表会将chrome://gpu中的VPx视频解码标记翻转为硬件加速,即使在没有VPx硬件加速的PC上也是如此,就像Ivy Bridge笔记本电脑一样,我现在使用的是英特尔HD 4000.我不知道这只是一个表现性错误,Chrome实际上并没有尝试使用硬件加速,或者Chrome实际上是在做什么所以(这似乎不得不崩溃或什么,但它没有)。

Chrome标记是混乱和碰撞的单词选择混乱。标志显示覆盖软件渲染列表。此标志需要启用,而不是禁用。但是如果它已启用,您将无法看到“已启用”或任何类型的状态指示器。您会看到禁用这个词,作为更改设置的邀请。只是你知道......也许这对你来说都是旧帽子。

5)最后的沟渠,但非常强大的资源,以查看系统上的VP8正在进行的是Intel Media SDK。如果默认情况下它不是免费的,那么它可以免费作为英特尔IDE / C ++编译器学生版的一部分,以及付费IDE版本的免费试用版。你可以在那里做很多事情来看看它是什么。我们对他们的开发人员指南第24页中的这段话感到震惊:

  

可以通过简单的编译将硬件加速添加到FFmpeg   步。对于使用FFmpeg命令行或libav *编写的应用程序   然后可以通过更改编解码器名称来启用硬件API -   例如,从libx264到h264_qsv。

我会使用ffmpeg中的VP8编解码器的方法,看看你是否可以在Chrome之外触发系统上的硬件加速。

6)另请注意术语"硬件加速"当涉及到视频编解码器在整个行业中使用不一致时,我不确定Chrome究竟是什么意思(在标志中)。解码可以由GPU 加速,或者可以通过固定功能单元在硬件中完全执行,该固定功能单元也恰好在GPU上(但不使用GPU着色器)。这两者都称为硬件加速,但它们并不是一回事。有时"完全在硬件中"或"固定功能"将用于区分该场景与一般GPU加速(有时称为部分加速或混合加速)。我非常确定您的Braswell具有用于解码VP8的固定功能全硬件解决方案,但不能用于编码它,但这个文档记录很少。我认为对于编码,英特尔只提供某种GPU加速(使用着色器,可能使用OpenGL或OpenCL或其他东西,但我不知道细节)。这种区别对于浏览器等应用程序很重要。全硬件解码比单纯GPU加速更有效,而这些和其他英特尔实施细节可能会影响其Chrome友好性,非易失性,从而影响Chrome开发团队关于如何使用Braswell模型的决策。不幸的是,所有这些都记录不清......