http://en.wikipedia.org/wiki/Mesa_(computer_graphics)

Mesa (computer graphics)

From Wikipedia, the free encyclopedia
 
 
Mesa
Original author(s) Brian Paul
Developer(s) IntelAMDVMware(previously Tungsten Graphics)[1]
Initial release August 1, 1993; 20 years ago[citation needed]
Stable release 9.2.3 / November 13, 2013; 4 days ago[2]
Development status active
Written in CC++Assembly[3]
Operating system Cross-platform (Linux,BSD, et al.)
Type Graphics library
License MIT License[4]
Website mesa3d.org

Mesa is a collection of free and open-source libraries that implement several APIs related to hardware-accelerated 3D rendering3D computer graphics and also GPGPU. Mesa is hosted by freedesktop.org and used on LinuxBSD and other operating systems. Additionally to the APIs, Mesa also harbors the available free implementations of graphics device drivers. The development of Mesa started in August 1993 by Brian Pauland is still maintained by him, by now containing numerous contributions from various other people and companies worldwide, due to its broad adoption.

Software architecture[edit]

Illustration of the Linux graphics stack

The first true graphics hardware support was added to Mesa in 1997, based upon the Glide API for the once new 3dfx Voodoo I/IIgraphics cards and their successors.[5] 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.[6]

Graphic API implementations[edit]

The free implementations of the Wayland (display server protocol) rely upon the Mesa implementation of EGL. A special library called libwayland-EGL was written to accommodate access to the framebuffer

Mesa is known as housing implementation of graphic APIs, but it does also comprehend the available free and open-source device drivers for graphic chipsets, as can be seen by means of this Debian package. For DRI-drivers, the supported version of an API, is generally specific to the driver. E.g. the driver for Intel graphic chipsets support OpenGL ES 3.0 since Mesa 9.1,[7] while the other drivers, support only version 2.0. Mesa supports OpenGL ES 1.0, 1.1, 2.0, OpenGL version 3.1 (depending on the driver), along with some extensions from OpenGL 4. Support for OpenGL ES 3.0 has been added, but only Intel graphics are currently able to take advantage.[8]

Though, as of August 2013, Mesa was now the only free and open-source implementation of OpenGL, it's version 9.2 did only achieve compliance with OpenGL 3.1. OpenGL 3.1 was released on August 3rd, 2009 and OpenGL version 4.4 on July 22nd, 2013.[9]

Mesa 10 will comply with OpenGL 3.2, albeit only for certain GPU hardware.[10] It has not yet achieved full OpenGL 4 compliance at any level (OpenGL Extension Wrangler).

Drivers, that are written conforming to the Gallium3D-specifications[citation needed], do all support the same operating system kernels and APIs and versions thereof.

API OpenGL OpenGL ES OpenVG EGL GLX Glide Direct3D
Current Version 4.4
2013-07-22
3.0
2012-08-06
1.1
2008-12-03
1.4
2011-04-06
1.4
2005-12-16
3.10
2013-04-03
11.2
2011-09-13
Mesa 10.0 or 11.0 (2013-11-27)[11] 3.3[12] 2.0 1.1 1.4 1.4 deprecated 9.3 (and some of 10/11[13])
Mesa 9.0 (2012-10-08) 3.1[14] 2.0 1.1 1.4 1.4  ?
Mesa 8.0 (2012-02-08) 3.0 2.0 1.1 1.4 1.4  ?
Mesa 7.0 (2007-06-22) 2.1 N/A N/A N/A 1.4  ?
Mesa 6.0 (2004-01-06) 1.5 N/A N/A N/A 1.3  ?
Mesa 5.0 (2002-11-13) 1.4 N/A N/A N/A 1.3  ?
Mesa 4.0 (2001-10-22) 1.3 N/A N/A N/A 1.3  ?

The Wine (software) project wrote a free and open-source implementation of version 9.3 of the Direct3D rendering API. In conjunction with the Gallium3D Direct3D 9 State Tracker, Direct3D 9 games can be played at high frame rates on Linux.

Device driver implementations[edit]

DRI and Gallium3D have different driver models. Both share a lot of free and open-sourcecode

The available free and open-source device drivers for graphic chipsets are "stewarded" by Mesa (because the existent free and open-source implementation of APIs are developed inside of Mesa). Currently there are two frameworks to write graphics drivers: DRI and Gallium3D.

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.[15]

The free and open-source drivers do compete with the proprietary closed-source driver written by the developers. 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 [1][2][3][4][5], with some notable exceptions, where the free and open-source driver perform better than the vendor drivers.

