From: Nicolai Hähnle Date: Thu, 7 Jul 2016 07:25:31 +0000 (+0200) Subject: st/mesa: set debug callback async flag X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=084ca0d8e51ae0a5cca6cfc7e9d018d0b22b6fb7;p=mesa.git st/mesa: set debug callback async flag Reviewed-by: Edward O'Callaghan Reviewed-by: Marek Olšák --- diff --git a/src/mesa/state_tracker/st_context.c b/src/mesa/state_tracker/st_context.c index 472121581eb..f1d2084d6bb 100644 --- a/src/mesa/state_tracker/st_context.c +++ b/src/mesa/state_tracker/st_context.c @@ -90,7 +90,8 @@ static void st_Enable(struct gl_context * ctx, GLenum cap, GLboolean state) switch (cap) { case GL_DEBUG_OUTPUT: - st_enable_debug_output(st, state); + case GL_DEBUG_OUTPUT_SYNCHRONOUS: + st_update_debug_callback(st); break; default: break; diff --git a/src/mesa/state_tracker/st_debug.c b/src/mesa/state_tracker/st_debug.c index 214e2238148..b51f350d216 100644 --- a/src/mesa/state_tracker/st_debug.c +++ b/src/mesa/state_tracker/st_debug.c @@ -27,6 +27,7 @@ #include "main/context.h" +#include "main/debug_output.h" #include "program/prog_print.h" #include "pipe/p_state.h" @@ -164,16 +165,17 @@ st_debug_message(void *data, } void -st_enable_debug_output(struct st_context *st, boolean enable) +st_update_debug_callback(struct st_context *st) { struct pipe_context *pipe = st->pipe; if (!pipe->set_debug_callback) return; - if (enable) { + if (_mesa_get_debug_state_int(st->ctx, GL_DEBUG_OUTPUT)) { struct pipe_debug_callback cb; memset(&cb, 0, sizeof(cb)); + cb.async = !_mesa_get_debug_state_int(st->ctx, GL_DEBUG_OUTPUT_SYNCHRONOUS); cb.debug_message = st_debug_message; cb.data = st; pipe->set_debug_callback(pipe, &cb); diff --git a/src/mesa/state_tracker/st_debug.h b/src/mesa/state_tracker/st_debug.h index e14360937a9..6c1e915f68c 100644 --- a/src/mesa/state_tracker/st_debug.h +++ b/src/mesa/state_tracker/st_debug.h @@ -63,7 +63,7 @@ extern int ST_DEBUG; void st_debug_init( void ); -void st_enable_debug_output(struct st_context *st, boolean enable); +void st_update_debug_callback(struct st_context *st); static inline void ST_DBG( unsigned flag, const char *fmt, ... ) diff --git a/src/mesa/state_tracker/st_manager.c b/src/mesa/state_tracker/st_manager.c index 997d4284497..d323c87de7d 100644 --- a/src/mesa/state_tracker/st_manager.c +++ b/src/mesa/state_tracker/st_manager.c @@ -681,7 +681,7 @@ st_api_create_context(struct st_api *stapi, struct st_manager *smapi, st->ctx->Const.ContextFlags |= GL_CONTEXT_FLAG_DEBUG_BIT; - st_enable_debug_output(st, TRUE); + st_update_debug_callback(st); } if (attribs->flags & ST_CONTEXT_FLAG_FORWARD_COMPATIBLE)