Free and open-source graphics device driver

From HandWiki
Revision as of 19:05, 6 February 2024 by John Stpola (talk | contribs) (linkage)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Short description: Software that controls computer-graphics hardware


Flowchart with Tux, the Linux penguin
Data and instructions are sent to the GPU for processing. The rendered results are stored in a framebuffer, whose content is scanned by the display controller and sent to the screen.

A free and open-source graphics device driver is a software stack which controls computer-graphics hardware and supports graphics-rendering application programming interfaces (APIs) and is released under a free and open-source software license. Graphics device drivers are written for specific hardware to work within a specific operating system kernel and to support a range of APIs used by applications to access the graphics hardware. They may also control output to the display if the display driver is part of the graphics hardware. Most free and open-source graphics device drivers are developed by the Mesa project. The driver is made up of a compiler, a rendering API, and software which manages access to the graphics hardware.

Drivers without freely (and legally) -available source code are commonly known as binary drivers. Binary drivers used in the context of operating systems that are prone to ongoing development and change (such as Linux) create problems for end users and package maintainers. These problems, which affect system stability, security and performance, are the main reason for the independent development of free and open-source drivers. When no technical documentation is available, an understanding of the underlying hardware is often gained by clean-room reverse engineering. Based on this understanding, device drivers may be written and legally published under any software license.

In rare cases, a manufacturer's driver source code is available on the Internet without a free license. This means that the code can be studied and altered for personal use, but the altered (and usually the original) source code cannot be freely distributed. Solutions to bugs in the driver cannot be easily shared in the form of modified versions of the driver. Therefore, the utility of such drivers is significantly reduced in comparison to free and open-source drivers.

Problems with proprietary drivers

Software developer's view

Flowchart; see caption
Illustration of the Linux graphics stack

There are objections to binary-only drivers based on copyright, security, reliability and development concerns. As part of a wider campaign against binary blobs, OpenBSD lead developer Theo de Raadt said that with a binary driver there is "no way to fix it when it breaks (and it will break)"; when a product which relies on binary drivers is declared to be end-of-life by the manufacturer, it is effectively "broken forever."[1] The project has also stated that binary drivers[2] "hide bugs and workarounds for bugs",[3] an observation which has been somewhat vindicated by flaws found in binary drivers (including an exploitable bug in Nvidia's 3D drivers discovered in October 2006 by Rapid7). It is speculated that the bug has existed since 2004; Nvidia has denied this, asserting that the issue was only communicated to them in July 2006 and the 2004 bug was a bug in X.Org (not in Nvidia's driver).[4]

Binary drivers often do not work with current versions of open-source software, and rarely support development snapshots of open-source software; it is usually not directly possible for a developer to use Nvidia's or ATI's proprietary drivers with a development snapshot of an X server or a development snapshot of the Linux kernel. Features like kernel mode-setting cannot be added to binary drivers by anyone but the vendors, which prevents their inclusion if the vendor lacks capacity or interest.

In the Linux kernel development community, Linus Torvalds has made strong statements on the issue of binary-only modules: "I refuse to even consider tying my hands over some binary-only module ... I want people to know that when they use binary-only modules, it's their problem".[5] Another kernel developer, Greg Kroah-Hartman, has said that a binary-only kernel module does not comply with the kernel's license (the GNU General Public License); it "just violates the GPL due to fun things like derivative works and linking and other stuff."[6] Writer and computer scientist Peter Gutmann has expressed concern that the digital rights management scheme in Microsoft's Windows Vista operating system may limit the availability of the documentation required to write open drivers, since it "requires that the operational details of the device be kept confidential."[7]

In the case of binary drivers, there are objections due to free software philosophy, software quality and security concerns.[8] In 2006 Greg Kroah-Hartman concluded that:

"Closed source Linux kernel modules are illegal. That's it, it is very simple. I've had the misfortune of talking to a lot of different IP lawyers over the years about this topic, and every one that I've talked to all agree that there is no way that anyone can create a Linux kernel module, today, that can be closed source. It just violates the GPL due to fun things like derivative works and linking." [9]

The Linux kernel has never maintained a stable in-kernel application binary interface.[10] There are also concerns that proprietary drivers may contain backdoors, like the one found in Samsung Galaxy-series modem drivers.[11]

Hardware developer's view

Another flowchart; see caption
In the future, libGL-fglrx-glx could use the libDRM of the Radeon open-source driver instead of the proprietary binary blob; most of the investment is in the userspace driver.

When applications such as a 3D game engine or a 3D computer graphics software shunt calculations from the CPU to the GPU, they usually use a special-purpose API like OpenGL or Direct3D and do not address the hardware directly. Because all translation (from API calls to GPU opcodes) is done by the device driver, it contains specialized knowledge and is an object of optimization. Due to the history of the rigidity of proprietary driver development there has been a recent surge in the number of community-backed device drivers for desktop and mobile GPUs. Free and Open Hardware organizations like FOSSi, LowRISC, and others, would also benefit from the development of an open graphical hardware standard. This would then provide computer manufacturers, hobbyists, and the like with a complete, royalty-free platform with which to develop computing hardware and related devices.

