aboutsummaryrefslogtreecommitdiff
path: root/mesalib/docs/specs/MESA_configless_context.spec
blob: f2fafb35a19376f76448cab28afec15c98b4bd02 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
Name

    MESA_configless_context

Name Strings

    EGL_MESA_configless_context

Contact

    Neil Roberts <neil.s.roberts@intel.com>

Status

    Proposal

Version

    Version 1, February 28, 2014

Number

    EGL Extension #not assigned

Dependencies

    Requires EGL 1.4 or later.  This extension is written against the
    wording of the EGL 1.4 specification.

Overview

    This extension provides a means to use a single context to render to
    multiple surfaces which have different EGLConfigs. Without this extension
    the EGLConfig for every surface used by the context must be compatible
    with the one used by the context. The only way to render to surfaces with
    different formats would be to create multiple contexts but this is
    inefficient with modern GPUs where this restriction is unnecessary.

IP Status

    Open-source; freely implementable.

New Procedures and Functions

    None.

New Tokens

    Accepted as <config> in eglCreateContext

        EGL_NO_CONFIG_MESA                  ((EGLConfig)0)

Additions to the EGL Specification section "2.2 Rendering Contexts and Drawing
Surfaces"

    Add the following to the 3rd paragraph:

   "EGLContexts can also optionally be created with respect to an EGLConfig
    depending on the parameters used at creation time. If a config is provided
    then additional restrictions apply on what surfaces can be used with the
    context."

    Replace the last sentence of the 6th paragraph with:

   "In order for a context to be compatible with a surface they both must have
    been created with respect to the same EGLDisplay. If the context was
    created without respect to an EGLConfig then there are no further
    constraints. Otherwise they are only compatible if:"

    Remove the last bullet point in the list of constraints.

Additions to the EGL Specification section "3.7.1 Creating Rendering Contexts"

    Replace the paragraph starting "If config is not a valid EGLConfig..."
    with

   "The config argument can either be a valid EGLConfig or EGL_NO_CONFIG_MESA.
    If it is neither of these then an EGL_BAD_CONFIG error is generated. If a
    valid config is passed then the error will also be generated if the config
    does not support the requested client API (this includes requesting
    creation of an OpenGL ES 1.x context when the EGL_RENDERABLE_TYPE
    attribute of config does not contain EGL_OPENGL_ES_BIT, or creation of an
    OpenGL ES 2.x context when the attribute does not contain
    EGL_OPENGL_ES2_BIT).

    Passing EGL_NO_CONFIG_MESA will create a configless context. When a
    configless context is used with the OpenGL API it can be assumed that the
    initial values of the context's state will be decided when the context is
    first made current. In particular this means that the decision of whether
    to use GL_BACK or GL_FRONT for the initial value of the first output in
    glDrawBuffers will be decided based on the config of the draw surface when
    it is first bound."

Additions to the EGL Specification section "3.7.3 Binding Contexts and
Drawables"

    Replace the first bullet point with the following:

   "* If draw or read are not compatible with ctx as described in section 2.2,
      then an EGL_BAD_MATCH error is generated."

    Add a second bullet point after that:

   "* If draw and read are not compatible with each other as described in
      section 2.2, then an EGL_BAD_MATCH error is generated."

Issues

    1.  What happens when an OpenGL context with a double-buffered surface and
        draw buffer set to GL_BACK is made current with a single-buffered
        surface?

        NOT RESOLVED: There are a few options here.  An implementation can
        raise an error, change the drawbuffer state to GL_FRONT or just do
        nothing, expecting the application to set GL_FRONT drawbuffer before
        drawing.  However, this extension deliberately does not specify any
        required behavior in this corner case and applications should avoid
        mixing single- and double-buffered surfaces with configless contexts.

        Future extensions may specify required behavior in this case.

Revision History

    Version 1, February 28, 2014
        Initial draft (Neil Roberts)