Mesa (computer graphics)
Original author(s) | Brian Paul |
---|---|
Developer(s) |
Currently: Intel, AMD, VMware Formerly: Tungsten Graphics[1] |
Initial release | August 1993[2] |
Stable release | 11.1.2 / February 11, 2016[3] |
Development status | Active |
Written in | C, C++, Assembly[4] |
Operating system | Cross-platform (BSDs, Haiku, Linux, et al.) |
Type | Graphics library |
License | MIT License[5] |
Website |
mesa3d |
Mesa is a collection of free and open-source libraries that implement several rendering as well as video acceleration APIs related to hardware-accelerated 3D rendering, 3D computer graphics and GPGPU, the most prominent being OpenGL. Mesa is hosted at freedesktop.org and used on Linux, BSD and other operating systems. Additionally to the APIs, Mesa also harbors most of the available free and open-source graphics device drivers, which is a bit misleading, since the actual device drivers are located in the kernel, and the user-space part consists of some compiler software. The development of Mesa started in August 1993 by Brian Paul, who is still active in the project today, by now containing numerous contributions from various other people and companies worldwide, due to its broad adoption. Crowdfunding has been successfully used to partially drive development of Mesa.[6]
Overview
Implementations of rendering APIs
Mesa is known as housing implementation of graphic APIs. Historically the main API that Mesa has implemented is OpenGL, along with other Khronos Group related specifications (like OpenVG, OpenGL ES or recently EGL). But Mesa can implement other APIs and indeed it did with Glide.
The supported version of the different graphic APIs depends on the driver, because each hardware driver has its own implementation (and therefore status). This is specially true for DRI drivers, while the Gallium3D drivers share common code that tend to homogenize the supported extensions and versions.
Mesa 10.x complies with OpenGL 3.3, for Intel, AMD/ATI and Nvidia GPU hardware. Mesa 11.0 was announced with some drivers being OpenGL 4.1 compliant.[8] Mesa maintains a support matrix with the status of the current OpenGL 3 and 4 conformance.[9][10]
API | Vulkan | OpenGL | OpenGL ES | OpenVG | EGL | GLX | Direct3D | |
---|---|---|---|---|---|---|---|---|
Version | Date | TBA | 4.5 2014-08-11 | 3.2 2015-08-10 | 1.1 2008-12-03 | 1.5 2014-03-19 | 1.4 2005-12-16 | 11.2 2013-10-17 |
11.2 | 2016-03-11[11] | ??? | 4.2 (Intel 3.3) | 3.1 | N/A | 1.5 | 1.4 | 9.0c[12][13] |
11.1 | 2015-12-15[14] | N/A | 4.2 (Intel 3.3) | 3.0 | N/A | |||
11.0 | 2015-09-12[15] | 4.2 (Intel 3.3)[16] | N/A | |||||
10.6 | 2015-06-15[17] | 3.3 | N/A[18] | 1.4 | ||||
10.5 | 2015-03-06[19] | 3.3 | 1.1 | |||||
10.4 | 2014-12-14[20] | 3.3 | ||||||
10.3 | 2014-09-19[21] | 3.3 | N/A | |||||
10.2 | 2014-06-06[22] | 3.3 | ||||||
10.1 | 2014-03-04[23] | 3.3[24] | ||||||
10.0 | 2013-11-30[25] | 3.3[26] | ||||||
9.0 | 2012-10-08 | 3.1[27] | 2.0 | |||||
8.0 | 2012-02-08 | 3.0 | ||||||
7.0 | 2007-06-22 | 2.1 | N/A | N/A | N/A | |||
6.0 | 2004-01-06 | 1.5 | 1.3 | |||||
5.0 | 2002-11-13 | 1.4 | ||||||
4.0 | 2001-10-22 | 1.3 | ||||||
Legend: Old version Older version, still supported Latest version Future release |
There has also been a Direct3D 9 state tracker since July 2013.[28] Note that due to the modularized nature of OpenGL, Mesa actually supports extensions from newer versions of OpenGL without claiming full support for them. For example, as of September 2015, Mesa supports OpenGL 4.2 Core Profile but also 9 out of 12 extensions that form OpenGL 4.5, with two more extensions under development.
Vulkan
In March 2015, the Vulkan API was officially announced by Khronos. SPIR-V, a newer version of Standard Portable Intermediate Representation (SPIR), will be part of the core specification. It remains to be seen how Mesa's current LIR, HIR and TGSI will interoperate with SPIR-V.
Generic Buffer Management
Generic Buffer Management (GBM) is an API which provides a mechanism for allocating buffers for graphics rendering tied to Mesa. GBM is intended to be used as a native platform for EGL on drm or openwfd. The handle it creates can be used to initialize EGL and to create render target buffers.[29]
Mesa GBM is an abstraction of the graphics driver specific buffer management APIs (for instance the various libdrm_* libraries), implemented internally by calling into the Mesa GPU drivers.
For example, the Wayland compositor Weston does its rendering using OpenGL ES 2, which it initializes by calling EGL. Since the server runs on the "bare KMS driver", it uses the EGL DRM platform, which could really be called as the GBM platform, since it relies on the Mesa GBM interface.
At XDC2014, Nvidia employee Andy Ritger proposed to enhance EGL in order to replace GBM.[30]
Implementations of video acceleration APIs
There are three possible ways to do the calculations necessary for the encoding and decoding of video streams:
- use a codec and do calculations on the CPU
- use a codec and do calculations on the 3D rendering engine of the GPU
- use a SIP block designed specifically for this task, e.g. PureVideo, Unified Video Decoder, Video Coding Engine, Quick Sync Video, DaVinci, CedarX, Crystal HD, etc.
Utilizing the CPU doesn't require any special support to be present in Mesa, but methods two and three do require explicit support by the graphics device driver and additional special interfaces (APIs) to be used by end-user software to access this hardware, which are shared in Mesa 3D. Several APIs for the access of video decoding hardware have been designed, including:
- Video Decode and Presentation API for Unix (VDPAU) – by Nvidia
- Video Acceleration API (VAAPI) – by Intel
- Distributed Codec Engine (DCE) – by Texas Instruments
- DirectX Video Acceleration (DXVA) – Microsoft Windows-only
- OpenMAX IL – video encoding by Khronos Group
- OpenVideo Decode (OVD) – AMD vaporware
- X-Video Bitstream Acceleration (XvBA) – extension to Xv
- X-Video Motion Compensation (XvMC) – extension to Xv
One of these interfaces is then used by end-user software, like e.g. VLC media player, GStreamer or HandBrake, to access the video acceleration hardware and make use of it.
Please note, that V4L2 is a kernel-to-user-space interface for video bit streams delivered by webcams or TV tuners.
Nouveau supports PureVideo and provides access to it through VDPAU and partly through XvMC.[31]
The free radeon driver supports Unified Video Decoder and Video Coding Engine through VDPAU and OpenMAX.[32]
Device drivers
The available free and open-source device drivers for graphic chipsets are "stewarded" by Mesa (because the existing free and open-source implementation of APIs are developed inside of Mesa). Currently there are two frameworks to write graphics drivers: DRI and Gallium3D. An overview over some of the drivers available in Mesa is given at http://mesamatrix.net/ The driver vc4 is missing from this site, while the driver freedreno is not part of mesa.
There are device drivers for AMD/ATI R100 to R800, Intel, and Nvidia cards with 3D acceleration. Previously drivers existed for the IBM/Toshiba/Sony Cell APU of the PlayStation 3, S3 Virge & Savage chipsets, VIA chipsets, Matrox G200 & G400, and more.[33]
The free and open-source drivers compete with proprietary closed-source drivers. Depending on the availability of hardware documentation and man-power, the free and open-source driver lag behind more or less in supporting 3D acceleration of new hardware. Also, 3D rendering performance is usually significantly slower with some notable exceptions,[34][35][36][37] where the free and open-source driver performs better than proprietary drivers.
Direct Rendering Infrastructure (DRI)
At the time 3D graphics cards became more mainstream for PCs, individuals partly supported by some companies began working on adding more support for hardware-accelerated 3D rendering to Mesa. The Direct Rendering Infrastructure (DRI) was one of these approaches to interface Mesa, OpenGL and other 3D rendering API libraries with the device drivers and hardware. After reaching a basic level of usability, DRI support was officially added to Mesa. This significantly broadened the available range of hardware support achievable when using the Mesa library.[38]
With adapting to DRI, the Mesa library finally took over the role of the front end component of a full scale OpenGL framework with varying backend components that could offer different degrees of 3D hardware support while not dropping the full software rendering capability. The total system used many different software components.[38]
While the design requires all these components to interact carefully, the interfaces between them are relatively fixed. Nonetheless, as most components interacting with the Mesa stack are open source, experimental work is often done through altering several components at once as well as the interfaces between them. If such experiments prove successful, they can be incorporated into the next major or minor release. That applies e.g. to the update of the DRI specification developed in the 2007-2008 timeframe. The result of this experimentation, DRI2, operates without locks and with improved back buffer support. For this, a special git branch of Mesa was created.[39]
DRI3 should be supported by at least the intel driver.[40][41]
Software renderer
Software rendering is the misleading term, when shaders are executed on the CPU instead of the GPU. Mesa also contains an implementation of software rendering that allows shaders to run on the CPU as a fallback when no graphics hardware accelerators are present called swrast. The Gallium software rasterizer is known as softpipe or when built with support for LLVM llvmpipe which generates CPU code at runtime.[42][43]
Mega drivers
The idea of bundling multiple drivers into a single "mega" driver was proposed by Eric Anholt. It allows for a single copy of the shared Mesa code to be used among multiple drivers (instead of it existing in each driver separately) and offering better performance than a separate shared library due to the removal of the internal library interface.[44] The state trackers for VDPAU and XvMC have become separate libraries.[45]
shader-db
shader-db is a collection of about 20,000 shaders gathered from various computer games and benchmarks as well as some scripts to compile these and collect some statistics. Shader-db shall help validate an optimization.
It was noticed that an unexpected number of shaders are not hand-written but generated. This means these shaders were originally written in HLSL and then translated into GLSL by some translator program, such as e.g. HLSL2GLSL. The problem is, that the generated code is often far from being optimal. Matt Turner said it was much easier to fix this in the translator program, then having to make Mesa's compiler carry the burden of dealing with such bloated shaders.
shader-db cannot be considered free and open-source software. To use it legally, one must have a license for all the computer games, that the shaders are part of. At least the Valve Corporation has granted all Mesa and all Debian developers free personal licenses for all the games distributed on Steam.
Software architecture
The so called "user-mode graphics device drivers" (UMD) in Mesa have very few commonalities with what is generally called a device driver. There are a couple of differences:
- they are meant to work on top of additionally existent kernel mode graphics device drivers, that are e.g. available as part of the Linux kernel found in the source code under
/drivers/gpu/drm/
Each UMD communicates with its kernel mode counterpart with the help of a specific library, name libdrm_specific and a generic one, named libdrm. This section shall look solely on the user-mode part above libdrm - there is some implementation of the finite-state machine as specified by e.g. OpenGL; this implementation of the OpenGL state machine may be shared among multiple UMDs or not
- they consist to a great part of some sort of compiler, that ingests e.g. GLSL and eventually outputs machine code. Parsers and may be shared among multiple UMD or be specific
Mesa's Intermediate Representations
One goal of Mesa is the optimization of code that is to be executed by the respective GPU. Another is the sharing of code. Instead of documenting the pieces of software, that do this or that, this Wikipedia article shall instead look at the Intermediate Representations used in the process of compiling and optimizing. See Abstract syntax tree (AST) and Static single assignment form (SSA form).
SPIR-V
SPIR-V is a certain version of the Standard Portable Intermediate Representation. The idea is, that game engines output SPIR-V instead of GLSL. In contrast to the latter, SPIR-V is binary to protect intellectual property and is already the result of general optimizations. A UMD needs only apply optimizations, that are specific to the supported hardware.
GLSL IR
- http://cgit.freedesktop.org/mesa/mesa/tree/src/compiler/glsl/README
- XDC2014, Matt Turner: Video on YouTube, Matt Turner - GLSL compiler: Where we've been and where we're going
- XDC2015, Matt Turner: Video on YouTube, http://www.x.org/wiki/Events/XDC2015/Program/turner_glsl_compiler.pdf
NIR
- Connor Abbott - NIR, or moving beyond GLSL IR in Mesa XDC2014
- http://cgit.freedesktop.org/mesa/mesa/tree/src/glsl/nir/README
- https://fosdem.org/2016/schedule/event/i965_nir/attachments/slides/1113/export/events/attachments/i965_nir/slides/1113/nir_vec4_i965_fosdem_2016_rc1.pdf
TGSI
The Tungsten Graphics Shader Infrastructure (TGSI) was introduced in 2008 by Tungsten Graphics. All Gallium3D-style UMDs ingest TGSI.
LLVM IR
The UMDs radeonsi
and llvmpipe
do not ouput machine code, but instead LLVM IR. From here on, LLVM does optimizations and the compilation to machine code. This does mean, that a certain minimum version of LLVM has to be installed as well!
Mesa's GLSL compiler
Mesa's GLSL compiler generates its own IR. Because each driver has very different requirements from a LIR, it differentiates between HIR (high-level IR) and LIR (low-level IR).
Gallium3D
Gallium3D was developed by Tungsten Graphics as a means to simplify the writing of device drivers and also to achieve maximum portability of them, without having to rewrite the source code. Gallium3D specification were released in 2008 and as of 15 February 2016, the current version is still 0.4.
Most device drivers inside of Mesa have been rewritten conforming to the new internal APIs defined by Gallium3D, and new drivers written since the introduction of Gallium3D have been written as Gallium3D drivers from the beginning on. A notable exception is the Mesa driver for the Intel 965-family of GPUs.
The main disadvantage is, that by introducing additional interfaces, namely the Gallium3D WinSys Interface, the full capabilities of the underlying hardware can not be accessed by the device drivers.
Performance
Criticism
At least John Carmack did complain about the "layers of crap" in the Linux graphics stack.
History
Project initiator Brian Paul was a graphics hobbyist. He thought it would be fun to implement a simple 3D graphics library using the OpenGL API, which he might then use instead of VOGL (very ordinary GL Like Library).[2] Beginning in 1993, he spent eighteen months of part-time development before he released the software on the Internet. The software was well received, and people began contributing to its development. Mesa started off by rendering all 3D computer graphics on the CPU. Despite this, the internal architecture of Mesa was designed to be open for attaching to graphics processor-accelerated 3D rendering. In this first phase, rendering was done indirectly in the display server, leaving some overhead and noticeable speed lagging behind the theoretical maximum. The Diamond Monster 3D, using the Voodoo Graphics chipset, was one of the first 3D hardware devices supported by Mesa.
The first true graphics hardware support was added to Mesa in 1997, based upon the Glide API for the then new 3dfx Voodoo I/II graphics cards and their successors.[38] A major problem of using Glide as the acceleration layer was the habit of Glide to run full screen, which was only suitable for computer games. Further, Glide took the lock of the screen memory, and thus the display server was blocked from doing any other GUI tasks.[46]
In 2014, LunarG, a United States based private computer software company founded in 2009 that specializes in 3D driver development, enhancements and tuning,[47] received funding from Valve to explore the possibility of game performance improvements using LunarGLASS technology in the Mesa driver.[48]
See also
References
- ↑ David Marshall (2008-12-16). "VMware's year end acquisition of Tungsten Graphics". InfoWorld. Retrieved 2011-08-06.
- 1 2 "Mesa Introduction". Mesa Team. Retrieved 2015-06-08.
- ↑ "Mesa 11.1.2 release announcement". Retrieved 2016-02-11.
- ↑ "Mesa Languages Page". Open Hub. Retrieved 2015-03-02.
- ↑ "Mesa 3D license". Retrieved 2015-06-03.
- ↑ "Improve OpenGL support for the Linux Graphics Drivers - Mesa". Indiegogo. 2013-12-11. Retrieved 2015-01-21.
- ↑ "AMD exploring new Linux driver Strategy". 2014-03-22. Retrieved 2014-03-23.
- ↑ "Mesa 11.0 Has Been Branched, The Release March Begins". 2015-08-22. Retrieved 2015-08-22.
- ↑ "mesa/mesa - The Mesa 3D Graphics Library". Retrieved 2015-01-22.
- ↑ "The OpenGL vs Mesa matrix". 2015-03-25. Retrieved 2015-03-29.
- ↑ "[Mesa-dev] Mesa 11.2.0 release plan". Retrieved 2016-01-26.
- ↑ "latest patches to "nine" state tracker". 2016-02-04.
- ↑ Larabel, Michael (14 December 2014). "Mesa 10.4 Officially Released With Direct3D 9 State Tracker". Phoronix. Retrieved 11 July 2015.
- ↑ "[Mesa-announce] Mesa 11.1.0". Retrieved 2015-12-15.
- ↑ "[Mesa-announce] Mesa 11.0.0". Retrieved 2015-09-26.
- ↑ "[Mesa] Intel releases OpenGL 4.4 for Windows". Retrieved 2015-09-10.
- ↑ "[Mesa-announce] Mesa 10.6.0". Retrieved 2015-06-15.
- ↑ Larabel, Michael (4 March 2015). "OpenVG Support Stripped From Gallium3D". Phoronix. Retrieved 11 July 2015.
- ↑ "[Mesa-announce] Mesa 10.5.0". Retrieved 2015-03-07.
- ↑ "[Mesa-announce] Mesa 10.4.0 released". Retrieved 2015-03-07.
- ↑ "[Mesa-announce] Mesa 10.3 released". Retrieved 2015-03-07.
- ↑ "[Mesa-announce] Mesa 10.2 released". Retrieved 2015-03-07.
- ↑ "[Mesa-announce] Mesa 10.1 released". Retrieved 2015-03-07.
- ↑ Larabel, Michael (2014-03-05). "Mesa 10.1 Released With Many Open-Source Driver Improvements". Phoronix.
- ↑ "[Mesa-announce] Mesa 10.0 released". Retrieved 2015-03-07.
- ↑ Larabel, Michael (2013-10-26). "Features To Be Found In Mesa 10.0". Phoronix.
- ↑ "Mesa 9.0 Release Notes". Mesa. 8 October 2012. Retrieved 11 July 2015.
- ↑ http://www.phoronix.com/scan.php?page=news_item&px=MTQxMjk
- ↑ "libgbm in the Debian repositories".
- ↑ "Enabling Alternative Window Systems with a non-Mesa Graphics Driver Implementation".
- ↑ "Nouveau Video Acceleration". freedesktop.org.
- ↑ "Radeon Feature Matrix". freedesktop.org.
- ↑ Direct Rendering Infrastructure Status Page on freedesktop.org
- ↑ http://apcmag.com/how-to-improve-gaming-performance-on-your-linux-machine.htm
- ↑ http://www.geeks3d.com/20120110/linux-mesa-gallium3d-nouveau-and-nvidia-drivers-opengl-test-gtx-280-gtx-480-gtx-580/
- ↑ http://www.phoronix.com/vr.php?view=18344
- ↑ http://www.phoronix.com/scan.php?page=article&item=july_2013_gpus&num=8
- 1 2 3 Brian Paul (2000-08-10). "Introduction to the Direct Rendering Infrastructure". dri.sourceforge.net. Retrieved 2012-01-25.
- ↑ "DRI2". X.org. Retrieved 2012-01-25.
- ↑ http://lwn.net/Articles/570082/
- ↑ http://lists.freedesktop.org/archives/dri-devel/2013-November/048258.html
- ↑ "LLVMpipe: OpenGL With Gallium3D on Your CPU". Phoronix.com. 2010-04-30. Retrieved 2014-11-04.
- ↑ "llvmpipe". mesa3d.org. Retrieved 2015-06-08.
- ↑ "DRI megadrivers". 2013-09-25.
- ↑ "VDPAU & XvMC state trackers are now separate libraries". 2014-06-23.
- ↑ "What's the relationship between Glide and DRI?". dri.freedesktop.org. Retrieved 2012-01-25.
- ↑ "Services - LunarG". LunarG. Retrieved 2014-09-17.
- ↑ Dawe, Liam (2014-06-08). "Valve Are Funding A Big Change To Mesa, Should Improve Linux Graphical Performance". GamingOnLinux. Retrieved 2014-09-17.
External links
- Official website
- The history of Mesa, by Jake Edge, October 2013
User mode | User applications | For example, bash, LibreOffice, Apache OpenOffice, Blender, 0 A.D., Mozilla Firefox, etc. | ||||
---|---|---|---|---|---|---|
Low-level system components: | System daemons: systemd, runit, logind, networkd, soundd, ... |
Windowing system: X11, Wayland, Mir, SurfaceFlinger (Android) |
Other libraries: GTK+, Qt, EFL, SDL, SFML, FLTK, GNUstep, etc. |
Graphics: Mesa, AMD Catalyst, ... | ||
C standard library | open(), exec(), sbrk(), socket(), fopen(), calloc(), ... (up to 2000 subroutines) glibc aims to be POSIX/SUS-compatible, uClibc targets embedded systems, bionic written for Android, etc. | |||||
Kernel mode | Linux kernel | stat, splice, dup, read, open, ioctl, write, mmap, close, exit, etc. (about 380 system calls) The Linux kernel System Call Interface (SCI, aims to be POSIX/SUS-compatible) | ||||
Process scheduling subsystem |
IPC subsystem |
Memory management subsystem |
Virtual files subsystem |
Network subsystem | ||
Other components: ALSA, DRI, evdev, LVM, device mapper, Linux Network Scheduler, Netfilter Linux Security Modules: SELinux, TOMOYO, AppArmor, Smack | ||||||
Hardware (CPU, main memory, data storage devices, etc.) |
|