The desktop computer market was long dominated by PC hardware using the x86/x86-64 instruction set and GPUs available for the PC. With three major competitors (Nvidia, AMD and Intel). The main competing factor was the price of hardware and raw performance in 3D computer games, which is greatly affected by the efficient translation of API calls into GPU opcodes. The display driver and the video decoder are inherent parts of the graphics card: hardware designed to assist in the calculations necessary for the decoding of video streams. As the market for PC hardware has dwindled, it seems unlikely that new competitors will enter this market and it is unclear how much more knowledge one company could gain by seeing the source code of other companies' drivers.

The mobile sector presents a different situation. The functional blocks (the application-specific integrated circuit display driver, 2- and 3D acceleration and video decoding and encoding) are separate semiconductor intellectual property (SIP) blocks on the chip, since hardware devices vary substantially; some portable media players require a display driver that accelerates video decoding, but does not require 3D acceleration. The development goal is not only raw 3D performance, but system integration, power consumption and 2D capabilities. There is also an approach which abandons the traditional method (Vsync) of updating the display and makes better use of sample and hold technology to lower power consumption.

During the second quarter of 2013 79.3 percent of smartphones sold worldwide were running a version of Android,[12] and the Linux kernel dominates smartphones. Hardware developers have an incentive to deliver Linux drivers for their hardware but, due to competition, no incentive to make these drivers free and open-source. Additional problems are the Android-specific augmentations to the Linux kernel which have not been accepted in mainline, such as the Atomic Display Framework (ADF).[13] ADF is a feature of 3.10 AOSP kernels which provides a dma-buf-centric framework between Android's hwcomposer HAL and the kernel driver. ADF significantly overlaps with the DRM-KMS framework. ADF has not been accepted into mainline, but a different set of solutions addressing the same problems (known as atomic mode setting) is under development. Projects such as libhybris harness Android device drivers to run on Linux platforms other than Android.

Software architecture

Illustration of differences between Gallium3D and Direct Rendering Infrastructure models
Although Mesa (DRI) and Gallium3D have different driver models, they share free and open-source code.
Driver example matrix
An example matrix of the Gallium3D driver model. With the introduction of the Gallium3D tracker and WinSys interfaces, 18 modules are required instead of 36. Each WinSys module can work with each Gallium3D device driver module and each State Tracker module.

Free and open-source drivers are primarily developed on and for Linux by Linux kernel developers, third-party programming enthusiasts and employees of companies such as Advanced Micro Devices. Each driver has five parts:

  1. A Linux kernel component DRM
  2. A Linux kernel component KMS driver (the display controller driver)
  3. A libDRM user-space component (a wrapper library for DRM system calls, which should only be used by Mesa 3D)
  4. A Mesa 3D user-space component. This component is hardware-specific; it is executed on the CPU and translates OpenGL commands, for example, into machine code for the GPU. Because the device driver is split, marshalling is possible. Mesa 3D is the only free and open-source implementation of OpenGL, OpenGL ES, OpenVG, GLX, EGL and OpenCL. In July 2014, most of the components conformed to Gallium3D specifications. A fully functional State Tracker for Direct3D version 9 is written in C, and an unmaintained tracker for Direct3D versions 10 and 11 is written in C++.[14] Wine has Direct3D version 9. Another Wine component translates Direct3D calls into OpenGL calls, working with OpenGL.
  5. Device Dependent X (DDX), another 2D graphics device driver for X.Org Server

The DRM is kernel-specific. A VESA driver is generally available for any operating system. The VESA driver supports most graphics cards without acceleration and at display resolutions limited to a set programmed in the Video BIOS by the manufacturer.[15]

History

The Linux graphics stack has evolved, detoured by the X Window System core protocol.

Free and open-source drivers

ATI and AMD

Radeon

Diagram
Linux device drivers for AMD hardware in August 2016

AMD's proprietary driver, AMD Catalyst for their Radeon, is available for Microsoft Windows and Linux (formerly fglrx). A current version can be downloaded from AMD's site, and some Linux distributions contain it in their repositories. It is in the process of being replaced with an AMDGPU-PRO hybrid driver combining the open-source kernel, X and Mesa multimedia drivers with closed-source OpenGL, OpenCL and Vulkan drivers derived from Catalyst.

The FOSS drivers for ATI-AMD GPUs are being developed under the name Radeon (xf86-video-ati or xserver-xorg-video-radeon). They still must load proprietary microcode into the GPU to enable hardware acceleration.[16][failed verification]

Radeon 3D code is split into six drivers, according to GPU technology: the radeon, r200 and r300 classic drivers and r300g, r600g and radeonsi Gallium3D drivers:

An up-to-date feature matrix is available,[17] and there is support for Video Coding Engine[18] and Unified Video Decoder.[19][20] The free and open-source Radeon graphics device drivers are not reverse-engineered, but are based on documentation released by AMD without the requirement to sign a non-disclosure agreement (NDA).[21][22][23] Documentation began to be gradually released in 2007.[24][25][26]

In addition to providing the necessary documentation, AMD employees contribute code to support their hardware and features.[18]

All components of the Radeon graphics device driver are developed by core contributors and interested parties worldwide. In 2011, the r300g outperformed Catalyst in some cases.

AMDGPU

Main page: Software:AMDGPU

