On Wednesday, 2018-09-05 15:09:19 +0100, Emil Velikov wrote: > On 4 September 2018 at 20:34, Eric Engestrom <eric.engest...@intel.com> wrote: > > On Tuesday, 2018-09-04 20:33:33 +0100, Eric Engestrom wrote: > >> On Tuesday, 2018-09-04 19:32:58 +0100, Emil Velikov wrote: > >> > From: Emil Velikov <emil.veli...@collabora.com> > >> > > >> > Introduce the API for device query and enumeration. Those at the moment > >> > produce nothing useful since zero devices are actually available. > >> > > >> > That contradicts with the spec, so the extension isn't advertised just > >> > yet. > >> > > >> > With later commits we'll add support for software (always) and hardware > >> > devices. Each one exposing the respective extension string. > >> > > >> > v2: > >> > - fold API boilerplate into this patch > >> > - move _eglAddDevice, _eglDeviceSupports, _eglRefreshDeviceList to this > >> > patch (Eric, Mathias) > >> > - make _eglFiniDevice the one called last > >> > > >> > Signed-off-by: Emil Velikov <emil.veli...@collabora.com> > >> > --- > >> > src/egl/Makefile.sources | 2 + > >> > src/egl/main/eglapi.c | 64 +++++++++++++ > >> > src/egl/main/egldevice.c | 179 +++++++++++++++++++++++++++++++++++ > >> > src/egl/main/egldevice.h | 83 ++++++++++++++++ > >> > src/egl/main/egldisplay.h | 1 + > >> > src/egl/main/eglentrypoint.h | 4 + > >> > src/egl/main/eglglobals.c | 8 +- > >> > src/egl/main/eglglobals.h | 2 + > >> > src/egl/main/egltypedefs.h | 2 + > >> > src/egl/meson.build | 2 + > >> > 10 files changed, 344 insertions(+), 3 deletions(-) > >> > create mode 100644 src/egl/main/egldevice.c > >> > create mode 100644 src/egl/main/egldevice.h > >> > > >> > diff --git a/src/egl/Makefile.sources b/src/egl/Makefile.sources > >> > index 82f13ad3cbd..0cc5f1bbfef 100644 > >> > --- a/src/egl/Makefile.sources > >> > +++ b/src/egl/Makefile.sources > >> > @@ -10,6 +10,8 @@ LIBEGL_C_FILES := \ > >> > main/eglcurrent.c \ > >> > main/eglcurrent.h \ > >> > main/egldefines.h \ > >> > + main/egldevice.c \ > >> > + main/egldevice.h \ > >> > main/egldisplay.c \ > >> > main/egldisplay.h \ > >> > main/egldriver.c \ > >> > diff --git a/src/egl/main/eglapi.c b/src/egl/main/eglapi.c > >> > index c8c6a50f6ad..6df5e841463 100644 > >> > --- a/src/egl/main/eglapi.c > >> > +++ b/src/egl/main/eglapi.c > >> > @@ -95,6 +95,7 @@ > >> > #include "egldisplay.h" > >> > #include "egltypedefs.h" > >> > #include "eglcurrent.h" > >> > +#include "egldevice.h" > >> > #include "egldriver.h" > >> > #include "eglsurface.h" > >> > #include "eglconfig.h" > >> > @@ -2575,6 +2576,69 @@ eglSetBlobCacheFuncsANDROID(EGLDisplay *dpy, > >> > EGLSetBlobFuncANDROID set, > >> > _eglUnlockDisplay(disp); > >> > } > >> > > >> > +static EGLBoolean EGLAPIENTRY > >> > +eglQueryDeviceAttribEXT(EGLDeviceEXT device, > >> > + EGLint attribute, > >> > + EGLAttrib *value) > >> > +{ > >> > + _EGLDevice *dev = _eglLookupDevice(device); > >> > + EGLBoolean ret; > >> > + > >> > + _EGL_FUNC_START(NULL, EGL_NONE, NULL, EGL_FALSE); > >> > + if (!dev) > >> > + RETURN_EGL_ERROR(NULL, EGL_BAD_DEVICE_EXT, EGL_FALSE); > >> > + > >> > + ret = _eglQueryDeviceAttribEXT(dev, attribute, value); > >> > + RETURN_EGL_EVAL(NULL, ret); > >> > +} > >> > + > >> > +static const char * EGLAPIENTRY > >> > +eglQueryDeviceStringEXT(EGLDeviceEXT device, > >> > + EGLint name) > >> > +{ > >> > + _EGLDevice *dev = _eglLookupDevice(device); > >> > + > >> > + _EGL_FUNC_START(NULL, EGL_NONE, NULL, NULL); > >> > + if (!dev) > >> > + RETURN_EGL_ERROR(NULL, EGL_BAD_DEVICE_EXT, NULL); > >> > + > >> > + RETURN_EGL_EVAL(NULL, _eglQueryDeviceStringEXT(dev, name)); > >> > +} > >> > + > >> > +static EGLBoolean EGLAPIENTRY > >> > +eglQueryDevicesEXT(EGLint max_devices, > >> > + EGLDeviceEXT *devices, > >> > + EGLint *num_devices) > >> > +{ > >> > + EGLBoolean ret; > >> > + > >> > + _EGL_FUNC_START(NULL, EGL_NONE, NULL, EGL_FALSE); > >> > + ret = _eglQueryDevicesEXT(max_devices, (_EGLDevice **) devices, > >> > + num_devices); > >> > + RETURN_EGL_EVAL(NULL, ret); > >> > +} > >> > + > >> > +static EGLBoolean EGLAPIENTRY > >> > +eglQueryDisplayAttribEXT(EGLDisplay dpy, > >> > + EGLint attribute, > >> > + EGLAttrib *value) > >> > +{ > >> > + _EGLDisplay *disp = _eglLockDisplay(dpy); > >> > + _EGLDriver *drv; > >> > + > >> > + _EGL_FUNC_START(NULL, EGL_NONE, NULL, EGL_FALSE); > >> > + _EGL_CHECK_DISPLAY(disp, EGL_FALSE, drv); > >> > + > >> > + switch (attribute) { > >> > + case EGL_DEVICE_EXT: > >> > + *value = (EGLAttrib) disp->Device; > >> > + break; > >> > + default: > >> > + RETURN_EGL_ERROR(disp, EGL_BAD_ATTRIBUTE, EGL_FALSE); > >> > + } > >> > + RETURN_EGL_SUCCESS(disp, EGL_TRUE); > >> > +} > >> > + > >> > __eglMustCastToProperFunctionPointerType EGLAPIENTRY > >> > eglGetProcAddress(const char *procname) > >> > { > >> > diff --git a/src/egl/main/egldevice.c b/src/egl/main/egldevice.c > >> > new file mode 100644 > >> > index 00000000000..bbc9f2060d1 > >> > --- /dev/null > >> > +++ b/src/egl/main/egldevice.c > >> > @@ -0,0 +1,179 @@ > >> > +/************************************************************************** > >> > + * > >> > + * Copyright 2015, 2018 Collabora > >> > + * All Rights Reserved. > >> > + * > >> > + * Permission is hereby granted, free of charge, to any person > >> > obtaining a > >> > + * copy of this software and associated documentation files (the > >> > + * "Software"), to deal in the Software without restriction, including > >> > + * without limitation the rights to use, copy, modify, merge, publish, > >> > + * distribute, sub license, and/or sell copies of the Software, and to > >> > + * permit persons to whom the Software is furnished to do so, subject to > >> > + * the following conditions: > >> > + * > >> > + * The above copyright notice and this permission notice (including the > >> > + * next paragraph) shall be included in all copies or substantial > >> > portions > >> > + * of the Software. > >> > + * > >> > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, > >> > EXPRESS OR > >> > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF > >> > MERCHANTABILITY, > >> > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT > >> > SHALL > >> > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR > >> > OTHER > >> > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, > >> > ARISING > >> > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER > >> > + * DEALINGS IN THE SOFTWARE. > >> > + * > >> > + > >> > **************************************************************************/ > >> > + > >> > +#include "util/macros.h" > >> > + > >> > +#include "eglcurrent.h" > >> > +#include "egldevice.h" > >> > +#include "eglglobals.h" > >> > +#include "egltypedefs.h" > >> > + > >> > + > >> > +struct _egl_device { > >> > + _EGLDevice *Next; > >> > + > >> > + const char *extensions; > >> > +}; > >> > + > >> > +void > >> > +_eglFiniDevice(void) > >> > +{ > >> > + _EGLDevice *dev_list, *dev; > >> > + > >> > + /* atexit function is called with global mutex locked */ > >> > + > >> > + dev_list = _eglGlobal.DeviceList; > >> > + while (dev_list) { > >> > + /* pop list head */ > >> > + dev = dev_list; > >> > + dev_list = dev_list->Next; > >> > + > >> > + free(dev); > >> > + } > >> > + > >> > + _eglGlobal.DeviceList = NULL; > >> > +} > >> > + > >> > +EGLBoolean > >> > +_eglCheckDeviceHandle(EGLDeviceEXT device) > >> > +{ > >> > + _EGLDevice *cur; > >> > + > >> > + mtx_lock(_eglGlobal.Mutex); > >> > + cur = _eglGlobal.DeviceList; > >> > + while (cur) { > >> > + if (cur == (_EGLDevice *) device) > >> > + break; > >> > + cur = cur->Next; > >> > + } > >> > + mtx_unlock(_eglGlobal.Mutex); > >> > + return (cur != NULL); > >> > +} > >> > + > >> > +/* Adds a device in DeviceList, if needed for the given fd. > >> > + * > >> > + * If a software device, the fd is ignored. > >> > + */ > >> > +_EGLDevice * > >> > +_eglAddDevice(int fd, bool software) > >> > +{ > >> > + _EGLDevice *dev; > >> > + > >> > + mtx_lock(_eglGlobal.Mutex); > >> > + > >> > + dev = NULL; > >> > + > >> > +out: > >> > + mtx_unlock(_eglGlobal.Mutex); > >> > + return dev; > >> > +} > >> > + > >> > +EGLBoolean > >> > +_eglDeviceSupports(_EGLDevice *dev, _EGLDeviceExtension ext) > >> > +{ > >> > + switch (ext) { > >> > + default: > >> > + assert(0); > >> > + return EGL_FALSE; > >> > + }; > >> > +} > >> > + > >> > +EGLBoolean > >> > +_eglQueryDeviceAttribEXT(_EGLDevice *dev, EGLint attribute, > >> > + EGLAttrib *value) > >> > +{ > >> > + switch (attribute) { > >> > + default: > >> > + _eglError(EGL_BAD_ATTRIBUTE, "eglQueryDeviceStringEXT"); > >> > + return EGL_FALSE; > >> > + } > >> > +} > >> > + > >> > +const char * > >> > +_eglQueryDeviceStringEXT(_EGLDevice *dev, EGLint name) > >> > +{ > >> > + switch (name) { > >> > + case EGL_EXTENSIONS: > >> > + return dev->extensions; > >> > + default: > >> > + _eglError(EGL_BAD_PARAMETER, "eglQueryDeviceStringEXT"); > >> > + return NULL; > >> > + }; > >> > +} > >> > + > >> > +/* Do a fresh lookup for devices. > >> > + * > >> > + * Walks through the DeviceList, discarding no longer available ones > >> > + * and adding new ones as applicable. > >> > + * > >> > + * Must be called with the global lock held. > >> > + */ > >> > +static int > >> > +_eglRefreshDeviceList(void) > >> > +{ > >> > + _EGLDevice *dev; > >> > + int count = 0; > >> > + > >> > + dev = _eglGlobal.DeviceList; > >> > + > >> > + return count; > >> > +} > >> > + > >> > +EGLBoolean > >> > +_eglQueryDevicesEXT(EGLint max_devices, > >> > + _EGLDevice **devices, > >> > + EGLint *num_devices) > >> > +{ > >> > + _EGLDevice *dev, *devs; > >> > + int i = 0, num_devs; > >> > + > >> > + if ((devices && max_devices <= 0) || !num_devices) > >> > + return _eglError(EGL_BAD_PARAMETER, "eglQueryDevicesEXT"); > >> > + > >> > + mtx_lock(_eglGlobal.Mutex); > >> > + > >> > + num_devs = _eglRefreshDeviceList(); > >> > + devs = _eglGlobal.DeviceList; > >> > + > >> > + /* bail early if we only care about the count */ > >> > + if (!devices) { > >> > + *num_devices = num_devs; > >> > + goto out; > >> > + } > >> > + > >> > + *num_devices = MIN2(num_devs, max_devices); > >> > + > >> > + for (i = 0, dev = devs; i < *num_devices; i++) { > >> > + devices[i] = dev; > >> > + dev = dev->Next; > >> > + } > >> > + > >> > +out: > >> > + mtx_unlock(_eglGlobal.Mutex); > >> > + > >> > + return EGL_TRUE; > >> > +} > >> > diff --git a/src/egl/main/egldevice.h b/src/egl/main/egldevice.h > >> > new file mode 100644 > >> > index 00000000000..72d250393f4 > >> > --- /dev/null > >> > +++ b/src/egl/main/egldevice.h > >> > @@ -0,0 +1,83 @@ > >> > +/************************************************************************** > >> > + * > >> > + * Copyright 2015, 2018 Collabora > >> > + * All Rights Reserved. > >> > + * > >> > + * Permission is hereby granted, free of charge, to any person > >> > obtaining a > >> > + * copy of this software and associated documentation files (the > >> > + * "Software"), to deal in the Software without restriction, including > >> > + * without limitation the rights to use, copy, modify, merge, publish, > >> > + * distribute, sub license, and/or sell copies of the Software, and to > >> > + * permit persons to whom the Software is furnished to do so, subject to > >> > + * the following conditions: > >> > + * > >> > + * The above copyright notice and this permission notice (including the > >> > + * next paragraph) shall be included in all copies or substantial > >> > portions > >> > + * of the Software. > >> > + * > >> > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, > >> > EXPRESS OR > >> > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF > >> > MERCHANTABILITY, > >> > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT > >> > SHALL > >> > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR > >> > OTHER > >> > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, > >> > ARISING > >> > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER > >> > + * DEALINGS IN THE SOFTWARE. > >> > + * > >> > + > >> > **************************************************************************/ > >> > + > >> > + > >> > +#ifndef EGLDEVICE_INCLUDED > >> > +#define EGLDEVICE_INCLUDED > >> > + > >> > + > >> > +#include <stdbool.h> > >> > +#include "egltypedefs.h" > >> > + > >> > + > >> > +#ifdef __cplusplus > >> > +extern "C" { > >> > +#endif > >> > + > >> > +void > >> > +_eglFiniDevice(void); > >> > + > >> > +EGLBoolean > >> > +_eglCheckDeviceHandle(EGLDeviceEXT device); > >> > + > >> > +static inline _EGLDevice * > >> > +_eglLookupDevice(EGLDeviceEXT device) > >> > +{ > >> > + _EGLDevice *dev = (_EGLDevice *) device; > >> > + if (!_eglCheckDeviceHandle(device)) > >> > + dev = NULL; > >> > + return dev; > >> > +} > >> > + > >> > +_EGLDevice * > >> > +_eglAddDevice(int fd, bool software); > >> > + > >> > +enum _egl_device_extension { > >> > + EGL_FOOBAR, > >> > >> I don't think this would compile :P > > > > Sorry, idiot here, ignore me :) > > > We all have silly moments. > > I didn't bother adding a comment since it's removed with the next patch :-\ > Could add something like "Add a temporary entry, since enum with zero > entries is illegal" if it makes sense.
That's not a bad idea, it might help the next "silly" person :) _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/mesa-dev