Direct Rendering Infrastructure (DRI)[edit]

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.[When?] 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.[5]

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.[5]

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.[16]

Gallium3D[edit]

Main article: 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. 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.

Software renderer[edit]

Mesa also contains an implementation to do software rendering.

Critique[edit]

The Mesa 3D project writes the free and open-source implementations of the APIs as well as the graphic device drivers. And it is limping behind the releases of new API versions.[17]

History[edit]

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 ofVOGL.[18] 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 tographics 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.

Mesa (computer graphics)的更多相关文章

  1. Computer Graphics Research Software

    Computer Graphics Research Software Helping you avoid re-inventing the wheel since 2009! Last update ...

  2. 水题 HDOJ 4716 A Computer Graphics Problem

    题目传送门 /* 水题:看见x是十的倍数就简单了 */ #include <cstdio> #include <iostream> #include <algorithm ...

  3. Mathematics for Computer Graphics数学在计算机图形学中的应用 [转]

    最近严重感觉到数学知识的不足! http://bbs.gameres.com/showthread.asp?threadid=10509 [译]Mathematics for Computer Gra ...

  4. Computer Graphics Thinking–texture tiling

    Here is one question: how to tile texture? One thing worth to notice: The DirectX and OpenGL stipula ...

  5. HDU 4716 A Computer Graphics Problem

    A Computer Graphics Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  6. Mathematics for Computer Graphics

    Mathematics for Computer Graphics 最近严重感觉到数学知识的不足! http://bbs.gameres.com/showthread.asp?threadid=105 ...

  7. Vector Math for 3D Computer Graphics (Bradley Kjell 著)

    https://chortle.ccsu.edu/VectorLessons/index.html Chapter0 Points and Lines (已看) Chapter1 Vectors, P ...

  8. Fundamentals of Computer Graphics 中文版(第二版) (Peter Shirley 著)

    1 引言 2 数学知识 3 光栅算法 4 信号处理 5 线性代数 6 矩阵变换 7 观察 8 隐藏面消除 9 表面明暗处理 10 光线追踪 11 纹理映射 12 完整的图形流水线 13 图形学的数据结 ...

  9. HDU 4716 A Computer Graphics Problem (水题)

    A Computer Graphics Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

随机推荐

  1. python基础——14(shelve/shutil/random/logging模块/标准流)

    一.标准流 1.1.标准输入流 res = sys.stdin.read(3) 可以设置读取的字节数 print(res) res = sys.stdin.readline() print(res) ...

  2. 【01】blockqote美化

    [01]blockqote美化   <!DOCTYPE html> <html lang="zh-cn"> <head> <meta ch ...

  3. joyoi1957 「Poetize5」Vani和Cl2捉迷藏

    最小路径可重点覆盖.先传递闭包,然后拆点,\(n-\)最大匹配,看算法竞赛进阶指南. #include <iostream> #include <cstring> #inclu ...

  4. joyoi1935 「Poetize3」导弹防御塔

    #include <iostream> #include <cstring> #include <cstdio> #include <queue> #i ...

  5. pycharm中脚本执行的3种模式(unittest框架、pytest框架、普通模式)

    背景知识,某次使用HTMLTestRunner的时候,发现一直都无法导出报告,后来查询资料发现了一些坑,现在整理一下来龙去脉. 一:pycharm默认的是pytest框架去执行unittest框架的测 ...

  6. [LoadRunner]LR性能测试结果样例分析

    R性能测试结果样例分析 测试结果分析 LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源. ...

  7. 检测SQLserver数据库链接是否正常

    select * From [数据库链接名].master.dbo.sysdatabases where name='数据库名' and status<>512

  8. 九度oj 题目1107:搬水果

    题目描述: 在一个果园里,小明已经将所有的水果打了下来,并按水果的不同种类分成了若干堆,小明决定把所有的水果合成一堆.每一次合并,小明可以把两堆水果合并到一起,消耗的体力等于两堆水果的重量之和.当然经 ...

  9. 送信 okhttp

    package jp.co.gunmabank.minefocus.accountApp import android.content.Intentimport android.graphics.Co ...

  10. BZOJ 3990 [SDOI2015]排序 ——搜索

    [题目分析] 可以发现,操作的先后顺序是不影响结果的,那么答案就是n!的和. 可以从小的步骤开始搜索,使得每一个当前最小的块都是上升的数列,然后看看是否可行即可. 复杂度好像是4^n [代码](哪里写 ...