At the 2014 Game Developers Conference, AMD announced that they were exploring a strategy change to re-base the user-space part of Catalyst on a free and open-source DRM kernel module instead of their proprietary kernel blob.[27]

The release of the new AMDGPU kernel module and stack was announced on the dri-devel mailing list in April 2015.[28] Although AMDGPU only officially supports GCN 1.2 and later graphics cards,[29] experimental support for GCN 1.0 and 1.1 graphics cards (which are only officially supported by the Radeon driver) may be enabled via a kernel parameter.[30][31] A separate libdrm, libdrm-amdgpu, has been included since libdrm 2.4.63.[32]

The radeonsi 3D code mentioned in the previous Radeon paragraph is also used with amdgpu; the 3D driver has back ends for both radeon and amdgpu.

Nvidia

Screenshot of grass growing out of the water
Screenshot of REnouveau, a program which collects data for most of Nouveau's reverse-engineering work

Nvidia's proprietary driver, Nvidia GeForce driver for GeForce, is available for Windows x86/x86-64, Linux x86/x86-64/ARM, OS X 10.5 and later, Solaris x86/x86-64 and FreeBSD x86/x86-64. A current version can be downloaded from the Internet, and some Linux distributions contain it in their repositories. The 4 October 2013 beta Nvidia GeForce driver 331.13 supports the EGL interface, enabling support for Wayland in conjunction with this driver.[33][34]

Nvidia's free and open-source driver is named nv.[35] It is limited (supporting only 2D acceleration), and Matthew Garrett, Dirk Hohndel and others have called its source code confusing.[36][37][38] Nvidia decided to deprecate nv, not adding support for Fermi or later GPUs and DisplayPort, in March 2010.[39]

In December 2009, Nvidia announced they would not support free graphics initiatives.[40] On 23 September 2013 The company announced that they would release some documentation of their GPUs.[41]

Nouveau is based almost entirely on information gained through reverse engineering. This project aims to produce 3D acceleration for X.Org/Wayland using Gallium3D.[42] On March 26, 2012, Nouveau's DRM component was marked stable and promoted from the staging area of the Linux kernel.[43] Nouveau supports Tesla- (and earlier), Fermi-, Kepler- and Maxwell-based GPUs.[44] On 31 January 2014, Nvidia employee Alexandre Courbot committed an extensive patch set which adds initial support for the GK20A (Tegra K1) to Nouveau.[45] In June 2014, Codethink reportedly ran a Wayland-based Weston compositor with Linux kernel 3.15, using EGL and a "100% open-source graphics driver stack" on a Tegra K1.[46] A feature matrix is available.[47] In July 2014, Nouveau was unable to outperform the Nvidia GeForce driver due to missing re-clocking support. Tegra-re is a project which is working to reverse-engineer nVidia's VLIW-based Tegra series of GPUs that predate Tegra K1.[48]

Nvidia distributes proprietary device drivers for Tegra through OEMs and as part of its Linux for Tegra (formerly L4T) development kit.[49] Nvidia and a partner, Avionic Design, were working on submitting Grate (free and open-source drivers for Tegra) upstream of the mainline Linux kernel in April 2012.[50][51] The company's co-founder and CEO laid out the Tegra processor roadmap with Ubuntu Unity at the 2013 GPU Technology Conference.[52]

Nvidia's Unified Memory driver (nvidia-uvm.ko), which implements memory management for Pascal and Volta GPUs on Linux, is MIT licensed. The source code is available in the Nvidia Linux driver downloads on systems that support nvidia-uvm.ko.

In May 2022 Nvidia Announced a new initiative and policy to open source its GPU Loadable Kernel Modules with dual GPL/MIT license, but only new models at alpha quality. But said "These changes are for the kernel modules, while the user-mode components are untouched. The user-mode remains closed source and is published with prebuilt binaries in the driver and the CUDA toolkit."[53]

Intel

Intel has a history of producing (or commissioning) open-source drivers for its graphics chips, with the exception of their PowerVR-based chips.[54] Their 2D X.Org driver is called xf86-video-intel. The kernel mode-setting driver in the Linux kernel does not use the Video BIOS for switching video modes; since some BIOSes have a limited range of modes, this provides more reliable access to those supported by Intel video adapters.

The company worked on optimizing their free Linux drivers for performance approaching their Windows counterparts, especially on Sandy Bridge and newer hardware where performance optimizations have allowed the Intel driver to outperform their proprietary Windows drivers in certain tasks, in 2011.[55][56][57] Some of the performance enhancements may also benefit users of older hardware.[58]

Support for Intel's LLC (Last Level Cache, L4-Cache, Crystalwell and Iris Pro) was added in Linux kernel 3.12,[59][60] and the company has 20 to 30 full-time Linux graphics developers.[61]

Matrox

Matrox develops and manufactures the Matrox Mystique, Parhelia, G200, G400 and G550. Although the company provides free and open-source drivers for their chipsets which are older than the G550; chipsets newer than the G550 are supported by a closed-source driver.

S3 Graphics

S3 Graphics develops the S3 Trio, ViRGE, Savage and Chrome, supported by OpenChrome.[62]

Arm Ltd

