valgrind suppressions: ignore XInitThreads leaks

As we load that symbol dynamically, valgrind gets confused
when it leaks and reports the leak against an unrelated library
and an unknown (??) symbol.

To address that, put the loading and calling of that symbol
in a separate function, and ignore any malloc leak happening
in that function.
This commit is contained in:
Mathieu Duponchelle 2018-04-12 18:50:35 +02:00
parent fe5b775060
commit ae7a213628
2 changed files with 25 additions and 5 deletions

View file

@ -203,12 +203,14 @@ GST_START_TEST (test_state_changes_down_seq)
GST_END_TEST; GST_END_TEST;
/* Separate function because XInitThreads leaks, but valgrind
static Suite * * gets confused when a dynamically loaded symbol leaks, and
states_suite (void) * shows it as a ??? symbol in an unrelated library, making
* it awkward to ignore in the suppression files
*/
static void
call_xinitthreads (void)
{ {
Suite *s = suite_create ("states_base");
TCase *tc_chain = tcase_create ("general");
GModule *libx11; GModule *libx11;
libx11 = libx11 =
@ -220,6 +222,15 @@ states_suite (void)
} }
g_module_close (libx11); g_module_close (libx11);
} }
}
static Suite *
states_suite (void)
{
Suite *s = suite_create ("states_base");
TCase *tc_chain = tcase_create ("general");
call_xinitthreads ();
suite_add_tcase (s, tc_chain); suite_add_tcase (s, tc_chain);
tcase_add_checked_fixture (tc_chain, setup, teardown); tcase_add_checked_fixture (tc_chain, setup, teardown);

View file

@ -569,3 +569,12 @@
fun:glXChooseFBConfig fun:glXChooseFBConfig
fun:gst_gl_context_glx_choose_format fun:gst_gl_context_glx_choose_format
} }
{
<a one time alloc>
Memcheck:Leak
match-leak-kinds: definite
fun:malloc
...
fun:call_xinitthreads
fun:states_suite
}