gl: Add/Update more debug statements

Where possible, use the _OBJECT variants in order to track better from
which object the debug statement is coming from

Define (and use) GST_CAT_DEFAULT where applicable

Use GST_PTR_FORMAT where applicable
This commit is contained in:
Edward Hervey 2015-02-12 15:02:31 +01:00 committed by Tim-Philipp Müller
parent 6d6c7f1f19
commit f56c4c541a
8 changed files with 96 additions and 61 deletions

View file

@ -336,7 +336,8 @@ gst_gl_buffer_pool_new (GstGLContext * context)
pool = g_object_new (GST_TYPE_GL_BUFFER_POOL, NULL); pool = g_object_new (GST_TYPE_GL_BUFFER_POOL, NULL);
pool->context = gst_object_ref (context); pool->context = gst_object_ref (context);
GST_LOG_OBJECT (pool, "new GL buffer pool %p", pool); GST_LOG_OBJECT (pool, "new GL buffer pool for context %" GST_PTR_FORMAT,
context);
return GST_BUFFER_POOL_CAST (pool); return GST_BUFFER_POOL_CAST (pool);
} }

View file

@ -494,6 +494,9 @@ gst_gl_color_convert_new (GstGLContext * context)
gst_video_info_set_format (&convert->out_info, GST_VIDEO_FORMAT_ENCODED, 0, gst_video_info_set_format (&convert->out_info, GST_VIDEO_FORMAT_ENCODED, 0,
0); 0);
GST_DEBUG_OBJECT (convert,
"Created new colorconvert for context %" GST_PTR_FORMAT, context);
return convert; return convert;
} }

View file

