MESA_program_binary_formats
Name
MESA_program_binary_formats
Name Strings
GL_MESA_program_binary_formats
Contributors
Ian Romanick
Jordan Justen
Timothy Arceri
Contact
Jordan Justen (jordan.l.justen 'at' intel.com)
Status
Complete.
Version
Last Modified Date: November 10, 2017
Revision: #2
Number
OpenGL Extension #516
OpenGL ES Extension #294
Dependencies
For use with the OpenGL ARB_get_program_binary extension, or the
OpenGL ES OES_get_program_binary extension.
Overview
The get_program_binary exensions require a GLenum binaryFormat.
This extension documents that format for use with Mesa.
New Procedures and Functions
None.
New Tokens
GL_PROGRAM_BINARY_FORMAT_MESA 0x875F
For ARB_get_program_binary, GL_PROGRAM_BINARY_FORMAT_MESA may be
returned from GetProgramBinary calls in the <binaryFormat>
parameter and when retrieving the value of PROGRAM_BINARY_FORMATS.
For OES_get_program_binary, GL_PROGRAM_BINARY_FORMAT_MESA may be
returned from GetProgramBinaryOES calls in the <binaryFormat>
parameter and when retrieving the value of
PROGRAM_BINARY_FORMATS_OES.
New State
None.
Issues
(1) Should we have a different format for each driver?
RESOLVED. Since Mesa supports multiple hardware drivers, having
a single format may cause separate drivers to have to reject a
binary for another type of hardware on the same machine. This
could lead to an application having to invalidate and get a new
binary more often.
This extension, at least initially, does not to attempt to
define a new token for each driver since systems that run
multiple drivers are not the common case.
Additionally, drivers in Mesa are now gaining the ability to
transparently cache shader programs. Therefore, although they
may need to provide the application with a new binary more
often, they likely can retrieve the program from the cache
rather than performing an expensive recompile.
Revision History
#02 11/10/2017 Jordan Justen Add Issues (1) suggested by Ian
#01 10/28/2017 Jordan Justen First draft.