(GL) gl_shader_init - Cleanups

This commit is contained in:
twinaphex 2016-04-16 05:36:09 +02:00
parent 1dfb29ddaf
commit 4e041ff3d0
2 changed files with 33 additions and 51 deletions

View File

@ -236,8 +236,6 @@ static bool gl_shader_init(gl_t *gl)
{
video_shader_ctx_init_t init_data;
enum rarch_shader_type type;
bool ret = false;
const shader_backend_t *backend = NULL;
settings_t *settings = config_get_ptr();
const char *shader_path = (settings->video.shader_enable
&& *settings->video.shader_path) ? settings->video.shader_path : NULL;
@ -251,69 +249,41 @@ static bool gl_shader_init(gl_t *gl)
type = video_shader_parse_type(shader_path,
gl->core_context ? RARCH_SHADER_GLSL : DEFAULT_SHADER_TYPE);
if (type == RARCH_SHADER_NONE)
{
RARCH_LOG("[GL]: Not loading any shader.\n");
return true;
}
switch (type)
{
#ifdef HAVE_CG
case RARCH_SHADER_CG:
RARCH_LOG("[GL]: Using Cg shader backend.\n");
backend = &gl_cg_backend;
if (gl->core_context)
shader_path = NULL;
break;
#endif
#ifdef HAVE_GLSL
case RARCH_SHADER_GLSL:
RARCH_LOG("[GL]: Using GLSL shader backend.\n");
backend = &gl_glsl_backend;
break;
#endif
default:
break;
}
if (!backend)
{
RARCH_ERR("[GL]: Didn't find valid shader backend. Continuing without shaders.\n");
RARCH_ERR("[GL]: Not loading any shader, or couldn't find valid shader backend. Continuing without shaders.\n");
return true;
}
#ifdef HAVE_GLSL
#ifdef HAVE_CG
if (gl->core_context && backend == &gl_cg_backend)
{
RARCH_ERR("[GL]: Cg cannot be used with core GL context. Falling back to GLSL.\n");
backend = &gl_glsl_backend;
shader_path = NULL;
}
init_data.gl.core_context_enabled = gl->core_context;
#endif
#endif
init_data.shader = backend;
init_data.shader_type = type;
init_data.shader = NULL;
init_data.data = gl;
init_data.path = shader_path;
ret = video_shader_driver_ctl(SHADER_CTL_INIT, &init_data);
if (video_shader_driver_ctl(SHADER_CTL_INIT, &init_data))
return true;
if (!ret)
{
RARCH_ERR("[GL]: Failed to initialize shader, falling back to stock.\n");
init_data.shader = backend;
init_data.data = gl;
init_data.shader = NULL;
init_data.path = NULL;
ret = video_shader_driver_ctl(SHADER_CTL_INIT, &init_data);
}
return ret;
return video_shader_driver_ctl(SHADER_CTL_INIT, &init_data);
}
static void gl_shader_deinit(gl_t *gl)

View File

@ -34,14 +34,25 @@ static const shader_backend_t *shader_ctx_drivers[] = {
NULL
};
static const shader_backend_t *video_shader_set_backend(enum rarch_shader_type type)
static const shader_backend_t *video_shader_set_backend(enum rarch_shader_type type,
bool core_context_inited)
{
switch (type)
{
case RARCH_SHADER_CG:
#ifdef HAVE_CG
if (core_context_inited)
{
RARCH_ERR("[Shader driver]: Cg cannot be used with core GL context. Trying to fall back to GLSL...\n");
#ifdef HAVE_GLSL
return &gl_glsl_backend;
#endif
}
else
{
RARCH_LOG("[Shader driver]: Using Cg shader backend.\n");
return &gl_cg_backend;
}
#else
break;
#endif
@ -164,7 +175,8 @@ bool video_shader_driver_ctl(enum video_shader_driver_ctl_state state, void *dat
if (!init->shader || !init->shader->init)
{
init->shader = video_shader_set_backend(init->shader_type);
init->shader = video_shader_set_backend(init->shader_type,
init->gl.core_context_enabled);
if (!init->shader)
return false;