开始学习OpenGL。 在现代Linux上,所有这些概念是如何相关的?
我开始学习OpenGL,因为这是我选择的硕士学位课程的一部分。 在课堂上,加速的3D图形在MS Windows上练习(也许DX3d实际上用来代替OpenGL,不确定)。 但是,我已经使用了很多年的Linux,并且我确信这是一个正确的开发环境,可以自由选择。 但是,据我所知,加速的3D,特别是驱动程序和硬件支持,在Linux上是一团糟。 所以,请帮助我将下面一堆概念组织成一个合理的结构,因为这是我能够看到和理解事物的唯一途径。
首先,有司机。 NVIDIA和AMD专有,加上“新风格”和一些开放的Radeon驱动程序,以及一个实验性的AMD开放但仍然是官方的。 这似乎很清楚。
其次,有一种叫做“mesa”的东西。 那是什么? 它是仅为免费驱动程序定义的,是免费驱动程序项目的一部分,还是定义和要求,无论使用何种驱动程序?
在开发2)中,“opengl”究竟是什么,它包含在哪里:mesa,司机,还有其他什么东西? 它可以是专有的吗?
最后,考虑到以上三点,在现代Linux系统上获取和安装OpenGL意味着什么?
OpenGL是一个接口。 要使用它,你需要一个实现。 有很多OpenGL的实现。 因为每个实现都是不同的,所以即使你的程序是相同的,当你用不同的实现运行它时,你的程序也会有不同的表现。 具有硬件渲染器的典型OpenGL实现将包含一些在用户空间(动态库)中运行的代码,在内核中运行的代码(设备驱动程序),在X.org服务器中运行的代码(DDX驱动程序) ,以及在显卡本身上运行的代码(固件)。 这是四种不同的代码!
AMD和nVidia为Linux提供专有的OpenGL实现。 这些实现具有封闭内核的闭源驱动程序,这意味着如果出现问题,Linux开发人员将无法为您提供帮助。 它们支持最新的OpenGL版本(例如4.5,如果您的硬件有能力),并具有完整的兼容性配置文件支持。
Mesa为Linux提供了一个开源的OpenGL实现。 此实现可以使用Noveau或Radeon开源驱动程序,它们不会污染内核。 Mesa也有一个名为llvmpipe的软件实现,它只在CPU上运行,不需要驱动程序。 它的速度令人印象深刻,但它比过时的硬件实施要慢得多。 Mesa最近开始支持OpenGL 4.x系列,但它需要一段时间才能通过发行版发布周期进行过滤,因此您更有可能看到OpenGL 3.3--而且这仅限于核心配置文件,因此您仅限于3.0与兼容性配置文件(类似于它在OS X上的工作原理)。
由于Mesa开发人员有限制地访问有关显卡的文档以及有限的开发资源,因此AMD或nVidia卡上的Mesa实现通常比供应商的实现慢,并且通常支持的OpenGL扩展更少。 然而,Mesa的实现非常稳定,它不会污染你的内核,而且一些Mesa实现甚至是Valgrind干净的。
安装OpenGL只是意味着在你的系统上安装一个OpenGL实现(你知道,使用dnf
或apt
或其他)。 这通常意味着供应商实施和Mesa实施之间的选择......除了Intel集成显卡,其中Mesa是供应商实施。
上一篇: Starting to learn OpenGL. On modern Linux, how are all these concepts related?
下一篇: Can't install NVIDIA graphics driver for Optimus/Bumblebee configuration