Arm Ltd is a fabless semiconductor company which licenses semiconductor intellectual property cores. Although they are known for the licensing the ARM instruction set and CPUs based on it, they also develop and license the Mali series of GPUs, and more recently Imortalis GPUs that support ray-tracing. On January 21, 2012, Phoronix reported that Luc Verhaegen was driving a reverse-engineering attempt aimed at the Arm Mali series of GPUs (specifically, the Mali-200 and Mali-400 versions). The reverse-engineering project, known as Lima, was presented at FOSDEM on February 4, 2012.[63][64] On February 2, 2013, Verhaegen demonstrated Quake III Arena in timedemo mode, running on top of the Lima driver.[65] In May 2018, a Lima developer posted the driver for inclusion in the Linux kernel.[66] As of May 2019, the Lima driver is part of the mainline Linux kernel.[67]

Panfrost is a reverse-engineered driver effort for Mali Txxx (Midgard) and Gxx (Bifrost) GPUs. Introducing Panfrost talk was presented at X.Org Developer's Conference 2018. As of May 2019, the Panfrost driver is part of the mainline Linux kernel.[68]

ARM has indicated no intention of providing support for their graphics acceleration hardware licensed under a free and open-source license. However, ARM employees sent patches for the Linux kernel to support their ARM HDLCD display controller and Mali DP500, DP550 and DP650 SIP blocks in December 2015 and April 2016.[69][70]

Imagination Technologies

Imagination Technologies is a fabless semiconductor company which develops and licenses semiconductor intellectual property cores, among which are the PowerVR GPUs. Intel has manufactured a number of PowerVR-based GPUs. PowerVR GPUs are widely used in mobile SoCs. Due to its wide use in embedded devices, the Free Software Foundation has put reverse-engineering of the PowerVR driver on its high-priority project list.[71] As of March 2022, Imagination has provided a FOSS driver for its Rogue architecture-based PowerVR GX6250 from 2014, and its more recent A-Series architecture-based AXE-1-16M and BXS-4-64 GPUs.[72]

Vivante

Vivante Corporation is a fabless semiconductor company which licenses semiconductor intellectual property cores and develops the GCxxxx series of GPUs. A Vivante proprietary, closed-source Linux driver consists of kernel- and user-space parts. Although the kernel component is open-source (GPL), the user-space components—consisting of the GLES(2) implementations and a HAL library—are not; these contain the bulk of the driver logic.

Wladimir J. van der Laan found and documented the state bits, command stream and shader ISA by studying how the blobs work, examining and manipulating command-stream dumps. The Etnaviv Gallium3D driver is being written based on this documentation. Van der Laan's work was inspired by the Lima driver, and the project has produced a functional-but-unoptimized Gallium3D LLVM driver. The Etnaviv driver has performed better than Vivante's proprietary code in some benchmarks, and it supports Vivante's GC400, GC800, GC1000, GC2000, GC3000 and GC7000 series.[73] In January 2017, Etnaviv was added to Mesa with both OpenGL ES 2.0 and Desktop OpenGL 2.1 support.[74]

Qualcomm

Qualcomm develops the Adreno (formerly ATI Imageon) mobile GPU series, and includes it as part of their Snapdragon mobile SoC series. Phoronix and Slashdot reported in 2012 that Rob Clark, inspired by the Lima driver, was working on reverse-engineering drivers for the Adreno GPU series.[75][76] In a referenced blog post, Clark wrote that he was doing the project in his spare time and that the Qualcomm platform was his only viable target for working on open 3D graphics. His employers (Texas Instruments and Linaro) were affiliated with the Imagination PowerVR and ARM Mali cores, which would have been his primary targets; he had working command streams for 2D support, and 3D commands seemed to have the same characteristics.[77] The driver code was published on Gitorious "freedreno",[78] and has been moved to Mesa.[79][80] In 2012, a working shader assembler was completed;[81] demonstration versions were developed for texture mapping[82] and phong shading,[83] using the reverse-engineered shader compiler. Clark demonstrated Freedreno running desktop compositing, the XBMC media player and Quake III Arena at FOSDEM on February 2, 2013.[84]

In August 2013, the kernel component of freedreno (MSM driver) was accepted into mainline and is available in Linux kernel 3.12 and later.[85] The DDX driver gained support for server-managed file descriptors requiring X.Org Server version 1.16 and above in July 2014.[86] In January 2016, the Mesa Gallium3D-style driver gained support for Adreno 430;[87] in November of that year, the driver added support for the Adreno 500 series.[88] Freedreno can be used on devices such as 96Boards Dragonboard 410c and Nexus 7 (2013) in traditional Linux distributions (like Debian and Fedora) and on Android.

Broadcom

Software diagram
The Mesa driver for VideoCore4, VC4, was written from scratch by Broadcom's Eric Anholt.[89]

Broadcom develops and designs the VideoCore GPU series as part of their SoCs. Since it is used by the Raspberry Pi, there has been considerable interest in a FOSS driver for VideoCore.[90] The Raspberry Pi Foundation, in co-operation with Broadcom, announced on October 24, 2012, that they open-sourced "all the ARM (CPU) code that drives the GPU".[citation needed] However, the announcement was misleading; according to the author of the reverse-engineered Lima driver, the newly open-sourced components only allowed message-passing between the ARM CPU and VideoCore but offered little insight into Videocore and little additional programability.[91] The Videocore GPU runs an RTOS which handles the processing; video acceleration is done with RTOS firmware coded for its proprietary GPU, and the firmware was not open-sourced on that date.[92] Since there was neither a toolchain targeting the proprietary GPU nor a documented instruction set, no advantage could be taken if the firmware source code became available. The Videocoreiv project[93] attempted to document the VideoCore GPUs.

