Gallium3D

Gallium3D
Original author(s) Tungsten Graphics (now VMware)
Developer(s) freedesktop.org?
Preview release 0.4[1] / April 24, 2010
Written in C
Operating system Cross-platform
Type Graphics library
License MIT License
Website www.freedesktop.org/wiki/Software/gallium/

Gallium3D is a set of interfaces and a collection of supporting libraries[2] intended to ease the programming of device drivers for 3D graphics chipsets for multiple operating systems, rendering or video acceleration APIs by splitting the graphics device driver into three parts. This is accomplished by the introduction of two interfaces: Gallium3D State Tracker Interface and the Gallium3D WinSys Interface. The three components are called

A feature matrix is being provided at GalliumStatus and the efforts of writing free and open-source device drivers for graphic chips is being separately documented in the Wikipedia: Free and open-source device drivers: graphics

The development of Gallium3D started in 2008 at Tungsten Graphics, and the implementation is available as free and open-source software as part of Mesa 3D hosted by freedesktop.org. The primary goal of making driver development easier, bundling otherwise duplicated code of several different drivers at a single point, and to support modern hardware architectures. This is done by providing a better division of labor, for example, leaving memory management to the kernel DRI driver.

Gallium3D has been a part of Mesa since 2009[3] and is currently used by the free and open source graphics driver for Nvidia (nouveau project),[4][5] for ATI Radeon R300-R900.[6][7][8] and for other free and open-source GPU device drivers.

Software architecture

Illustration of the Linux graphics stack
Mesa /DRI and Gallium3D have different driver models. Both share a lot of free and open-source code
A possible example matrix when implementing the Gallium3D driver model. Through the introduction of the Gallium3D Tracker Interface and the Gallium3D WinSys Interface, only 18 instead of 36 modules are required. Each WinSys module can work with each Gallium3D device driver module and with each State Tracker module.

Differences from classic graphics drivers

Gallium3D provides a unified API exposing standard hardware functions, such as shader units found on modern hardware. Thus, 3D APIs such as OpenGL 1.x/2.x, OpenGL 3.x, OpenVG, GPGPU infrastructure or even Direct3D (as found in the Wine compatibility layer) will need only a single back-end, called a state tracker, targeting the Gallium3D API. By contrast, classic-style device drivers require a different back-end for each hardware platform and several other APIs need translation to OpenGL at the expense of code duplication.[9][10][11] All vendor device drivers, due to their proprietary and closed-source nature, are written that way, meaning that, e.g. the AMD Catalyst implements both OpenGL and Direct3D, and the vendor drivers for the GeForce have their implementations.

Under Gallium3D, Direct Rendering Manager (DRM) kernel drivers will manage the memory and Direct Rendering Interface (DRI2) drivers will be more GPU processing oriented.[12] During the transition period from userspace modesetting to kernelspace modesetting some of the Mesa 3D drivers, such as the radeon driver or Intel's drivers, ended up supporting both DRI1 and DRI2 and used DRI2 if available on the system. Gallium3D additionally requires a level of shader support that is not available on older cards like e.g. ATi r100-r200 so users for those cards need to keep using Mesa 3D with DRI2 for their 3D usage.

Tungsten Graphics Shader Infrastructure

Tungsten Graphics Shader Infrastructure (TGSI) is an Intermediate representation like LLVM Intermediate Representation or the new Standard Portable Intermediate Representation (SPIR) to be used by the Vulkan API and OpenCL 2.1. Shaders written in OpenGL Shading Language are to be translated/compiled into TGSI, then optimizations are made, and then the TGSI shaders are being compiled into shaders for the instruction set of the used GPU, e.g. TeraScale (microarchitecture), Graphics Core Next, Tesla (microarchitecture), etc.

LLVM usage

GlassyMesa is an LLVM-based compiler stack for shaders written in GLSL. For SSA see the article Static single assignment form.

In addition, using the modular structure of Gallium3D, there is an effort underway to use the LLVM compiler suite and create a module to optimize shader code on the fly.[13]

The library represents each shader program using an extensible binary intermediate representation called Tungsten Graphics Shader Infrastructure (TGSI) which LLVM then translates into GLSL shaders optimized for target hardware

Adoption

Several free and open-source graphics device drivers which have been respectively are being written based on information gained through clean-room reverse engineering adopted the driver model provided by Gallium3D, e.g. nouveau and others (see Graphics hardware and FOSS for a complete list). The main reason may be, that the Gallium3D driver model lessens the amount of code required to be written. Of course, being licensed under a free software license, this code can at any time by anybody be rewritten to implement the DRI- or some other driver model.

History

Original authors of Gallium3D were Keith Whitwell and Brian Paul at Tungsten Graphics (acquired by VMware).

Milestones

As of Fall 2011, there were at least 10 known, mature and working Gallium3D drivers.[14] Open Source drivers for Nvidia graphics cards by the name of Nouveau team develops its drivers using the Gallium3D framework.[5][15]

2008-07-13: Nouveau development is done exclusively for the Gallium framework. The old DRI driver was removed from the master branch of the mesa repository on Freedesktop.org.[16]

2009-02-11: The gallium-0.2 branch was merged into mainline Master branch of Mesa.[17] Development is done in Mesa mainline.

2009-02-25: Gallium3D can run on Linux as well as FreeBSD kernels.[18]

2009-05-01: Zack Rusin from Tungsten Graphics added the OpenVG state tracker to Mesa 3D,[19] which enables Scalable Vector Graphics to be hardware-accelerated by any Gallium3D-based driver.

2009-07-17: Mesa3D 7.5 is released, the first version to include Gallium3D.[20]

2010-09-10: Initial support for the Evergreen GPUs was added to the r600g driver.[21]

2010-09-21: There are two Gallium3D drivers for ATI hardware known as r300g and r600g for R300-R500 and R600-Evergreen GPUs respectively.

2010-09-21: Major commits were made to the code to support Direct3D 10 and 11.[22] In time, this might offer the ability to use recent Direct3D implementations on GNU/Linux systems.

2011-11-30: Intel 965g and Cell Gallium drivers were removed from the master branch of Mesa as unmaintained and broken.[23] [24]

2014-11-18: Major commits were made to the code to support Direct3D 9.[25]

References

  1. cgit.freedesktop.org Build configuration file – Gallium documentation
  2. José Fonseca (2008-04-27). "Gallium3D: Introduction". Retrieved 2014-06-20.
  3. "Gallium3D Now In Mainline Mesa Code-Base!". Phoronix. 2009-02-11. Retrieved 2010-10-26.
  4. "The state of Nouveau, part 2". LWN.net. 2008-02-26. Retrieved 2008-03-07.
  5. 5.0 5.1 "Nouveau Companion 36". 2008-03-07. Retrieved 2008-04-01.
  6. "ATI R300 Gallium3D DRI Support Is "Done"". Phoronix. 2009-11-09. Retrieved 2010-11-15.
  7. "Radeon "R600g" Gallium3D Driver Merged To [Mesa] Master". Phoronix. 2010-05-27. Retrieved 2010-10-26.
  8. "X.Org Wiki GalliumStatus". Xorg. 2010-09-22. Retrieved 2010-12-07.
  9. "TG-Gallium3D". Tungsten Graphics. Retrieved 2008-04-01.
  10. zrusin (2008-02-06). "GPGPU". Retrieved 2008-04-01.
  11. zrusin (2008-02-07). "OpenVG and accelerating 2D". Retrieved 2008-04-01.
  12. "DRI2". 2007-10-04. Retrieved 2008-04-01.
  13. zrusin (2007-11-02). "Gallium3D LLVM". Retrieved 2008-04-01.
  14. contributors to freedesktop.org - Software/gallium (2 November 2011). "gallium". freedesktop.org. Retrieved 24 August 2012.
  15. "Nouveau Companion 37". 2008-03-21. Retrieved 2008-04-01.
  16. "nouveau: say goodbye to the old DRI driver... (cgit on FDO)". 2008-07-13.
  17. "Gallium3D Now In Mainline Mesa Code-Base!". 2009-02-11.
  18. Michael Larabel (2009-02-25). "Gallium3D, EGL Now Buildable On FreeBSD". Phoronix.
  19. "OpenVG state tracker is in Mesa 3D". 2009-05-01.
  20. "Mesa 7.5 Release Notes / 17 July 2009". 2009-07-17.
  21. "r600g: add initial evergreen support (cgit on FDO)". 2010-09-10.
  22. "d3d1x: add new Direct3D 10/11 COM state tracker for Gallium". 2010-09-21.
  23. Michael Larabel (2011-11-30). "The Gallium3D Intel 965 Driver Gets Dropped". Phoronix. p. 1. Retrieved 2011-12-01.
  24. Michael Larabel (2011-11-30). "The Gallium3D Cell Driver Gets Dropped Too". Phoronix. p. 1. Retrieved 2011-12-01.
  25. "nine: Add state tracker nine for Direct3D9 (v3)". 2014-11-18.

External links