mirror of
https://github.com/libretro/RetroArch
synced 2025-04-16 08:43:10 +00:00
Rewrite this
This commit is contained in:
parent
0a06d52f5e
commit
1a241fa9ce
@ -23,8 +23,6 @@
|
|||||||
#include "../../config.h"
|
#include "../../config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <glsym/glsym.h>
|
|
||||||
|
|
||||||
#include <retro_inline.h>
|
#include <retro_inline.h>
|
||||||
#include <gfx/math/matrix_4x4.h>
|
#include <gfx/math/matrix_4x4.h>
|
||||||
#include <gfx/scaler/scaler.h>
|
#include <gfx/scaler/scaler.h>
|
||||||
@ -34,146 +32,7 @@
|
|||||||
#include "../font_driver.h"
|
#include "../font_driver.h"
|
||||||
#include "../video_coord_array.h"
|
#include "../video_coord_array.h"
|
||||||
#include "../video_context_driver.h"
|
#include "../video_context_driver.h"
|
||||||
|
#include "../drivers/gl_capabilities.h"
|
||||||
#if (!defined(HAVE_OPENGLES) || defined(HAVE_OPENGLES3))
|
|
||||||
#ifdef GL_PIXEL_PACK_BUFFER
|
|
||||||
#define HAVE_GL_ASYNC_READBACK
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_PSGL)
|
|
||||||
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER_OES
|
|
||||||
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE_OES
|
|
||||||
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0_EXT
|
|
||||||
#elif defined(OSX_PPC)
|
|
||||||
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER_EXT
|
|
||||||
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE_EXT
|
|
||||||
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0_EXT
|
|
||||||
#else
|
|
||||||
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER
|
|
||||||
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE
|
|
||||||
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_OPENGLES2) || defined(HAVE_OPENGLES3) || defined(HAVE_OPENGLES_3_1) || defined(HAVE_OPENGLES_3_2)
|
|
||||||
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER
|
|
||||||
#if defined(HAVE_OPENGLES2)
|
|
||||||
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_OES
|
|
||||||
#else
|
|
||||||
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8
|
|
||||||
#endif
|
|
||||||
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT
|
|
||||||
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT
|
|
||||||
#elif defined(OSX_PPC)
|
|
||||||
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER_EXT
|
|
||||||
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_EXT
|
|
||||||
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT_EXT
|
|
||||||
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT_EXT
|
|
||||||
#elif defined(HAVE_PSGL)
|
|
||||||
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER_OES
|
|
||||||
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_SCE
|
|
||||||
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT_OES
|
|
||||||
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT_OES
|
|
||||||
#else
|
|
||||||
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER
|
|
||||||
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8
|
|
||||||
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT
|
|
||||||
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef OSX_PPC
|
|
||||||
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE_EXT
|
|
||||||
#elif defined(HAVE_PSGL)
|
|
||||||
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE_OES
|
|
||||||
#else
|
|
||||||
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_PSGL)
|
|
||||||
#define glGenerateMipmap glGenerateMipmapOES
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_FBO
|
|
||||||
|
|
||||||
#if defined(__APPLE__) || defined(HAVE_PSGL)
|
|
||||||
#define GL_RGBA32F GL_RGBA32F_ARB
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_PSGL)
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT32 GL_ARGB_SCE
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGB5 /* TODO: Verify if this is really 565 or just 555. */
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE16 GL_BGRA
|
|
||||||
#define RARCH_GL_FORMAT32 GL_UNSIGNED_INT_8_8_8_8_REV
|
|
||||||
#define RARCH_GL_FORMAT16 GL_RGB5
|
|
||||||
#elif defined(HAVE_OPENGLES)
|
|
||||||
/* Imgtec/SGX headers have this missing. */
|
|
||||||
#ifndef GL_BGRA_EXT
|
|
||||||
#define GL_BGRA_EXT 0x80E1
|
|
||||||
#endif
|
|
||||||
#ifdef IOS
|
|
||||||
/* Stupid Apple. */
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT32 GL_RGBA
|
|
||||||
#else
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT32 GL_BGRA_EXT
|
|
||||||
#endif
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGB
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA_EXT
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE16 GL_RGB
|
|
||||||
#define RARCH_GL_FORMAT32 GL_UNSIGNED_BYTE
|
|
||||||
#define RARCH_GL_FORMAT16 GL_UNSIGNED_SHORT_5_6_5
|
|
||||||
#else
|
|
||||||
/* On desktop, we always use 32-bit. */
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT32 GL_RGBA8
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGBA8
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE16 GL_BGRA
|
|
||||||
#define RARCH_GL_FORMAT32 GL_UNSIGNED_INT_8_8_8_8_REV
|
|
||||||
#define RARCH_GL_FORMAT16 GL_UNSIGNED_INT_8_8_8_8_REV
|
|
||||||
|
|
||||||
/* GL_RGB565 internal format isn't in desktop GL
|
|
||||||
* until 4.1 core (ARB_ES2_compatibility).
|
|
||||||
* Check for this. */
|
|
||||||
#ifndef GL_RGB565
|
|
||||||
#define GL_RGB565 0x8D62
|
|
||||||
#endif
|
|
||||||
#define RARCH_GL_INTERNAL_FORMAT16_565 GL_RGB565
|
|
||||||
#define RARCH_GL_TEXTURE_TYPE16_565 GL_RGB
|
|
||||||
#define RARCH_GL_FORMAT16_565 GL_UNSIGNED_SHORT_5_6_5
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Platform specific workarounds/hacks. */
|
|
||||||
#if defined(__CELLOS_LV2__)
|
|
||||||
#define NO_GL_READ_PIXELS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_OPENGL_MODERN) || defined(HAVE_OPENGLES2) || defined(HAVE_OPENGLES3) || defined(HAVE_OPENGLES_3_1) || defined(HAVE_OPENGLES_3_2) || defined(HAVE_PSGL)
|
|
||||||
|
|
||||||
#ifndef NO_GL_FF_VERTEX
|
|
||||||
#define NO_GL_FF_VERTEX
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef NO_GL_FF_MATRIX
|
|
||||||
#define NO_GL_FF_MATRIX
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_OPENGLES2) /* TODO: Figure out exactly what. */
|
|
||||||
#define NO_GL_CLAMP_TO_BORDER
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(HAVE_OPENGLES)
|
|
||||||
#ifndef GL_UNPACK_ROW_LENGTH
|
|
||||||
#define GL_UNPACK_ROW_LENGTH 0x0CF2
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef GL_SRGB_ALPHA_EXT
|
|
||||||
#define GL_SRGB_ALPHA_EXT 0x8C42
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct gl
|
typedef struct gl
|
||||||
{
|
{
|
||||||
@ -291,31 +150,6 @@ typedef struct gl
|
|||||||
GLuint vao;
|
GLuint vao;
|
||||||
} gl_t;
|
} gl_t;
|
||||||
|
|
||||||
static INLINE bool gl_check_error(void)
|
|
||||||
{
|
|
||||||
int error = glGetError();
|
|
||||||
switch (error)
|
|
||||||
{
|
|
||||||
case GL_INVALID_ENUM:
|
|
||||||
RARCH_ERR("GL: Invalid enum.\n");
|
|
||||||
break;
|
|
||||||
case GL_INVALID_VALUE:
|
|
||||||
RARCH_ERR("GL: Invalid value.\n");
|
|
||||||
break;
|
|
||||||
case GL_INVALID_OPERATION:
|
|
||||||
RARCH_ERR("GL: Invalid operation.\n");
|
|
||||||
break;
|
|
||||||
case GL_OUT_OF_MEMORY:
|
|
||||||
RARCH_ERR("GL: Out of memory.\n");
|
|
||||||
break;
|
|
||||||
case GL_NO_ERROR:
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
RARCH_ERR("Non specified GL error.\n");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool gl_load_luts(const struct video_shader *generic_shader,
|
bool gl_load_luts(const struct video_shader *generic_shader,
|
||||||
GLuint *lut_textures);
|
GLuint *lut_textures);
|
||||||
|
|
||||||
|
@ -1854,6 +1854,7 @@ static void *gl_init(const video_info_t *video, const input_driver_t **input, vo
|
|||||||
const char *renderer = NULL;
|
const char *renderer = NULL;
|
||||||
const char *version = NULL;
|
const char *version = NULL;
|
||||||
struct retro_hw_render_callback *hwr = NULL;
|
struct retro_hw_render_callback *hwr = NULL;
|
||||||
|
char *error_string = NULL;
|
||||||
settings_t *settings = config_get_ptr();
|
settings_t *settings = config_get_ptr();
|
||||||
gl_t *gl = (gl_t*)calloc(1, sizeof(gl_t));
|
gl_t *gl = (gl_t*)calloc(1, sizeof(gl_t));
|
||||||
const gfx_ctx_driver_t *ctx_driver = gl_get_context(gl);
|
const gfx_ctx_driver_t *ctx_driver = gl_get_context(gl);
|
||||||
@ -2094,8 +2095,12 @@ static void *gl_init(const video_info_t *video, const input_driver_t **input, vo
|
|||||||
gl_init_pbo_readback(gl);
|
gl_init_pbo_readback(gl);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!gl_check_error())
|
if (!gl_check_error(error_string))
|
||||||
|
{
|
||||||
|
RARCH_ERR("%s\n", error_string);
|
||||||
|
free(error_string);
|
||||||
goto error;
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
context_bind_hw_render(true);
|
context_bind_hw_render(true);
|
||||||
return gl;
|
return gl;
|
||||||
|
@ -20,6 +20,149 @@
|
|||||||
|
|
||||||
#include <boolean.h>
|
#include <boolean.h>
|
||||||
#include <retro_common_api.h>
|
#include <retro_common_api.h>
|
||||||
|
#include <retro_inline.h>
|
||||||
|
|
||||||
|
#include <glsym/glsym.h>
|
||||||
|
|
||||||
|
#if (!defined(HAVE_OPENGLES) || defined(HAVE_OPENGLES3))
|
||||||
|
#ifdef GL_PIXEL_PACK_BUFFER
|
||||||
|
#define HAVE_GL_ASYNC_READBACK
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_PSGL)
|
||||||
|
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER_OES
|
||||||
|
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE_OES
|
||||||
|
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0_EXT
|
||||||
|
#elif defined(OSX_PPC)
|
||||||
|
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER_EXT
|
||||||
|
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE_EXT
|
||||||
|
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0_EXT
|
||||||
|
#else
|
||||||
|
#define RARCH_GL_FRAMEBUFFER GL_FRAMEBUFFER
|
||||||
|
#define RARCH_GL_FRAMEBUFFER_COMPLETE GL_FRAMEBUFFER_COMPLETE
|
||||||
|
#define RARCH_GL_COLOR_ATTACHMENT0 GL_COLOR_ATTACHMENT0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_OPENGLES2) || defined(HAVE_OPENGLES3) || defined(HAVE_OPENGLES_3_1) || defined(HAVE_OPENGLES_3_2)
|
||||||
|
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER
|
||||||
|
#if defined(HAVE_OPENGLES2)
|
||||||
|
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_OES
|
||||||
|
#else
|
||||||
|
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8
|
||||||
|
#endif
|
||||||
|
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT
|
||||||
|
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT
|
||||||
|
#elif defined(OSX_PPC)
|
||||||
|
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER_EXT
|
||||||
|
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_EXT
|
||||||
|
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT_EXT
|
||||||
|
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT_EXT
|
||||||
|
#elif defined(HAVE_PSGL)
|
||||||
|
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER_OES
|
||||||
|
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8_SCE
|
||||||
|
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT_OES
|
||||||
|
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT_OES
|
||||||
|
#else
|
||||||
|
#define RARCH_GL_RENDERBUFFER GL_RENDERBUFFER
|
||||||
|
#define RARCH_GL_DEPTH24_STENCIL8 GL_DEPTH24_STENCIL8
|
||||||
|
#define RARCH_GL_DEPTH_ATTACHMENT GL_DEPTH_ATTACHMENT
|
||||||
|
#define RARCH_GL_STENCIL_ATTACHMENT GL_STENCIL_ATTACHMENT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef OSX_PPC
|
||||||
|
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE_EXT
|
||||||
|
#elif defined(HAVE_PSGL)
|
||||||
|
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE_OES
|
||||||
|
#else
|
||||||
|
#define RARCH_GL_MAX_RENDERBUFFER_SIZE GL_MAX_RENDERBUFFER_SIZE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_PSGL)
|
||||||
|
#define glGenerateMipmap glGenerateMipmapOES
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_FBO
|
||||||
|
|
||||||
|
#if defined(__APPLE__) || defined(HAVE_PSGL)
|
||||||
|
#define GL_RGBA32F GL_RGBA32F_ARB
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_PSGL)
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT32 GL_ARGB_SCE
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGB5 /* TODO: Verify if this is really 565 or just 555. */
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE16 GL_BGRA
|
||||||
|
#define RARCH_GL_FORMAT32 GL_UNSIGNED_INT_8_8_8_8_REV
|
||||||
|
#define RARCH_GL_FORMAT16 GL_RGB5
|
||||||
|
#elif defined(HAVE_OPENGLES)
|
||||||
|
/* Imgtec/SGX headers have this missing. */
|
||||||
|
#ifndef GL_BGRA_EXT
|
||||||
|
#define GL_BGRA_EXT 0x80E1
|
||||||
|
#endif
|
||||||
|
#ifdef IOS
|
||||||
|
/* Stupid Apple. */
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT32 GL_RGBA
|
||||||
|
#else
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT32 GL_BGRA_EXT
|
||||||
|
#endif
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGB
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA_EXT
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE16 GL_RGB
|
||||||
|
#define RARCH_GL_FORMAT32 GL_UNSIGNED_BYTE
|
||||||
|
#define RARCH_GL_FORMAT16 GL_UNSIGNED_SHORT_5_6_5
|
||||||
|
#else
|
||||||
|
/* On desktop, we always use 32-bit. */
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT32 GL_RGBA8
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT16 GL_RGBA8
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE32 GL_BGRA
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE16 GL_BGRA
|
||||||
|
#define RARCH_GL_FORMAT32 GL_UNSIGNED_INT_8_8_8_8_REV
|
||||||
|
#define RARCH_GL_FORMAT16 GL_UNSIGNED_INT_8_8_8_8_REV
|
||||||
|
|
||||||
|
/* GL_RGB565 internal format isn't in desktop GL
|
||||||
|
* until 4.1 core (ARB_ES2_compatibility).
|
||||||
|
* Check for this. */
|
||||||
|
#ifndef GL_RGB565
|
||||||
|
#define GL_RGB565 0x8D62
|
||||||
|
#endif
|
||||||
|
#define RARCH_GL_INTERNAL_FORMAT16_565 GL_RGB565
|
||||||
|
#define RARCH_GL_TEXTURE_TYPE16_565 GL_RGB
|
||||||
|
#define RARCH_GL_FORMAT16_565 GL_UNSIGNED_SHORT_5_6_5
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Platform specific workarounds/hacks. */
|
||||||
|
#if defined(__CELLOS_LV2__)
|
||||||
|
#define NO_GL_READ_PIXELS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_OPENGL_MODERN) || defined(HAVE_OPENGLES2) || defined(HAVE_OPENGLES3) || defined(HAVE_OPENGLES_3_1) || defined(HAVE_OPENGLES_3_2) || defined(HAVE_PSGL)
|
||||||
|
|
||||||
|
#ifndef NO_GL_FF_VERTEX
|
||||||
|
#define NO_GL_FF_VERTEX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef NO_GL_FF_MATRIX
|
||||||
|
#define NO_GL_FF_MATRIX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_OPENGLES2) /* TODO: Figure out exactly what. */
|
||||||
|
#define NO_GL_CLAMP_TO_BORDER
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_OPENGLES)
|
||||||
|
#ifndef GL_UNPACK_ROW_LENGTH
|
||||||
|
#define GL_UNPACK_ROW_LENGTH 0x0CF2
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef GL_SRGB_ALPHA_EXT
|
||||||
|
#define GL_SRGB_ALPHA_EXT 0x8C42
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
enum gl_capability_enum
|
enum gl_capability_enum
|
||||||
{
|
{
|
||||||
@ -43,6 +186,33 @@ enum gl_capability_enum
|
|||||||
|
|
||||||
RETRO_BEGIN_DECLS
|
RETRO_BEGIN_DECLS
|
||||||
|
|
||||||
|
static INLINE bool gl_check_error(char *error_string)
|
||||||
|
{
|
||||||
|
int error = glGetError();
|
||||||
|
switch (error)
|
||||||
|
{
|
||||||
|
case GL_INVALID_ENUM:
|
||||||
|
error_string = strdup("GL: Invalid enum.");
|
||||||
|
break;
|
||||||
|
case GL_INVALID_VALUE:
|
||||||
|
error_string = strdup("GL: Invalid value.");
|
||||||
|
break;
|
||||||
|
case GL_INVALID_OPERATION:
|
||||||
|
error_string = strdup("GL: Invalid operation.");
|
||||||
|
break;
|
||||||
|
case GL_OUT_OF_MEMORY:
|
||||||
|
error_string = strdup("GL: Out of memory.");
|
||||||
|
break;
|
||||||
|
case GL_NO_ERROR:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
error_string = strdup("Non specified GL error.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
bool gl_query_core_context_in_use(void);
|
bool gl_query_core_context_in_use(void);
|
||||||
|
|
||||||
void gl_query_core_context_set(bool set);
|
void gl_query_core_context_set(bool set);
|
||||||
|
@ -693,6 +693,7 @@ static void *gl_glsl_init(void *data, const char *path)
|
|||||||
unsigned i;
|
unsigned i;
|
||||||
struct shader_program_info shader_prog_info;
|
struct shader_program_info shader_prog_info;
|
||||||
bool shader_support = false;
|
bool shader_support = false;
|
||||||
|
char *error_string = NULL;
|
||||||
config_file_t *conf = NULL;
|
config_file_t *conf = NULL;
|
||||||
const char *stock_vertex = NULL;
|
const char *stock_vertex = NULL;
|
||||||
const char *stock_fragment = NULL;
|
const char *stock_fragment = NULL;
|
||||||
@ -843,8 +844,12 @@ static void *gl_glsl_init(void *data, const char *path)
|
|||||||
gl_glsl_find_uniforms(glsl, i, glsl->prg[i].id, &glsl->uniforms[i]);
|
gl_glsl_find_uniforms(glsl, i, glsl->prg[i].id, &glsl->uniforms[i]);
|
||||||
|
|
||||||
#ifdef GLSL_DEBUG
|
#ifdef GLSL_DEBUG
|
||||||
if (!gl_check_error())
|
if (!gl_check_error(error_string))
|
||||||
|
{
|
||||||
|
RARCH_ERR("%s\n", error_string);
|
||||||
|
free(error_string);
|
||||||
RARCH_WARN("Detected GL error in GLSL.\n");
|
RARCH_WARN("Detected GL error in GLSL.\n");
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (glsl->shader->variables)
|
if (glsl->shader->variables)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user