@ -274,7 +274,8 @@ gst_gl_context_new (GstGLDisplay * display)
_init_debug (); _init_debug ();
user_choice = g_getenv ("GST_GL_PLATFORM"); user_choice = g_getenv ("GST_GL_PLATFORM");
GST_INFO ("creating a context, user choice:%s", user_choice); GST_INFO ("creating a context for display %" GST_PTR_FORMAT
", user choice:%s", display, user_choice);
#if GST_GL_HAVE_PLATFORM_CGL #if GST_GL_HAVE_PLATFORM_CGL
if (!context && (!user_choice || g_strstr_len (user_choice, 5, "cgl"))) if (!context && (!user_choice || g_strstr_len (user_choice, 5, "cgl")))
context = GST_GL_CONTEXT (gst_gl_context_cocoa_new ()); context = GST_GL_CONTEXT (gst_gl_context_cocoa_new ());
@ -307,6 +308,10 @@ gst_gl_context_new (GstGLDisplay * display)
context->priv->display = gst_object_ref (display); context->priv->display = gst_object_ref (display);
GST_DEBUG_OBJECT (context,
"Done creating context for display %" GST_PTR_FORMAT " (user_choice:%s)",
display, user_choice);
return context; return context;
} }
@ -556,7 +561,7 @@ gst_gl_context_finalize (GObject * object)
if (context->priv->alive) { if (context->priv->alive) {
g_mutex_lock (&context->priv->render_lock); g_mutex_lock (&context->priv->render_lock);
GST_INFO ("send quit gl window loop"); GST_INFO_OBJECT (context, "send quit gl window loop");
gst_gl_window_quit (context->window); gst_gl_window_quit (context->window);
while (context->priv->alive) { while (context->priv->alive) {
g_cond_wait (&context->priv->destroy_cond, &context->priv->render_lock); g_cond_wait (&context->priv->destroy_cond, &context->priv->render_lock);
@ -568,9 +573,9 @@ gst_gl_context_finalize (GObject * object)
if (context->priv->gl_thread) { if (context->priv->gl_thread) {
gpointer ret = g_thread_join (context->priv->gl_thread); gpointer ret = g_thread_join (context->priv->gl_thread);
GST_INFO ("gl thread joined"); GST_INFO_OBJECT (context, "gl thread joined");
if (ret != NULL) if (ret != NULL)
GST_ERROR ("gl thread returned a non-null pointer"); GST_ERROR_OBJECT (context, "gl thread returned a non-null pointer");
context->priv->gl_thread = NULL; context->priv->gl_thread = NULL;
} }
@ -592,6 +597,7 @@ gst_gl_context_finalize (GObject * object)
g_free (context->priv->gl_exts); g_free (context->priv->gl_exts);
g_weak_ref_clear (&context->priv->other_context_ref); g_weak_ref_clear (&context->priv->other_context_ref);
GST_DEBUG_OBJECT (context, "End of finalize");
G_OBJECT_CLASS (gst_gl_context_parent_class)->finalize (object); G_OBJECT_CLASS (gst_gl_context_parent_class)->finalize (object);
} }
@ -619,6 +625,8 @@ gst_gl_context_activate (GstGLContext * context, gboolean activate)
context_class = GST_GL_CONTEXT_GET_CLASS (context); context_class = GST_GL_CONTEXT_GET_CLASS (context);
g_return_val_if_fail (context_class->activate != NULL, FALSE); g_return_val_if_fail (context_class->activate != NULL, FALSE);
GST_DEBUG_OBJECT (context, "activate:%d", activate);
GST_OBJECT_LOCK (context); GST_OBJECT_LOCK (context);
result = context_class->activate (context, activate); result = context_class->activate (context, activate);
@ -762,6 +770,8 @@ gst_gl_context_set_window (GstGLContext * context, GstGLWindow * window)
{ {
g_return_val_if_fail (!GST_GL_IS_WRAPPED_CONTEXT (context), FALSE); g_return_val_if_fail (!GST_GL_IS_WRAPPED_CONTEXT (context), FALSE);
GST_DEBUG_OBJECT (context, "window:%" GST_PTR_FORMAT, window);
/* we can't change the window while we are running */ /* we can't change the window while we are running */
if (context->priv->alive) if (context->priv->alive)
return FALSE; return FALSE;
@ -794,8 +804,10 @@ gst_gl_context_get_window (GstGLContext * context)
{ {
g_return_val_if_fail (GST_GL_IS_CONTEXT (context), NULL); g_return_val_if_fail (GST_GL_IS_CONTEXT (context), NULL);
if (GST_GL_IS_WRAPPED_CONTEXT (context)) if (GST_GL_IS_WRAPPED_CONTEXT (context)) {
GST_WARNING_OBJECT (context, "context is not toplevel, returning NULL");
return NULL; return NULL;
}
_ensure_window (context); _ensure_window (context);
@ -896,6 +908,9 @@ gst_gl_context_create (GstGLContext * context,
g_return_val_if_fail (GST_GL_IS_CONTEXT (context), FALSE); g_return_val_if_fail (GST_GL_IS_CONTEXT (context), FALSE);
g_return_val_if_fail (!GST_GL_IS_WRAPPED_CONTEXT (context), FALSE); g_return_val_if_fail (!GST_GL_IS_WRAPPED_CONTEXT (context), FALSE);
GST_DEBUG_OBJECT (context, " other_context:%" GST_PTR_FORMAT, other_context);
_ensure_window (context); _ensure_window (context);
g_mutex_lock (&context->priv->render_lock); g_mutex_lock (&context->priv->render_lock);
@ -911,7 +926,7 @@ gst_gl_context_create (GstGLContext * context,
context->priv->created = TRUE; context->priv->created = TRUE;
GST_INFO ("gl thread created"); GST_INFO_OBJECT (context, "gl thread created");
} }
alive = context->priv->alive; alive = context->priv->alive;
@ -1086,13 +1101,14 @@ _create_context_info (GstGLContext * context, GstGLAPI gl_api, gint * gl_major,
return FALSE; return FALSE;
} }
GST_INFO ("GL_VERSION: %s", GST_INFO_OBJECT (context, "GL_VERSION: %s",
GST_STR_NULL ((const gchar *) gl->GetString (GL_VERSION))); GST_STR_NULL ((const gchar *) gl->GetString (GL_VERSION)));
GST_INFO ("GL_SHADING_LANGUAGE_VERSION: %s", GST_STR_NULL ((const gchar *) GST_INFO_OBJECT (context, "GL_SHADING_LANGUAGE_VERSION: %s",
GST_STR_NULL ((const gchar *)
gl->GetString (GL_SHADING_LANGUAGE_VERSION))); gl->GetString (GL_SHADING_LANGUAGE_VERSION)));
GST_INFO ("GL_VENDOR: %s", GST_INFO_OBJECT (context, "GL_VENDOR: %s",
GST_STR_NULL ((const gchar *) gl->GetString (GL_VENDOR))); GST_STR_NULL ((const gchar *) gl->GetString (GL_VENDOR)));
GST_INFO ("GL_RENDERER: %s", GST_INFO_OBJECT (context, "GL_RENDERER: %s",
GST_STR_NULL ((const gchar *) gl->GetString (GL_RENDERER))); GST_STR_NULL ((const gchar *) gl->GetString (GL_RENDERER)));
gl_err = gl->GetError (); gl_err = gl->GetError ();
@ -1186,6 +1202,8 @@ gst_gl_context_create_thread (GstGLContext * context)
g_mutex_lock (&context->priv->render_lock); g_mutex_lock (&context->priv->render_lock);
GST_DEBUG_OBJECT (context, "Creating thread");
error = context->priv->error; error = context->priv->error;
other_context = g_weak_ref_get (&context->priv->other_context_ref); other_context = g_weak_ref_get (&context->priv->other_context_ref);
@ -1202,6 +1220,7 @@ gst_gl_context_create_thread (GstGLContext * context)
if (window_class->open) { if (window_class->open) {
if (!window_class->open (context->window, error)) { if (!window_class->open (context->window, error)) {
GST_WARNING_OBJECT (context, "Failed to open window");
g_assert (error == NULL || *error != NULL); g_assert (error == NULL || *error != NULL);
goto failure; goto failure;
} }
@ -1230,6 +1249,7 @@ gst_gl_context_create_thread (GstGLContext * context)
if (context_class->choose_format && if (context_class->choose_format &&
!context_class->choose_format (context, error)) { !context_class->choose_format (context, error)) {
GST_WARNING ("Failed to choose format");
g_assert (error == NULL || *error != NULL); g_assert (error == NULL || *error != NULL);
g_free (compiled_api_s); g_free (compiled_api_s);
g_free (user_api_s); g_free (user_api_s);
@ -1237,19 +1257,21 @@ gst_gl_context_create_thread (GstGLContext * context)
goto failure; goto failure;
} }
GST_INFO ("Attempting to create opengl context. user chosen api(s) (%s), " GST_INFO_OBJECT (context,
"compiled api support (%s) display api (%s)", user_api_s, "Attempting to create opengl context. user chosen api(s) (%s), "
compiled_api_s, display_api_s); "compiled api support (%s) display api (%s)", user_api_s, compiled_api_s,
display_api_s);
if (!context_class->create_context (context, if (!context_class->create_context (context,
compiled_api & user_api & display_api, other_context, error)) { compiled_api & user_api & display_api, other_context, error)) {
GST_WARNING_OBJECT (context, "Failed to create context");
g_assert (error == NULL || *error != NULL); g_assert (error == NULL || *error != NULL);
g_free (compiled_api_s); g_free (compiled_api_s);
g_free (user_api_s); g_free (user_api_s);
g_free (display_api_s); g_free (display_api_s);
goto failure; goto failure;
} }
GST_INFO ("created context"); GST_INFO_OBJECT (context, "created context");
if (!gst_gl_context_activate (context, TRUE)) { if (!gst_gl_context_activate (context, TRUE)) {
g_set_error (error, GST_GL_CONTEXT_ERROR, g_set_error (error, GST_GL_CONTEXT_ERROR,
@ -1265,7 +1287,7 @@ gst_gl_context_create_thread (GstGLContext * context)
g_assert (gl_api != GST_GL_API_NONE && gl_api != GST_GL_API_ANY); g_assert (gl_api != GST_GL_API_NONE && gl_api != GST_GL_API_ANY);
api_string = gst_gl_api_to_string (gl_api); api_string = gst_gl_api_to_string (gl_api);
GST_INFO ("available GL APIs: %s", api_string); GST_INFO_OBJECT (context, "available GL APIs: %s", api_string);
if (((compiled_api & gl_api & display_api) & user_api) == GST_GL_API_NONE) { if (((compiled_api & gl_api & display_api) & user_api) == GST_GL_API_NONE) {
g_set_error (error, GST_GL_CONTEXT_ERROR, GST_GL_CONTEXT_ERROR_WRONG_API, g_set_error (error, GST_GL_CONTEXT_ERROR, GST_GL_CONTEXT_ERROR_WRONG_API,
@ -1284,13 +1306,14 @@ gst_gl_context_create_thread (GstGLContext * context)
g_free (user_api_s); g_free (user_api_s);
g_free (display_api_s); g_free (display_api_s);
GST_DEBUG_OBJECT (context, "Filling info");
gst_gl_context_fill_info (context, error); gst_gl_context_fill_info (context, error);
context->priv->alive = TRUE; context->priv->alive = TRUE;
if (gl->DebugMessageCallback) { if (gl->DebugMessageCallback) {
#if !defined(GST_DISABLE_GST_DEBUG) #if !defined(GST_DISABLE_GST_DEBUG)
GST_INFO ("Enabling GL context debugging"); GST_INFO_OBJECT (context, "Enabling GL context debugging");
/* enable them all */ /* enable them all */
gl->DebugMessageControl (GL_DONT_CARE, GL_DONT_CARE, GL_DONT_CARE, 0, 0, gl->DebugMessageControl (GL_DONT_CARE, GL_DONT_CARE, GL_DONT_CARE, 0, 0,
GL_TRUE); GL_TRUE);
@ -1298,8 +1321,11 @@ gst_gl_context_create_thread (GstGLContext * context)
#endif #endif
} }
if (other_context) if (other_context) {
GST_DEBUG_OBJECT (context, "Unreffing other_context %" GST_PTR_FORMAT,
other_context);
gst_object_unref (other_context); gst_object_unref (other_context);
}
g_cond_signal (&context->priv->create_cond); g_cond_signal (&context->priv->create_cond);
@ -1309,7 +1335,7 @@ gst_gl_context_create_thread (GstGLContext * context)
gst_gl_window_run (context->window); gst_gl_window_run (context->window);
GST_INFO ("loop exited\n"); GST_INFO_OBJECT (context, "loop exited");
g_mutex_lock (&context->priv->render_lock); g_mutex_lock (&context->priv->render_lock);

View file

@ -116,7 +116,7 @@ gst_gl_display_init (GstGLDisplay * display)
static void static void
gst_gl_display_finalize (GObject * object) gst_gl_display_finalize (GObject * object)
{ {
GST_TRACE ("finalize %p", object); GST_TRACE_OBJECT (object, "finalizing");
G_OBJECT_CLASS (gst_gl_display_parent_class)->finalize (object); G_OBJECT_CLASS (gst_gl_display_parent_class)->finalize (object);
} }
@ -272,8 +272,9 @@ gst_context_set_gl_display (GstContext * context, GstGLDisplay * display)
g_return_if_fail (context != NULL); g_return_if_fail (context != NULL);
GST_CAT_LOG (gst_context, "setting GstGLDisplay(%p) on context(%p)", display, GST_CAT_LOG (gst_context,
context); "setting GstGLDisplay(%" GST_PTR_FORMAT ") on context(%" GST_PTR_FORMAT
")", display, context);
s = gst_context_writable_structure (context); s = gst_context_writable_structure (context);
gst_structure_set (s, GST_GL_DISPLAY_CONTEXT_TYPE, GST_TYPE_GL_DISPLAY, gst_structure_set (s, GST_GL_DISPLAY_CONTEXT_TYPE, GST_TYPE_GL_DISPLAY,

View file

@ -62,7 +62,7 @@
GST_GL_API_OPENGL | GST_GL_API_OPENGL3 | GST_GL_API_GLES2, 3, 0)) GST_GL_API_OPENGL | GST_GL_API_OPENGL3 | GST_GL_API_GLES2, 3, 0))
GST_DEBUG_CATEGORY_STATIC (GST_CAT_GL_MEMORY); GST_DEBUG_CATEGORY_STATIC (GST_CAT_GL_MEMORY);
#define GST_CAT_DEFUALT GST_CAT_GL_MEMORY #define GST_CAT_DEFAULT GST_CAT_GL_MEMORY
static GstAllocator *_gl_allocator; static GstAllocator *_gl_allocator;
@ -385,9 +385,8 @@ _generate_texture (GstGLContext * context, GenTexture * data)
const GstGLFuncs *gl = context->gl_vtable; const GstGLFuncs *gl = context->gl_vtable;
GLenum internal_format; GLenum internal_format;
GST_CAT_TRACE (GST_CAT_GL_MEMORY, GST_TRACE ("Generating texture format:%u type:%u dimensions:%ux%u",
"Generating texture format:%u type:%u dimensions:%ux%u", data->gl_format, data->gl_format, data->gl_type, data->width, data->height);
data->gl_type, data->width, data->height);
internal_format = internal_format =
_sized_gl_format_from_gl_format_type (data->gl_format, data->gl_type); _sized_gl_format_from_gl_format_type (data->gl_format, data->gl_type);
@ -402,7 +401,7 @@ _generate_texture (GstGLContext * context, GenTexture * data)
gl->TexParameteri (data->gl_target, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); gl->TexParameteri (data->gl_target, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
gl->TexParameteri (data->gl_target, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); gl->TexParameteri (data->gl_target, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
GST_CAT_LOG (GST_CAT_GL_MEMORY, "generated texture id:%d", data->result); GST_LOG ("generated texture id:%d", data->result);
} }
/* find the difference between the start of the plane and where the video /* find the difference between the start of the plane and where the video
@ -453,7 +452,7 @@ _upload_memory (GstGLContext * context, GstGLMemory * gl_mem)
gl->PixelStorei (GL_UNPACK_ALIGNMENT, gl_mem->unpack_length); gl->PixelStorei (GL_UNPACK_ALIGNMENT, gl_mem->unpack_length);
} }
GST_CAT_LOG (GST_CAT_GL_MEMORY, "upload for texture id:%u, with pbo %u %ux%u", GST_LOG ("upload for texture id:%u, with pbo %u %ux%u",
gl_mem->tex_id, gl_mem->transfer_pbo, gl_mem->tex_width, gl_mem->tex_id, gl_mem->transfer_pbo, gl_mem->tex_width,
GL_MEM_HEIGHT (gl_mem)); GL_MEM_HEIGHT (gl_mem));
@ -501,7 +500,7 @@ _transfer_upload (GstGLContext * context, GstGLMemory * gl_mem)
if (!gl_mem->transfer_pbo) if (!gl_mem->transfer_pbo)
gl->GenBuffers (1, &gl_mem->transfer_pbo); gl->GenBuffers (1, &gl_mem->transfer_pbo);
GST_CAT_DEBUG (GST_CAT_GL_MEMORY, "uploading texture %u using pbo %u", GST_DEBUG ("uploading texture %u using pbo %u",
gl_mem->tex_id, gl_mem->transfer_pbo); gl_mem->tex_id, gl_mem->transfer_pbo);
size = ((GstMemory *) gl_mem)->maxsize; size = ((GstMemory *) gl_mem)->maxsize;
@ -537,8 +536,7 @@ _calculate_unpack_length (GstGLMemory * gl_mem)
n_gl_bytes = _gl_texture_type_n_bytes (gl_mem->tex_type); n_gl_bytes = _gl_texture_type_n_bytes (gl_mem->tex_type);
if (n_gl_bytes == 0) { if (n_gl_bytes == 0) {
GST_CAT_ERROR (GST_CAT_GL_MEMORY, "Unsupported texture type %d", GST_ERROR ("Unsupported texture type %d", gl_mem->tex_type);
gl_mem->tex_type);
return; return;
} }
@ -554,7 +552,7 @@ _calculate_unpack_length (GstGLMemory * gl_mem)
((GL_MEM_WIDTH (gl_mem) * n_gl_bytes) + j - 1) & ~(j - 1); ((GL_MEM_WIDTH (gl_mem) * n_gl_bytes) + j - 1) & ~(j - 1);
if (round_up_j == GL_MEM_STRIDE (gl_mem)) { if (round_up_j == GL_MEM_STRIDE (gl_mem)) {
GST_CAT_LOG (GST_CAT_GL_MEMORY, "Found alignment of %u based on width " GST_LOG ("Found alignment of %u based on width "
"(with plane width:%u, plane stride:%u and pixel stride:%u. " "(with plane width:%u, plane stride:%u and pixel stride:%u. "
"RU%u(%u*%u) = %u)", j, GL_MEM_WIDTH (gl_mem), "RU%u(%u*%u) = %u)", j, GL_MEM_WIDTH (gl_mem),
GL_MEM_STRIDE (gl_mem), n_gl_bytes, j, GL_MEM_WIDTH (gl_mem), GL_MEM_STRIDE (gl_mem), n_gl_bytes, j, GL_MEM_WIDTH (gl_mem),
@ -577,7 +575,7 @@ _calculate_unpack_length (GstGLMemory * gl_mem)
guint round_up_j = ((GL_MEM_STRIDE (gl_mem)) + j - 1) & ~(j - 1); guint round_up_j = ((GL_MEM_STRIDE (gl_mem)) + j - 1) & ~(j - 1);
if (round_up_j == (GL_MEM_STRIDE (gl_mem))) { if (round_up_j == (GL_MEM_STRIDE (gl_mem))) {
GST_CAT_LOG (GST_CAT_GL_MEMORY, "Found alignment of %u based on " GST_LOG ("Found alignment of %u based on "
"stride (with plane stride:%u and pixel stride:%u. " "stride (with plane stride:%u and pixel stride:%u. "
"RU%u(%u) = %u)", j, GL_MEM_STRIDE (gl_mem), n_gl_bytes, j, "RU%u(%u) = %u)", j, GL_MEM_STRIDE (gl_mem), n_gl_bytes, j,
GL_MEM_STRIDE (gl_mem), round_up_j); GL_MEM_STRIDE (gl_mem), round_up_j);
@ -593,8 +591,8 @@ _calculate_unpack_length (GstGLMemory * gl_mem)
} }
if (j < n_gl_bytes) { if (j < n_gl_bytes) {
GST_CAT_ERROR GST_ERROR
(GST_CAT_GL_MEMORY, "Failed to find matching alignment. Image may " ("Failed to find matching alignment. Image may "
"look corrupted. plane width:%u, plane stride:%u and pixel " "look corrupted. plane width:%u, plane stride:%u and pixel "
"stride:%u", GL_MEM_WIDTH (gl_mem), GL_MEM_STRIDE (gl_mem), "stride:%u", GL_MEM_WIDTH (gl_mem), GL_MEM_STRIDE (gl_mem),
n_gl_bytes); n_gl_bytes);
@ -623,7 +621,7 @@ _transfer_download (GstGLContext * context, GstGLMemory * gl_mem)
if (!gl_mem->transfer_pbo) if (!gl_mem->transfer_pbo)
gl->GenBuffers (1, &gl_mem->transfer_pbo); gl->GenBuffers (1, &gl_mem->transfer_pbo);
GST_CAT_DEBUG (GST_CAT_GL_MEMORY, "downloading texture %u using pbo %u", GST_DEBUG ("downloading texture %u using pbo %u",
gl_mem->tex_id, gl_mem->transfer_pbo); gl_mem->tex_id, gl_mem->transfer_pbo);
size = ((GstMemory *) gl_mem)->maxsize; size = ((GstMemory *) gl_mem)->maxsize;
@ -645,7 +643,7 @@ _transfer_download (GstGLContext * context, GstGLMemory * gl_mem)
GL_TEXTURE_2D, gl_mem->tex_id, 0); GL_TEXTURE_2D, gl_mem->tex_id, 0);
if (!gst_gl_context_check_framebuffer_status (context)) { if (!gst_gl_context_check_framebuffer_status (context)) {
GST_CAT_ERROR (GST_CAT_GL_MEMORY, "failed to download texture"); GST_ERROR ("failed to download texture");
goto fbo_error; goto fbo_error;
} }
@ -686,7 +684,7 @@ _download_memory (GstGLContext * context, GstGLMemory * gl_mem)
goto error; goto error;
} }
GST_CAT_LOG (GST_CAT_GL_MEMORY, "downloading memory %p, tex %u into %p", GST_LOG ("downloading memory %p, tex %u into %p",
gl_mem, gl_mem->tex_id, gl_mem->data); gl_mem, gl_mem->tex_id, gl_mem->data);
if (gl_mem->tex_type == GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE if (gl_mem->tex_type == GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE
@ -702,7 +700,7 @@ _download_memory (GstGLContext * context, GstGLMemory * gl_mem)
map_data = map_data =
gl->MapBufferRange (GL_PIXEL_PACK_BUFFER, 0, size, GL_MAP_READ_BIT); gl->MapBufferRange (GL_PIXEL_PACK_BUFFER, 0, size, GL_MAP_READ_BIT);
if (!map_data) { if (!map_data) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, "error mapping buffer for download"); GST_WARNING ("error mapping buffer for download");
gl->BindBuffer (GL_PIXEL_PACK_BUFFER, 0); gl->BindBuffer (GL_PIXEL_PACK_BUFFER, 0);
goto read_pixels; goto read_pixels;
} }
@ -774,9 +772,10 @@ _gl_mem_init (GstGLMemory * mem, GstAllocator * allocator, GstMemory * parent,
_calculate_unpack_length (mem); _calculate_unpack_length (mem);
GST_CAT_DEBUG (GST_CAT_GL_MEMORY, "new GL texture memory:%p format:%u " GST_DEBUG ("new GL texture context:%" GST_PTR_FORMAT " memory:%p format:%u "
"dimensions:%ux%u stride:%u size:%" G_GSIZE_FORMAT, mem, mem->tex_type, "dimensions:%ux%u stride:%u size:%" G_GSIZE_FORMAT, context, mem,
mem->tex_width, GL_MEM_HEIGHT (mem), GL_MEM_STRIDE (mem), maxsize); mem->tex_type, mem->tex_width, GL_MEM_HEIGHT (mem), GL_MEM_STRIDE (mem),
maxsize);
} }
static GstGLMemory * static GstGLMemory *
@ -801,11 +800,11 @@ _gl_mem_new (GstAllocator * allocator, GstMemory * parent,
gst_gl_context_thread_add (context, gst_gl_context_thread_add (context,
(GstGLContextThreadFunc) _generate_texture, &data); (GstGLContextThreadFunc) _generate_texture, &data);
if (!data.result) { if (!data.result) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, GST_WARNING ("Could not create GL texture with context:%" GST_PTR_FORMAT,
"Could not create GL texture with context:%p", context); context);
} }
GST_CAT_TRACE (GST_CAT_GL_MEMORY, "created texture %u", data.result); GST_TRACE ("created texture %u", data.result);
mem->tex_id = data.result; mem->tex_id = data.result;
mem->tex_target = data.gl_target; mem->tex_target = data.gl_target;
@ -824,8 +823,7 @@ _gl_mem_map (GstGLMemory * gl_mem, gsize maxsize, GstMapFlags flags)
if ((flags & GST_MAP_GL) == GST_MAP_GL) { if ((flags & GST_MAP_GL) == GST_MAP_GL) {
if ((flags & GST_MAP_READ) == GST_MAP_READ) { if ((flags & GST_MAP_READ) == GST_MAP_READ) {
GST_CAT_TRACE (GST_CAT_GL_MEMORY, "mapping GL texture:%u for reading", GST_TRACE ("mapping GL texture:%u for reading", gl_mem->tex_id);
gl_mem->tex_id);
if (GST_GL_MEMORY_FLAG_IS_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD)) { if (GST_GL_MEMORY_FLAG_IS_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD)) {
gst_gl_context_thread_add (gl_mem->context, gst_gl_context_thread_add (gl_mem->context,
(GstGLContextThreadFunc) _upload_memory, gl_mem); (GstGLContextThreadFunc) _upload_memory, gl_mem);
@ -834,8 +832,7 @@ _gl_mem_map (GstGLMemory * gl_mem, gsize maxsize, GstMapFlags flags)
} }
if ((flags & GST_MAP_WRITE) == GST_MAP_WRITE) { if ((flags & GST_MAP_WRITE) == GST_MAP_WRITE) {
GST_CAT_TRACE (GST_CAT_GL_MEMORY, "mapping GL texture:%u for writing", GST_TRACE ("mapping GL texture:%u for writing", gl_mem->tex_id);
gl_mem->tex_id);
GST_GL_MEMORY_FLAG_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD); GST_GL_MEMORY_FLAG_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD);
GST_GL_MEMORY_FLAG_UNSET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD); GST_GL_MEMORY_FLAG_UNSET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD);
} }
@ -843,8 +840,7 @@ _gl_mem_map (GstGLMemory * gl_mem, gsize maxsize, GstMapFlags flags)
data = &gl_mem->tex_id; data = &gl_mem->tex_id;
} else { /* not GL */ } else { /* not GL */
if ((flags & GST_MAP_READ) == GST_MAP_READ) { if ((flags & GST_MAP_READ) == GST_MAP_READ) {
GST_CAT_TRACE (GST_CAT_GL_MEMORY, GST_TRACE ("mapping GL texture:%u for reading from system memory",
"mapping GL texture:%u for reading from system memory",
gl_mem->tex_id); gl_mem->tex_id);
if (GST_GL_MEMORY_FLAG_IS_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD)) { if (GST_GL_MEMORY_FLAG_IS_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD)) {
gst_gl_context_thread_add (gl_mem->context, gst_gl_context_thread_add (gl_mem->context,
@ -854,8 +850,8 @@ _gl_mem_map (GstGLMemory * gl_mem, gsize maxsize, GstMapFlags flags)
} }
if ((flags & GST_MAP_WRITE) == GST_MAP_WRITE) { if ((flags & GST_MAP_WRITE) == GST_MAP_WRITE) {
GST_CAT_TRACE (GST_CAT_GL_MEMORY, GST_TRACE ("mapping GL texture:%u for writing to system memory",
"mapping GL texture:%u for writing to system memory", gl_mem->tex_id); gl_mem->tex_id);
GST_GL_MEMORY_FLAG_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD); GST_GL_MEMORY_FLAG_SET (gl_mem, GST_GL_MEMORY_FLAG_NEED_UPLOAD);
GST_GL_MEMORY_FLAG_UNSET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD); GST_GL_MEMORY_FLAG_UNSET (gl_mem, GST_GL_MEMORY_FLAG_NEED_DOWNLOAD);
} }
@ -962,11 +958,10 @@ _gl_mem_copy_thread (GstGLContext * context, gpointer data)
} }
if (!tex_id) { if (!tex_id) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, GST_WARNING ("Could not create GL texture with context:%p", src->context);
"Could not create GL texture with context:%p", src->context);
} }
GST_CAT_LOG (GST_CAT_GL_MEMORY, "copying memory %p, tex %u into texture %i", GST_LOG ("copying memory %p, tex %u into texture %i",
src, src->tex_id, tex_id); src, src->tex_id, tex_id);
/* FIXME: try and avoid creating and destroying fbo's every copy... */ /* FIXME: try and avoid creating and destroying fbo's every copy... */
@ -1060,7 +1055,7 @@ _gl_mem_copy (GstGLMemory * src, gssize offset, gssize size)
&src->valign, src->plane, NULL, NULL); &src->valign, src->plane, NULL, NULL);
dest->data = g_try_malloc (src->mem.maxsize); dest->data = g_try_malloc (src->mem.maxsize);
if (dest->data == NULL) { if (dest->data == NULL) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, "Could not copy GL Memory"); GST_WARNING ("Could not copy GL Memory");
gst_memory_unref ((GstMemory *) dest); gst_memory_unref ((GstMemory *) dest);
return NULL; return NULL;
} }
@ -1085,7 +1080,7 @@ _gl_mem_copy (GstGLMemory * src, gssize offset, gssize size)
&src->valign, src->plane, NULL, NULL); &src->valign, src->plane, NULL, NULL);
if (!copy_params.result) { if (!copy_params.result) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, "Could not copy GL Memory"); GST_WARNING ("Could not copy GL Memory");
gst_memory_unref ((GstMemory *) dest); gst_memory_unref ((GstMemory *) dest);
return NULL; return NULL;
} }
@ -1093,7 +1088,7 @@ _gl_mem_copy (GstGLMemory * src, gssize offset, gssize size)
dest->tex_id = copy_params.tex_id; dest->tex_id = copy_params.tex_id;
dest->data = g_try_malloc (src->mem.maxsize); dest->data = g_try_malloc (src->mem.maxsize);
if (dest->data == NULL) { if (dest->data == NULL) {
GST_CAT_WARNING (GST_CAT_GL_MEMORY, "Could not copy GL Memory"); GST_WARNING ("Could not copy GL Memory");
gst_memory_unref ((GstMemory *) dest); gst_memory_unref ((GstMemory *) dest);
return NULL; return NULL;
} }
@ -1144,7 +1139,7 @@ _gl_mem_free (GstAllocator * allocator, GstMemory * mem)
{ {
GstGLMemory *gl_mem = (GstGLMemory *) mem; GstGLMemory *gl_mem = (GstGLMemory *) mem;
GST_CAT_TRACE (GST_CAT_GL_MEMORY, "freeing texture %u", gl_mem->tex_id); GST_TRACE ("freeing texture %u", gl_mem->tex_id);
gst_gl_context_thread_add (gl_mem->context, gst_gl_context_thread_add (gl_mem->context,
(GstGLContextThreadFunc) _destroy_gl_objects, gl_mem); (GstGLContextThreadFunc) _destroy_gl_objects, gl_mem);

View file

@ -170,7 +170,7 @@ gst_gl_shader_finalize (GObject * object)
shader = GST_GL_SHADER (object); shader = GST_GL_SHADER (object);
priv = shader->priv; priv = shader->priv;
GST_TRACE ("finalizing shader %u", priv->program_handle); GST_TRACE_OBJECT (shader, "finalizing shader %u", priv->program_handle);
g_free (priv->vertex_src); g_free (priv->vertex_src);
g_free (priv->fragment_src); g_free (priv->fragment_src);
@ -402,6 +402,9 @@ gst_gl_shader_new (GstGLContext * context)
shader = g_object_new (GST_GL_TYPE_SHADER, NULL); shader = g_object_new (GST_GL_TYPE_SHADER, NULL);
shader->context = gst_object_ref (context); shader->context = gst_object_ref (context);
GST_DEBUG_OBJECT (shader, "Created new GLShader for context %" GST_PTR_FORMAT,
context);
return shader; return shader;
} }

View file

@ -777,6 +777,9 @@ gst_gl_upload_new (GstGLContext * context)
upload->priv->upload_impl[i] = upload_methods[i]->new (upload); upload->priv->upload_impl[i] = upload_methods[i]->new (upload);
} }
GST_DEBUG_OBJECT (upload, "Created new GLUpload for context %" GST_PTR_FORMAT,
context);
return upload; return upload;
} }

View file

@ -100,6 +100,8 @@ gst_gl_upload_meta_new (GstGLContext * context)
upload->context = gst_object_ref (context); upload->context = gst_object_ref (context);
GST_DEBUG_OBJECT (upload, "Created upload for context %"GST_PTR_FORMAT, upload->context);
return upload; return upload;
} }
@ -108,6 +110,7 @@ gst_gl_upload_meta_finalize (GObject * object)
{ {
GstGLUploadMeta *upload; GstGLUploadMeta *upload;
GST_DEBUG_OBJECT (object, "Finalizing");
upload = GST_GL_UPLOAD_META (object); upload = GST_GL_UPLOAD_META (object);
gst_gl_upload_meta_reset (upload); gst_gl_upload_meta_reset (upload);