a bit more debugging code in buffer.c
watch global buffercache
This commit is contained in:
parent
c87991c9f0
commit
463d2e885f
10
TODO
10
TODO
@ -3,6 +3,16 @@
|
|||||||
- add some stuff to count main thread buffers being created and destroyed,
|
- add some stuff to count main thread buffers being created and destroyed,
|
||||||
verify that we are now handling that
|
verify that we are now handling that
|
||||||
|
|
||||||
|
- vips_sink_disc() calls wbuffer_position() which will set up the first
|
||||||
|
buffer ... but that's called from the main thread and so will create a
|
||||||
|
global buffer
|
||||||
|
|
||||||
|
can we call this from a worker instead and save a few locks?
|
||||||
|
|
||||||
|
- vips_region_dispose() calls vips_buffer_unref() which calls
|
||||||
|
buffer_cache_get(), which will create a main-thread buffercache ... can we
|
||||||
|
fix this?
|
||||||
|
|
||||||
- do we need all the locks?
|
- do we need all the locks?
|
||||||
|
|
||||||
- benchmark again and confirm we've not slowed down
|
- benchmark again and confirm we've not slowed down
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
#define DEBUG_VERBOSE
|
#define DEBUG_VERBOSE
|
||||||
#define DEBUG_CREATE
|
#define DEBUG_CREATE
|
||||||
#define DEBUG
|
#define DEBUG
|
||||||
|
#define DEBUG_GLOBAL
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
@ -93,6 +94,13 @@ static GPrivate *buffer_thread_key = NULL;
|
|||||||
*/
|
*/
|
||||||
static VipsBufferThread *vips_buffer_thread_global = NULL;
|
static VipsBufferThread *vips_buffer_thread_global = NULL;
|
||||||
|
|
||||||
|
#ifdef DEBUG_GLOBAL
|
||||||
|
/* Count main thread buffers in and out.
|
||||||
|
*/
|
||||||
|
static int vips_buffer_thread_global_n = 0;
|
||||||
|
static int vips_buffer_thread_global_highwater = 0;
|
||||||
|
#endif /*DEBUG_GLOBAL*/
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
static void *
|
static void *
|
||||||
vips_buffer_dump( VipsBuffer *buffer, size_t *reserve, size_t *alive )
|
vips_buffer_dump( VipsBuffer *buffer, size_t *reserve, size_t *alive )
|
||||||
@ -161,6 +169,12 @@ vips_buffer_dump_all( void )
|
|||||||
}
|
}
|
||||||
#endif /*DEBUG_CREATE*/
|
#endif /*DEBUG_CREATE*/
|
||||||
#endif /*DEBUG*/
|
#endif /*DEBUG*/
|
||||||
|
|
||||||
|
#ifdef DEBUG_GLOBAL
|
||||||
|
printf( "buffers: %d global buffers\n", vips_buffer_thread_global_n );
|
||||||
|
printf( "buffers: %d high water global buffers\n",
|
||||||
|
vips_buffer_thread_global_highwater );
|
||||||
|
#endif /*DEBUG_GLOBAL*/
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -252,6 +266,12 @@ buffer_cache_image_postclose( VipsImage *im, VipsBufferCache *cache )
|
|||||||
|
|
||||||
g_hash_table_remove( buffer_thread->hash, im );
|
g_hash_table_remove( buffer_thread->hash, im );
|
||||||
|
|
||||||
|
#ifdef DEBUG_GLOBAL
|
||||||
|
vips_buffer_thread_global_n -= 1;
|
||||||
|
printf( "buffer_cache_image_postclose: %d global buffers\n",
|
||||||
|
vips_buffer_thread_global_n );
|
||||||
|
#endif /*DEBUG_GLOBAL*/
|
||||||
|
|
||||||
g_mutex_unlock( vips__global_lock );
|
g_mutex_unlock( vips__global_lock );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,10 +293,24 @@ buffer_cache_new( VipsBufferThread *buffer_thread, VipsImage *im )
|
|||||||
* from the main thread, since (obviously) thread shutdown will never
|
* from the main thread, since (obviously) thread shutdown will never
|
||||||
* happen. In this case, we need to free resources on image close.
|
* happen. In this case, we need to free resources on image close.
|
||||||
*/
|
*/
|
||||||
if( !vips_thread_isworker() )
|
if( !vips_thread_isworker() ) {
|
||||||
g_signal_connect( im, "postclose",
|
g_signal_connect( im, "postclose",
|
||||||
G_CALLBACK( buffer_cache_image_postclose ), cache );
|
G_CALLBACK( buffer_cache_image_postclose ), cache );
|
||||||
|
|
||||||
|
#ifdef DEBUG_GLOBAL
|
||||||
|
/* No need to lock. Main thread buffer_cache_new() calls are
|
||||||
|
* always inside a lock already.
|
||||||
|
*/
|
||||||
|
vips_buffer_thread_global_n += 1;
|
||||||
|
vips_buffer_thread_global_highwater = VIPS_MAX(
|
||||||
|
vips_buffer_thread_global_highwater,
|
||||||
|
vips_buffer_thread_global_n );
|
||||||
|
|
||||||
|
printf( "buffer_cache_new: %d global buffers\n",
|
||||||
|
vips_buffer_thread_global_n );
|
||||||
|
#endif /*DEBUG_GLOBAL*/
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef DEBUG_CREATE
|
#ifdef DEBUG_CREATE
|
||||||
g_mutex_lock( vips__global_lock );
|
g_mutex_lock( vips__global_lock );
|
||||||
vips__buffer_cache_all =
|
vips__buffer_cache_all =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user