Merge remote-tracking branch 'origin/7.36'

Conflicts:
	ChangeLog
	configure.ac
This commit is contained in:
John Cupitt 2013-11-20 15:12:14 +00:00
commit dc24afb28f
3 changed files with 18 additions and 9 deletions

View File

@ -24,6 +24,9 @@
- add --strip option to jpegsave - add --strip option to jpegsave
- added vips_gaussblur() convenience function - added vips_gaussblur() convenience function
20/11/13 started 7.36.5
- better cache sizing in unbuffered sequential mode
15/11/13 started 7.36.4 15/11/13 started 7.36.4
- improve compat with im_init_world() - improve compat with im_init_world()

View File

@ -46,6 +46,7 @@
*/ */
/* /*
#define VIPS_DEBUG_GREEN
#define VIPS_DEBUG #define VIPS_DEBUG
*/ */
@ -120,7 +121,7 @@ vips_sequential_generate( VipsRegion *or,
VipsRect *r = &or->valid; VipsRect *r = &or->valid;
VipsRegion *ir = (VipsRegion *) seq; VipsRegion *ir = (VipsRegion *) seq;
VIPS_DEBUG_MSG( "thread %p request for line %d, height %d\n", VIPS_DEBUG_MSG_GREEN( "thread %p request for line %d, height %d\n",
g_thread_self(), r->top, r->height ); g_thread_self(), r->top, r->height );
if( sequential->trace ) if( sequential->trace )
@ -130,7 +131,7 @@ vips_sequential_generate( VipsRegion *or,
g_mutex_lock( sequential->lock ); g_mutex_lock( sequential->lock );
VIPS_DEBUG_MSG( "thread %p has lock ...\n", g_thread_self() ); VIPS_DEBUG_MSG_GREEN( "thread %p has lock ...\n", g_thread_self() );
/* If we've seen an error, everything must stop. /* If we've seen an error, everything must stop.
*/ */
@ -163,7 +164,7 @@ vips_sequential_generate( VipsRegion *or,
g_time_val_add( &time, STALL_TIME * 1000000 ); g_time_val_add( &time, STALL_TIME * 1000000 );
#endif #endif
VIPS_DEBUG_MSG( "thread %p stalling for up to %gs ...\n", VIPS_DEBUG_MSG_GREEN( "thread %p stalling for up to %gs ...\n",
g_thread_self(), STALL_TIME ); g_thread_self(), STALL_TIME );
/* Exit the loop on timeout or condition passes. We have to /* Exit the loop on timeout or condition passes. We have to
@ -180,7 +181,7 @@ vips_sequential_generate( VipsRegion *or,
break; break;
#endif #endif
VIPS_DEBUG_MSG( "thread %p awake again ...\n", VIPS_DEBUG_MSG_GREEN( "thread %p awake again ...\n",
g_thread_self() ); g_thread_self() );
} }
@ -194,7 +195,7 @@ vips_sequential_generate( VipsRegion *or,
*/ */
VipsRect area; VipsRect area;
VIPS_DEBUG_MSG( "thread %p skipping to line %d ...\n", VIPS_DEBUG_MSG_GREEN( "thread %p skipping to line %d ...\n",
g_thread_self(), g_thread_self(),
r->top ); r->top );
@ -217,7 +218,7 @@ vips_sequential_generate( VipsRegion *or,
/* This is a request for old or present pixels -- serve from cache. /* This is a request for old or present pixels -- serve from cache.
* This may trigger further, sequential reads. * This may trigger further, sequential reads.
*/ */
VIPS_DEBUG_MSG( "thread %p reading ...\n", g_thread_self() ); VIPS_DEBUG_MSG_GREEN( "thread %p reading ...\n", g_thread_self() );
if( vips_region_prepare( ir, r ) || if( vips_region_prepare( ir, r ) ||
vips_region_region( or, ir, r, r->left, r->top ) ) { vips_region_region( or, ir, r, r->left, r->top ) ) {
VIPS_DEBUG_MSG( "thread %p error, unlocking ...\n", VIPS_DEBUG_MSG( "thread %p error, unlocking ...\n",
@ -234,7 +235,7 @@ vips_sequential_generate( VipsRegion *or,
*/ */
sequential->y_pos = VIPS_RECT_BOTTOM( r ); sequential->y_pos = VIPS_RECT_BOTTOM( r );
VIPS_DEBUG_MSG( "thread %p updating y_pos to %d and " VIPS_DEBUG_MSG_GREEN( "thread %p updating y_pos to %d and "
"waking stalled\n", "waking stalled\n",
g_thread_self(), g_thread_self(),
sequential->y_pos ); sequential->y_pos );
@ -242,7 +243,7 @@ vips_sequential_generate( VipsRegion *or,
g_cond_broadcast( sequential->ready ); g_cond_broadcast( sequential->ready );
} }
VIPS_DEBUG_MSG( "thread %p unlocking ...\n", g_thread_self() ); VIPS_DEBUG_MSG_GREEN( "thread %p unlocking ...\n", g_thread_self() );
g_mutex_unlock( sequential->lock ); g_mutex_unlock( sequential->lock );

View File

@ -898,7 +898,12 @@ vips_line_cache_build( VipsObject *object )
block_cache->access = cache->access; block_cache->access = cache->access;
if( cache->access == VIPS_ACCESS_SEQUENTIAL_UNBUFFERED ) if( cache->access == VIPS_ACCESS_SEQUENTIAL_UNBUFFERED )
block_cache->max_tiles = 1; /* A tile per thread.
*
* Imagine scanline tiles and four threads. And add a bit for
* slop.
*/
block_cache->max_tiles = 2 * vips_concurrency_get();
else { else {
/* Enough lines for two complete buffers would be exactly /* Enough lines for two complete buffers would be exactly
* right. Make it 3 to give us some slop room. * right. Make it 3 to give us some slop room.