better render init stops a race
when running inside some versions of gdb
This commit is contained in:
parent
78f927e606
commit
8840bc8a14
@ -114,6 +114,7 @@ void vips__threadpool_init( void );
|
||||
|
||||
void vips__cache_init( void );
|
||||
|
||||
void vips__sink_screen_init( void );
|
||||
void vips__print_renders( void );
|
||||
|
||||
void vips__type_leak( void );
|
||||
|
@ -384,6 +384,7 @@ vips_init( const char *argv0 )
|
||||
#endif /*HAVE_THREAD_NEW*/
|
||||
|
||||
vips__threadpool_init();
|
||||
vips__sink_screen_init();
|
||||
vips__buffer_init();
|
||||
vips__meta_init();
|
||||
|
||||
|
@ -1029,8 +1029,8 @@ render_thread_main( void *client )
|
||||
return( NULL );
|
||||
}
|
||||
|
||||
static void
|
||||
vips_sink_screen_init( void )
|
||||
void
|
||||
vips__sink_screen_init( void )
|
||||
{
|
||||
g_assert( !render_thread );
|
||||
g_assert( !render_dirty_lock );
|
||||
@ -1039,9 +1039,6 @@ vips_sink_screen_init( void )
|
||||
render_thread = vips_g_thread_new( "sink_screen",
|
||||
render_thread_main, NULL );
|
||||
vips_semaphore_init( &n_render_dirty_sem, 0, "n_render_dirty" );
|
||||
|
||||
g_assert( render_thread );
|
||||
g_assert( render_dirty_lock );
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1101,12 +1098,8 @@ vips_sink_screen( VipsImage *in, VipsImage *out, VipsImage *mask,
|
||||
int priority,
|
||||
VipsSinkNotify notify_fn, void *a )
|
||||
{
|
||||
static GOnce once = G_ONCE_INIT;
|
||||
|
||||
Render *render;
|
||||
|
||||
VIPS_ONCE( &once, (GThreadFunc) vips_sink_screen_init, NULL );
|
||||
|
||||
if( tile_width <= 0 || tile_height <= 0 ||
|
||||
max_tiles < -1 ) {
|
||||
vips_error( "vips_sink_screen", "%s", _( "bad parameters" ) );
|
||||
|
Loading…
Reference in New Issue
Block a user