On February 28, 2014 (the Raspberry Pi's second anniversary), Broadcom and the Raspberry Pi Foundation announced the release of full documentation for the VideoCore IV graphics core and a complete source release of the graphics stack under a 3-clause BSD license.[94][95] The free-license 3D graphics code was committed to Mesa on 29 August 2014,[96] and first appeared on Mesa's 10.3 release.

Other vendors

Although Silicon Integrated Systems and VIA Technologies have expressed limited interest in open-source drivers, both have released source code which has been integrated into X.Org by FOSS developers.[38] In July 2008, VIA opened documentation of their products to improve its image in the Linux and open-source communities.[97] The company has failed to work with the open-source community to provide documentation and a working DRM driver, leaving expectations of Linux support unfulfilled.[98] On January 6, 2011, it was announced that VIA was no longer interested in supporting free graphics initiatives.[99]

DisplayLink announced an open-source project, Libdlo,[100] with the goal of bringing support for their USB graphics technology to Linux and other platforms. Its code is available under the LGPL license,[101] but it has not been integrated into an X.Org driver. DisplayLink graphics support is available through the kernel udlfb driver (with fbdev) in mainline and udl/drm driver, which in March 2012 was only available in the drm-next tree.

Non-hardware-related vendors may also assist free graphics initiatives. Red Hat has two full-time employees (David Airlie and Jérôme Glisse) working on Radeon software,[102] and the Fedora Project sponsors a Fedora Graphics Test Week event before the launch of their new Linux distribution versions to test free graphics drivers.[103] Other companies which have provided development or support include Novell and VMware.

Open hardware projects

See caption
Assembled Project VGA graphics board
Another circuit board
Open Graphics Project prototype

Project VGA aims to create a low-budget, open-source VGA-compatible video card.[104] The Open Graphics Project aims to create an open-hardware GPU. The Open Graphics Device v1 has dual DVI-I outputs and a 100-pin IDC connector. In September 2010, the first 25 OGD1 boards were made available for grant application and purchase.[105] The Milkymist system on a chip, targeted at embedded graphics instead of desktop computers, supports a VGA output, a limited vertex shader and a 2D texturing unit.[106]

The Nyuzi,[107] an experimental GPGPU processor, includes a synthesizable hardware design written in System Verilog, an instruction set emulator, an LLVM-based C-C++ compiler, software libraries and tests and explores parallel software and hardware. It can run on a Terasic DE2-115 field-programmable gate array board.[108][109]

If a project uses FPGAs, it generally has a partially (or completely) closed-source toolchain. There are currently a couple of open-source toolchains available, however, for Lattice-based FPGAs (notably for iCE40 and ECP5 boards) which utilize Project IceStorm,[110] and Trellis,[111] respectively. There is also a larger, ongoing effort to create the "GCC of FPGAs" called SymbiFlow[112] which includes the aforementioned FPGA toolchains as well as an early-stage open-source toolchain for Xilinx-based FPGAs.

See also

References

  1. Theo de Raadt (2006-12-03). "Open Documentation for Hardware". Presentation slides from OpenCON 2006. http://www.openbsd.org/papers/opencon06-docs/index.html. 
  2. "What does "binary" means in device driver?". https://stackoverflow.com/questions/8804204/what-does-binary-means-in-device-driver. 
  3. "3.9: "Blob!"". OpenBSD. http://www.openbsd.org/lyrics.html#39. 
  4. "Linux - How does the Rapid7 Advisory R7-0025 affect the NVIDIA Unix driver?". http://Nvidia.custhelp.com/cgi-bin/Nvidia.cfg/php/enduser/std_adp.php?p_faqid=1971. 
  5. "a/lt-binary". https://lwn.net/1999/0211/a/lt-binary.html. 
  6. Kroah-Hartman, Greg. "Myths, Lies, and Truths about the Linux kernel". linux kernel monkey log. http://www.kroah.com/log/linux/ols_2006_keynote.html. 
  7. Peter Gutmann (2006-12-26). A Cost Analysis of Windows Vista Content Protection. http://www.cs.auckland.ac.nz/~pgut001/pubs/vista_cost.html#oss. Retrieved 2007-01-28. 
  8. Linux Weekly News, Aug 14, 2006: X.org, distributors, and proprietary modules
  9. Greg Kroah-Hartman (2006). "Myths, Lies, and Truths about the Linux kernel". Linux Symposium. http://www.kroah.com/log/linux/ols_2006_keynote.html. 
  10. "The Linux Kernel Driver Interface". https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/stable_api_nonsense.txt. 
  11. "SamsungGalaxyBackdoor". 2014-02-04. http://redmine.replicant.us/projects/replicant/wiki/SamsungGalaxyBackdoor. 
  12. "Android Nears 80% Market Share In Global Smartphone Shipments, As iOS And BlackBerry Share Slides, Per IDC". 7 August 2013. https://techcrunch.com/2013/08/07/android-nears-80-market-share-in-global-smartphone-shipments-as-ios-and-blackberry-share-slides-per-idc/. 
  13. "Atomic Display Framework". https://lwn.net/Articles/565422/. 
  14. "Direct3D 9 state tracker". 16 July 2013. http://lists.freedesktop.org/archives/mesa-dev/2013-July/041900.html. 
  15. "Index of /doc/Documentation/fb/". https://www.kernel.org/doc/Documentation/fb/. 
  16. Details of Debian package firmware-linux-nonfree in Stable Debian.org
  17. "Radeon Feature". http://xorg.freedesktop.org/wiki/RadeonFeature. 
  18. 18.0 18.1 "initial VCE support in Linux kernel and in the Mesa driver". 4 February 2014. http://lists.freedesktop.org/archives/mesa-dev/2014-February/053203.html. 
  19. "drm-next-3.15 Feb 18". 18 February 2014. http://lists.freedesktop.org/archives/dri-devel/2014-February/054159.html. 
  20. "drm-next-3.15 Mar 04". 4 March 2014. http://lists.freedesktop.org/archives/dri-devel/2014-March/054999.html. 
  21. "AMD Developer Guides". http://developer.amd.com/resources/documentation-articles/developer-guides-manuals/. 
  22. "Documentation provided by AMD". http://www.x.org/docs/AMD/. 
  23. "AMD 3D Documentation list". http://www.botchco.com/agd5f/?p=58. 
  24. "AMD to open up graphics specs". LWN.net. 2007-09-05. https://lwn.net/Articles/248227/. 
  25. "AMD: GPU Specifications Without NDAs!". 2007-09-10. https://www.phoronix.com/scan.php?page=news_item&px=NjA0Ng. 
  26. David Airlie (2007-09-13). "AMD hand me specs on a CD". http://airlied.livejournal.com/50613.html. 
  27. "AMD exploring new Linux driver Strategy". 2014-03-22. https://www.phoronix.com/scan.php?page=article&item=amd_catalyst_kernel&num=1. 
  28. "Initial AMDGPU driver release". 2015-04-20. http://lists.freedesktop.org/archives/dri-devel/2015-April/081501.html. 
  29. "AMD Moves Forward With Unified Linux Driver Strategy, New Kernel Driver". https://www.phoronix.com/scan.php?page=article&item=amd_bordeaux_strategy&num=1. 
  30. "AMDGPU driver documentation". https://dri.freedesktop.org/docs/drm/gpu/amdgpu.html. 
  31. "AMD Unleashes Initial AMDGPU Driver Support For GCN 1.0 / Southern Islands GPUs". https://www.phoronix.com/scan.php?page=news_item&px=AMDGPU-SI-Experimental-Code. 
  32. "libdrm 2.4.63". 2015-08-14. https://lwn.net/Articles/654542/. 
  33. "Support for EGL on 32-bit platforms". 2013-10-04. http://www.nvidia.com/object/linux-display-amd64-331.13-driver.html. 
  34. "lib32-nvidia-utils 340.24-1 File List". 2014-07-15. https://www.archlinux.org/packages/multilib/x86_64/lib32-nvidia-utils/files/. 
  35. "X.org nv driver page". 2013-05-20. http://xorg.freedesktop.org/wiki/nv. 
  36. "Patch by Dirk Hohndel". 1998-11-18. http://cvsweb.xfree86.org/cvsweb/xc/programs/Xserver/hw/xfree86/vga256/drivers/nv/Attic/README.RIVATNT.diff?r1=1.1.2.2&r2=1.1.2.3&hideattic=0&only_with_tag=xf-3_3_3. "... opposed to such obfuscated code. We do not regard this as free software according to our standards" 
  37. "Nouveau – The community & past, current and future developments". 2011-09-13. http://phd.mupuf.org/files/xdc2011_slides.pdf. 
  38. 38.0 38.1 David M. Airlie (2006-07-19). "Open Source Graphic Drivers—They Don't Kill Kittens". Ottawa, Ontario, Canada. http://www.linuxsymposium.org/2006/linuxsymposium_procv1.pdf. Retrieved 2007-01-28. 
  39. "Nvidia deprecates "NV"". Phoronix. 2010-03-26. https://www.phoronix.com/scan.php?page=article&item=nvidia_kills_nv&num=1. 
  40. "Nvidia's Response To Recent Nouveau Work". Phoronix. 2009-12-14. https://www.phoronix.com/scan.php?page=news_item&px=NzgwNQ. 
  41. "Nvidia offers to release public documentation on certain aspects of their GPUs". 2013-09-23. http://lists.freedesktop.org/archives/nouveau/2013-September/014480.html. 
  42. "Nouveau: Accelerated Open Source driver for nVidia cards". http://nouveau.freedesktop.org/wiki/. 
  43. "The Nouveau driver graduates from staging". LWN.net. 2012-03-23. https://lwn.net/Articles/488338/. 
  44. "Engineering names for Nvidia". http://nouveau.freedesktop.org/wiki/CodeNames/. 
  45. "drm/nouveau: initial support for GK20A (Tegra K1)". 2014-01-31. http://lists.freedesktop.org/archives/dri-devel/2014-January/053028.html. 
  46. "Codethink Gets The NVIDIA Jetson TK1 Running With Linux 3.15, Wayland". Phoronix. 2014-06-12. https://www.phoronix.com/scan.php?page=news_item&px=MTcxODc. 
  47. "Nouveau Driver Feature Matrix". http://nouveau.freedesktop.org/wiki/FeatureMatrix. 
  48. "Tegra-re". https://github.com/kusma/tegra-re. 
  49. "Linux For Tegra Archive". 30 January 2014. https://developer.nvidia.com/linux-tegra. 
  50. Mayo, Jon (2012-04-20). "[RFC 0/4] Add NVIDIA Tegra DRM support". dri-devel (Mailing list). Retrieved 2012-08-21.
  51. Larabel, Michael (2012-04-11). "A NVIDIA Tegra 2 DRM/KMS Driver Tips Up". Phoronix Media. https://www.phoronix.com/scan.php?page=news_item&px=MTA4NjA. 
  52. "GTC 2013: NVIDIA's Tegra Roadmap (6 of 11)". YouTube. https://www.youtube.com/watch?v=8kIQWWJs_po&t=9m35s. 
  53. "NVIDIA Releases Open-Source GPU Kernel Modules". 2022-05-19. https://developer.nvidia.com/blog/nvidia-releases-open-source-gpu-kernel-modules/. 
  54. An overview of graphic card manufacturers and how well they work with Ubuntu Ubuntu Gamer, January 10, 2011 (Article by Luke Benstead); (copy of the article)
  55. "More Performance Comes Out Of Intel Linux SNB". Phoronix. 2011-03-22. https://www.phoronix.com/scan.php?page=news_item&px=OTIzNQ. 
  56. "Intel Sandy Bridge Performance Goes Up Again". Phoronix. 2011-03-31. https://www.phoronix.com/scan.php?page=article&item=intel_llc_caching&num=1. 
  57. "Intel SNB Linux Driver Can Out Run Windows Driver". Phoronix. 2011-05-23. https://www.phoronix.com/scan.php?page=article&item=intel_snbsds_compare&num=1. 
  58. "A Historical Look At Intel Ironlake Graphics Performance". Phoronix. 2011-05-25. https://www.phoronix.com/vr.php?view=16049. 
  59. "drm/i915: Use eLLC/LLC by default when available". https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=4d15c145a6234d999c0452eec0d275c1fbf0688c. 
  60. "drm/i915: Use Write-Through cacheing for the display plane on Iris". https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=651d794fae9b79237aae1c97f8a9d9f3817bd31d. 
  61. "Intel Has 20~30 Full-Time Linux Graphics Developers". 2013-02-02. https://www.phoronix.com/scan.php?page=news_item&px=MTI5MTI. 
  62. "OpenChrome". https://www.freedesktop.org/wiki/Openchrome/. 
  63. phoronix (6 February 2012). "Phoronix.com - FOSDEM 2012 - Open-Source ARM Mali". https://www.youtube.com/watch?v=MvRJ_8K8baI. 
  64. Phoronix, Jan 21 2012: An Open-Source, Reverse-Engineered Mali GPU Driver
  65. "Quake 3 Arena timedemo on top of the lima driver!". http://libv.livejournal.com/23886.html. 
  66. "Lima DRM driver [LWN.net"]. https://lwn.net/Articles/755084/. 
  67. drm/lima: driver for ARM Mali4xx GPUs}
  68. drm/panfrost: Add initial panfrost driver
  69. "drm: Add support for the ARM HDLCD display controller". Linux kernel mailing list. 2015-12-11. https://lwn.net/Articles/667575/. 
  70. "Initial support for ARM Mali Display Controller". Linux kernel mailing list. 2016-04-01. http://lkml.iu.edu/hypermail/linux/kernel/1604.0/00503.html. 
  71. Free Software Foundation, Apr 25, 2005: High Priority Free Software Projects
  72. "Imagination Tech Publishes Open-Source PowerVR Vulkan Driver For Mesa" (in en). https://www.phoronix.com/scan.php?page=news_item&px=Open-Source-PowerVR-Vulkan. 
  73. "laanwj/etna_viv". https://github.com/laanwj/etna_viv/wiki. 
  74. "etnaviv: gallium driver for Vivante GPUs". https://cgit.freedesktop.org/mesa/mesa/commit/?id=c9e8b49b885242d84ba031dacef5aa4a5ac1e5b6. 
  75. Michael Larabel (14 April 2012). "An Open-Source Graphics Driver For Snapdragon". Phoronix. https://www.phoronix.com/scan.php?page=article&item=qualcomm_freedreno. 
  76. Soulskill (14 April 2012). "Open-Source Qualcomm GPU Driver Published". Slashdot. http://linux.slashdot.org/story/12/04/14/219230/open-source-qualcomm-gpu-driver-published. 
  77. Rob Clark (14 April 2012). "Fighting back against binary blobs!". Linaro. http://bloggingthemonkey.blogspot.se/2012/04/fighting-back-against-binary-blobs.html. 
  78. Freedreno, 15 April 2012
  79. "Mesa/Gallium3D Gets Its First ARM SoC GPU Driver - Phoronix". https://www.phoronix.com/scan.php?page=news_item&px=MTMyNTE. 
  80. "Mesa (master): r600g: add Richland APU pci ids". 15 March 2013. http://lists.freedesktop.org/archives/mesa-commit/2013-March/042190.html. 
  81. Rob Clark (29 July 2012). "freedreno update: first renders shader assembler!". http://bloggingthemonkey.blogspot.se/2012/07/freedreno-update-first-renders-shader.html. 
  82. Rob Clark (5 August 2012). "textured cube (fullscreen!)". http://bloggingthemonkey.blogspot.se/2012/08/textured-cube-fullscreen.html. 
  83. Rob Clark (15 August 2012). "Open Source lolscat!". http://bloggingthemonkey.blogspot.se/2012/08/open-source-lolscat.html. 
  84. "Open ARM GPU drivers – Freedreno". FOSDEM. 2013-02-02. https://archive.fosdem.org/2013/schedule/event/operating_systems_open_arm_gpu/. 
  85. "Merge the MSM driver from Rob Clark". kernel.org. 2013-08-28. http://cgit.freedesktop.org/~airlied/linux/commit/?id=e906d7bdd3b63ffac8b91f2f05c450775de95ef6. 
  86. "xf86-video-freedreno 1.2.0". freedesktop.org. 2014-07-14. http://lists.freedesktop.org/archives/xorg/2014-July/056748.html. 
  87. "Add support for adreno 430". http://cgit.freedesktop.org/mesa/mesa/commit/?id=13b87e02b979b86872e1872b8cb325d376d05cc5. 
  88. "Index Mesa-Mesa". https://cgit.freedesktop.org/mesa/mesa/commit/?id=946cf4eb6846767306a221eec7d0f82d20dfb6b5. 
  89. Anholt, Eric (2014-06-17). "New Job at Broadcom". http://anholt.livejournal.com/44239.html?nojs=1. 
  90. "Phoronix on the Raspberry Pi GPU". https://www.phoronix.com/scan.php?page=news_item&px=MTA1MTc. 
  91. "Open Source ARM userland - Raspberry Pi". 24 October 2012. https://www.raspberrypi.org/blog/open-source-arm-userspace/#comment-34981. 
  92. "Open Source ARM userland - Raspberry Pi". 24 October 2012. http://www.raspberrypi.org/archives/2221. 
  93. "hermanhermitage/videocoreiv". https://github.com/hermanhermitage/videocoreiv/wiki/VideoCore-IV---BCM2835-Overview. 
  94. "Raspberry Pi marks 2nd birthday with plan for open source graphics driver". 28 February 2014. https://arstechnica.com/information-technology/2014/02/raspberry-pi-marks-2nd-birthday-with-plan-for-open-source-graphics-driver/. 
  95. Upton, Eben (28 February 2014). "A birthday present from Broadcom - Raspberry Pi". Raspberry Pi Foundation. https://www.raspberrypi.org/blog/a-birthday-present-from-broadcom/. 
  96. "vc4: Initial skeleton driver import". The Mesa 3D Graphics Library. 2014-08-09. http://cgit.freedesktop.org/mesa/mesa/commit/?id=1850d0a1cbf044dc4d29b7a9ede2c634f667d853. 
  97. Michael Larabel (2008-07-26). "VIA Publishes Three Programming Guides". Phoronix. https://www.phoronix.com/scan.php?page=news_item&px=NjYyMg. 
  98. Michael Larabel (2009-11-21). "VIA's Linux TODO List... Maybe Look Forward To 2011?". Phoronix. https://www.phoronix.com/scan.php?page=article&item=via_2010_roadmap&num=1. 
  99. VIA's Open Linux Graphics Driver Has Been Defenestrated Phoronix, January 06, 2011 (Article by Michael Larabel)
  100. "Libdlo". https://libdlo.freedesktop.org/wiki/. 
  101. "DisplayLink Releases Linux Source Code for its USB Graphics Processors" (Press release). DisplayLink. 2009-05-15. Retrieved 2009-05-15.
  102. AMD's Hiring Another Open-Source Driver Developer Phoronix, December 11, 2010 (Article by Michael Larabel)
  103. It's Fedora Graphics Test Week Phoronix, February 22, 2011 (Article by Michael Larabel)
  104. "Home of Project VGA, the low budget, open source, VGA compatible video card". http://wacco.mveas.com/.  090503 wacco.mveas.com
  105. "Linux Fund: OGD1". Open Graphics Project. 2010-09-23. http://linuxfund.org/projects/ogd1/. 
  106. Bourdeauducq, Sebastien (June 2010). "A performance-driven SoC architecture for video synthesis". http://www.milkymist.org/thesis/thesis.pdf. 
  107. "Nyuzi is an experimental GPGPU processor". June 2021. https://github.com/jbush001/NyuziProcessor/. 
  108. "SOC Test Environment". https://github.com/jbush001/NyuziProcessor/wiki/SOC-Test-Environment. 
  109. "Running on Terasic DE2-115 FPGA board". https://github.com/jbush001/NyuziProcessor/tree/master/hardware/fpga/de2-115. 
  110. "Project IceStorm Homepage". 21 January 2022. http://www.clifford.at/icestorm/. 
  111. "Project Trellis Repository". 30 May 2021. https://github.com/SymbiFlow/prjtrellis. 
  112. "SymbiFlow Homepage". https://symbiflow.github.io/. 

External links