[Mesa-dev] [PATCH 1/2] egl: add optional plat_opt to _eglFindDisplay()
Emil Velikov
emil.l.velikov at gmail.com
Thu Apr 4 15:25:27 UTC 2019
From: Emil Velikov <emil.velikov at collabora.com>
The EGL_EXT_platform_device extension will be coming shortly. It will
effectively require comparing the platform specific options, passed via
the attribs array.
Cc: Mathias Fröhlich <Mathias.Froehlich at gmx.net>
Cc: Marek Olšák <maraeo at gmail.com>
Signed-off-by: Emil Velikov <emil.velikov at collabora.com>
---
I'm not a huge fan of this. Yet again the other platform (x11) that uses
these has a number of issues, see below for details. Once those are resolved
we could try and make this more uniform.
a) spec does not mention if a new (or the existing) EGLDislay should be
given for same native_dpy/screen_no combo.
b) the implementation has number of issues:
- screen 0 is hardcoded when using DEFAULT_DISPLAY
- screen is _ignored_ when using !DEFAULT_DISPLAY
---
src/egl/main/eglapi.c | 2 +-
src/egl/main/egldisplay.c | 12 +++++++-----
src/egl/main/egldisplay.h | 2 +-
3 files changed, 9 insertions(+), 7 deletions(-)
diff --git a/src/egl/main/eglapi.c b/src/egl/main/eglapi.c
index 588c6a5f1eb..4696eca8f82 100644
--- a/src/egl/main/eglapi.c
+++ b/src/egl/main/eglapi.c
@@ -379,7 +379,7 @@ eglGetDisplay(EGLNativeDisplayType nativeDisplay)
native_display_ptr = (void*) nativeDisplay;
plat = _eglGetNativePlatform(native_display_ptr);
- disp = _eglFindDisplay(plat, native_display_ptr);
+ disp = _eglFindDisplay(plat, native_display_ptr, NULL);
return _eglGetDisplayHandle(disp);
}
diff --git a/src/egl/main/egldisplay.c b/src/egl/main/egldisplay.c
index b26a9575087..e8ef3d8ed93 100644
--- a/src/egl/main/egldisplay.c
+++ b/src/egl/main/egldisplay.c
@@ -211,9 +211,11 @@ _eglFiniDisplay(void)
/**
* Find the display corresponding to the specified native display, or create a
* new one.
+ *
+ * Certain platform types can use plat_opt.
*/
_EGLDisplay *
-_eglFindDisplay(_EGLPlatformType plat, void *plat_dpy)
+_eglFindDisplay(_EGLPlatformType plat, void *plat_dpy, void *plat_opt)
{
_EGLDisplay *disp;
@@ -477,7 +479,7 @@ _eglGetX11Display(Display *native_display,
const EGLAttrib *attrib_list)
{
_EGLDisplay *display = _eglFindDisplay(_EGL_PLATFORM_X11,
- native_display);
+ native_display, NULL);
if (!display) {
_eglError(EGL_BAD_ALLOC, "eglGetPlatformDisplay");
@@ -503,7 +505,7 @@ _eglGetGbmDisplay(struct gbm_device *native_display,
return NULL;
}
- return _eglFindDisplay(_EGL_PLATFORM_DRM, native_display);
+ return _eglFindDisplay(_EGL_PLATFORM_DRM, native_display, NULL);
}
#endif /* HAVE_DRM_PLATFORM */
@@ -518,7 +520,7 @@ _eglGetWaylandDisplay(struct wl_display *native_display,
return NULL;
}
- return _eglFindDisplay(_EGL_PLATFORM_WAYLAND, native_display);
+ return _eglFindDisplay(_EGL_PLATFORM_WAYLAND, native_display, NULL);
}
#endif /* HAVE_WAYLAND_PLATFORM */
@@ -539,6 +541,6 @@ _eglGetSurfacelessDisplay(void *native_display,
return NULL;
}
- return _eglFindDisplay(_EGL_PLATFORM_SURFACELESS, native_display);
+ return _eglFindDisplay(_EGL_PLATFORM_SURFACELESS, native_display, NULL);
}
#endif /* HAVE_SURFACELESS_PLATFORM */
diff --git a/src/egl/main/egldisplay.h b/src/egl/main/egldisplay.h
index cfd0ff66d64..a7c2641b600 100644
--- a/src/egl/main/egldisplay.h
+++ b/src/egl/main/egldisplay.h
@@ -202,7 +202,7 @@ _eglFiniDisplay(void);
extern _EGLDisplay *
-_eglFindDisplay(_EGLPlatformType plat, void *plat_dpy);
+_eglFindDisplay(_EGLPlatformType plat, void *plat_dpy, void *plat_opt);
extern void
--
2.21.0
More information about the mesa-dev
mailing list