mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-10 14:23:57 +00:00
[client] egl: use glGetError and codes for errors in gl* functions
We used to use DEBUG_EGL_ERROR for gl* functions, which just yields EGL_SUCCESS even when there are errors.
This commit is contained in:
parent
0cbc529640
commit
b8effaf42c
3 changed files with 26 additions and 4 deletions
|
@ -19,6 +19,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "egldebug.h"
|
#include "egldebug.h"
|
||||||
|
#include <GLES3/gl3.h>
|
||||||
#include <EGL/egl.h>
|
#include <EGL/egl.h>
|
||||||
|
|
||||||
const char * egl_getErrorStr(void)
|
const char * egl_getErrorStr(void)
|
||||||
|
@ -43,3 +44,17 @@ const char * egl_getErrorStr(void)
|
||||||
default : return "UNKNOWN";
|
default : return "UNKNOWN";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char * gl_getErrorStr(void)
|
||||||
|
{
|
||||||
|
switch (glGetError())
|
||||||
|
{
|
||||||
|
case GL_NO_ERROR : return "GL_NO_ERROR";
|
||||||
|
case GL_INVALID_ENUM : return "GL_INVALID_ENUM";
|
||||||
|
case GL_INVALID_VALUE : return "GL_INVALID_VALUE";
|
||||||
|
case GL_INVALID_OPERATION : return "GL_INVALID_OPERATION";
|
||||||
|
case GL_INVALID_FRAMEBUFFER_OPERATION: return "GL_INVALID_FRAMEBUFFER_OPERATION";
|
||||||
|
case GL_OUT_OF_MEMORY : return "GL_OUT_OF_MEMORY";
|
||||||
|
default : return "UNKNOWN";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -21,9 +21,16 @@
|
||||||
#include "common/debug.h"
|
#include "common/debug.h"
|
||||||
|
|
||||||
const char * egl_getErrorStr(void);
|
const char * egl_getErrorStr(void);
|
||||||
|
const char * gl_getErrorStr(void);
|
||||||
|
|
||||||
#define DEBUG_EGL_WARN(fmt, ...) \
|
#define DEBUG_EGL_WARN(fmt, ...) \
|
||||||
DEBUG_WARN(fmt " (%s)", ##__VA_ARGS__, egl_getErrorStr())
|
DEBUG_WARN(fmt " (%s)", ##__VA_ARGS__, egl_getErrorStr())
|
||||||
|
|
||||||
#define DEBUG_EGL_ERROR(fmt, ...) \
|
#define DEBUG_EGL_ERROR(fmt, ...) \
|
||||||
DEBUG_ERROR(fmt " (%s)", ##__VA_ARGS__, egl_getErrorStr())
|
DEBUG_ERROR(fmt " (%s)", ##__VA_ARGS__, egl_getErrorStr())
|
||||||
|
|
||||||
|
#define DEBUG_GL_WARN(fmt, ...) \
|
||||||
|
DEBUG_WARN(fmt " (%s)", ##__VA_ARGS__, gl_getErrorStr())
|
||||||
|
|
||||||
|
#define DEBUG_GL_ERROR(fmt, ...) \
|
||||||
|
DEBUG_ERROR(fmt " (%s)", ##__VA_ARGS__, gl_getErrorStr())
|
||||||
|
|
|
@ -156,7 +156,7 @@ static bool egl_texture_map(EGL_Texture * texture, uint8_t i)
|
||||||
|
|
||||||
if (!texture->buf[i].map)
|
if (!texture->buf[i].map)
|
||||||
{
|
{
|
||||||
DEBUG_EGL_ERROR("glMapBufferRange failed for %d of %lu bytes", i,
|
DEBUG_GL_ERROR("glMapBufferRange failed for %d of %lu bytes", i,
|
||||||
texture->pboBufferSize);
|
texture->pboBufferSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -447,7 +447,7 @@ bool egl_texture_update_from_dma(EGL_Texture * texture, const FrameBuffer * fram
|
||||||
void * new = realloc(texture->dmaImages, newCount * sizeof *texture->dmaImages);
|
void * new = realloc(texture->dmaImages, newCount * sizeof *texture->dmaImages);
|
||||||
if (!new)
|
if (!new)
|
||||||
{
|
{
|
||||||
DEBUG_EGL_ERROR("Failed to allocate memory");
|
DEBUG_ERROR("Failed to allocate memory");
|
||||||
eglDestroyImage(texture->display, image);
|
eglDestroyImage(texture->display, image);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -487,7 +487,7 @@ bool egl_texture_update_from_dma(EGL_Texture * texture, const FrameBuffer * fram
|
||||||
|
|
||||||
case GL_WAIT_FAILED:
|
case GL_WAIT_FAILED:
|
||||||
case GL_INVALID_VALUE:
|
case GL_INVALID_VALUE:
|
||||||
DEBUG_EGL_ERROR("glClientWaitSync failed");
|
DEBUG_GL_ERROR("glClientWaitSync failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
glDeleteSync(fence);
|
glDeleteSync(fence);
|
||||||
|
@ -572,7 +572,7 @@ enum EGL_TexStatus egl_texture_bind(EGL_Texture * texture)
|
||||||
case GL_INVALID_VALUE:
|
case GL_INVALID_VALUE:
|
||||||
glDeleteSync(texture->buf[b].sync);
|
glDeleteSync(texture->buf[b].sync);
|
||||||
texture->buf[b].sync = 0;
|
texture->buf[b].sync = 0;
|
||||||
DEBUG_EGL_ERROR("glClientWaitSync failed");
|
DEBUG_GL_ERROR("glClientWaitSync failed");
|
||||||
return EGL_TEX_STATUS_ERROR;
|
return EGL_TEX_STATUS_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue