egldisplay.h revision 63beb3df98147f34fd0965cb0afbb97444206d0c
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 41enum _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}; 53typedef enum _egl_platform_type _EGLPlatformType; 54 55 56enum _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 */ 65typedef enum _egl_resource_type _EGLResourceType; 66 67 68/** 69 * A resource of a display. 70 */ 71struct _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 */ 86struct _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_context; 107 EGLBoolean KHR_create_context; 108 109 EGLBoolean NOK_swap_region; 110 EGLBoolean NOK_texture_from_pixmap; 111 112 EGLBoolean ANDROID_image_native_buffer; 113 114 EGLBoolean NV_post_sub_buffer; 115}; 116 117 118struct _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 157extern _EGLPlatformType 158_eglGetNativePlatform(EGLNativeDisplayType nativeDisplay); 159 160 161extern void 162_eglFiniDisplay(void); 163 164 165extern _EGLDisplay * 166_eglFindDisplay(_EGLPlatformType plat, void *plat_dpy); 167 168 169PUBLIC void 170_eglReleaseDisplayResources(_EGLDriver *drv, _EGLDisplay *dpy); 171 172 173PUBLIC void 174_eglCleanupDisplay(_EGLDisplay *disp); 175 176 177extern EGLBoolean 178_eglCheckDisplayHandle(EGLDisplay dpy); 179 180 181PUBLIC 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 */ 189static 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 */ 202static INLINE EGLDisplay 203_eglGetDisplayHandle(_EGLDisplay *dpy) 204{ 205 return (EGLDisplay) ((dpy) ? dpy : EGL_NO_DISPLAY); 206} 207 208 209extern void 210_eglInitResource(_EGLResource *res, EGLint size, _EGLDisplay *dpy); 211 212 213PUBLIC void 214_eglGetResource(_EGLResource *res); 215 216 217PUBLIC EGLBoolean 218_eglPutResource(_EGLResource *res); 219 220 221extern void 222_eglLinkResource(_EGLResource *res, _EGLResourceType type); 223 224 225extern void 226_eglUnlinkResource(_EGLResource *res, _EGLResourceType type); 227 228 229/** 230 * Return true if the resource is linked. 231 */ 232static INLINE EGLBoolean 233_eglIsResourceLinked(_EGLResource *res) 234{ 235 return res->IsLinked; 236} 237 238 239#endif /* EGLDISPLAY_INCLUDED */ 240