egl: add null platform
[mesa.git] / src / egl / main / egldisplay.h
1 /**************************************************************************
2 *
3 * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
4 * Copyright 2009-2010 Chia-I Wu <olvaffe@gmail.com>
5 * Copyright 2010-2011 LunarG, Inc.
6 * All Rights Reserved.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a
9 * copy of this software and associated documentation files (the
10 * "Software"), to deal in the Software without restriction, including
11 * without limitation the rights to use, copy, modify, merge, publish,
12 * distribute, sub license, and/or sell copies of the Software, and to
13 * permit persons to whom the Software is furnished to do so, subject to
14 * the following conditions:
15 *
16 * The above copyright notice and this permission notice (including the
17 * next paragraph) shall be included in all copies or substantial portions
18 * of the Software.
19 *
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
23 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
25 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
26 * DEALINGS IN THE SOFTWARE.
27 *
28 **************************************************************************/
29
30
31 #ifndef EGLDISPLAY_INCLUDED
32 #define EGLDISPLAY_INCLUDED
33
34
35 #include "egltypedefs.h"
36 #include "egldefines.h"
37 #include "eglmutex.h"
38 #include "eglarray.h"
39
40
41 enum _egl_platform_type {
42 _EGL_PLATFORM_WINDOWS,
43 _EGL_PLATFORM_X11,
44 _EGL_PLATFORM_WAYLAND,
45 _EGL_PLATFORM_DRM,
46 _EGL_PLATFORM_FBDEV,
47 _EGL_PLATFORM_NULL,
48 _EGL_PLATFORM_ANDROID,
49
50 _EGL_NUM_PLATFORMS,
51 _EGL_INVALID_PLATFORM = -1
52 };
53 typedef enum _egl_platform_type _EGLPlatformType;
54
55
56 enum _egl_resource_type {
57 _EGL_RESOURCE_CONTEXT,
58 _EGL_RESOURCE_SURFACE,
59 _EGL_RESOURCE_IMAGE,
60 _EGL_RESOURCE_SYNC,
61
62 _EGL_NUM_RESOURCES
63 };
64 /* this cannot and need not go into egltypedefs.h */
65 typedef enum _egl_resource_type _EGLResourceType;
66
67
68 /**
69 * A resource of a display.
70 */
71 struct _egl_resource
72 {
73 /* which display the resource belongs to */
74 _EGLDisplay *Display;
75 EGLBoolean IsLinked;
76 EGLint RefCount;
77
78 /* used to link resources of the same type */
79 _EGLResource *Next;
80 };
81
82
83 /**
84 * Optional EGL extensions info.
85 */
86 struct _egl_extensions
87 {
88 EGLBoolean MESA_screen_surface;
89 EGLBoolean MESA_copy_context;
90 EGLBoolean MESA_drm_display;
91 EGLBoolean MESA_drm_image;
92
93 EGLBoolean WL_bind_wayland_display;
94
95 EGLBoolean KHR_image_base;
96 EGLBoolean KHR_image_pixmap;
97 EGLBoolean KHR_vg_parent_image;
98 EGLBoolean KHR_gl_texture_2D_image;
99 EGLBoolean KHR_gl_texture_cubemap_image;
100 EGLBoolean KHR_gl_texture_3D_image;
101 EGLBoolean KHR_gl_renderbuffer_image;
102
103 EGLBoolean KHR_reusable_sync;
104 EGLBoolean KHR_fence_sync;
105
106 EGLBoolean KHR_surfaceless_gles1;
107 EGLBoolean KHR_surfaceless_gles2;
108 EGLBoolean KHR_surfaceless_opengl;
109
110 EGLBoolean NOK_swap_region;
111 EGLBoolean NOK_texture_from_pixmap;
112
113 EGLBoolean ANDROID_image_native_buffer;
114 EGLBoolean ANDROID_swap_rectangle;
115 };
116
117
118 struct _egl_display
119 {
120 /* used to link displays */
121 _EGLDisplay *Next;
122
123 _EGLMutex Mutex;
124
125 _EGLPlatformType Platform; /**< The type of the platform display */
126 void *PlatformDisplay; /**< A pointer to the platform display */
127
128 _EGLDriver *Driver; /**< Matched driver of the display */
129 EGLBoolean Initialized; /**< True if the display is initialized */
130
131 /* options that affect how the driver initializes the display */
132 struct {
133 EGLBoolean TestOnly; /**< Driver should not set fields when true */
134 EGLBoolean UseFallback; /**< Use fallback driver (sw or less features) */
135 } Options;
136
137 /* these fields are set by the driver during init */
138 void *DriverData; /**< Driver private data */
139 EGLint VersionMajor; /**< EGL major version */
140 EGLint VersionMinor; /**< EGL minor version */
141 EGLint ClientAPIs; /**< Bitmask of APIs supported (EGL_xxx_BIT) */
142 _EGLExtensions Extensions; /**< Extensions supported */
143
144 /* these fields are derived from above */
145 char VersionString[1000]; /**< EGL_VERSION */
146 char ClientAPIsString[1000]; /**< EGL_CLIENT_APIS */
147 char ExtensionsString[_EGL_MAX_EXTENSIONS_LEN]; /**< EGL_EXTENSIONS */
148
149 _EGLArray *Screens;
150 _EGLArray *Configs;
151
152 /* lists of resources */
153 _EGLResource *ResourceLists[_EGL_NUM_RESOURCES];
154 };
155
156
157 extern _EGLPlatformType
158 _eglGetNativePlatform(EGLNativeDisplayType nativeDisplay);
159
160
161 extern void
162 _eglFiniDisplay(void);
163
164
165 extern _EGLDisplay *
166 _eglFindDisplay(_EGLPlatformType plat, void *plat_dpy);
167
168
169 PUBLIC void
170 _eglReleaseDisplayResources(_EGLDriver *drv, _EGLDisplay *dpy);
171
172
173 PUBLIC void
174 _eglCleanupDisplay(_EGLDisplay *disp);
175
176
177 extern EGLBoolean
178 _eglCheckDisplayHandle(EGLDisplay dpy);
179
180
181 PUBLIC EGLBoolean
182 _eglCheckResource(void *res, _EGLResourceType type, _EGLDisplay *dpy);
183
184
185 /**
186 * Lookup a handle to find the linked display.
187 * Return NULL if the handle has no corresponding linked display.
188 */
189 static INLINE _EGLDisplay *
190 _eglLookupDisplay(EGLDisplay display)
191 {
192 _EGLDisplay *dpy = (_EGLDisplay *) display;
193 if (!_eglCheckDisplayHandle(display))
194 dpy = NULL;
195 return dpy;
196 }
197
198
199 /**
200 * Return the handle of a linked display, or EGL_NO_DISPLAY.
201 */
202 static INLINE EGLDisplay
203 _eglGetDisplayHandle(_EGLDisplay *dpy)
204 {
205 return (EGLDisplay) ((dpy) ? dpy : EGL_NO_DISPLAY);
206 }
207
208
209 extern void
210 _eglInitResource(_EGLResource *res, EGLint size, _EGLDisplay *dpy);
211
212
213 PUBLIC void
214 _eglGetResource(_EGLResource *res);
215
216
217 PUBLIC EGLBoolean
218 _eglPutResource(_EGLResource *res);
219
220
221 extern void
222 _eglLinkResource(_EGLResource *res, _EGLResourceType type);
223
224
225 extern void
226 _eglUnlinkResource(_EGLResource *res, _EGLResourceType type);
227
228
229 /**
230 * Return true if the resource is linked.
231 */
232 static INLINE EGLBoolean
233 _eglIsResourceLinked(_EGLResource *res)
234 {
235 return res->IsLinked;
236 }
237
238
239 #endif /* EGLDISPLAY_INCLUDED */