diff options
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | src/pj_initcache.c | 124 |
2 files changed, 67 insertions, 62 deletions
@@ -1,3 +1,8 @@ +2011-03-23 Frank Warmerdam <warmerdam@pobox.com> + + * src/pj_initcache.c: Fix reversed memcpy that causes a crash on the + 16th item put in the initcache. (#100). + 2011-02-21 Frank Warmerdam <warmerdam@pobox.com> * src/pj_init.c: fix serious bug in locale handling, wasn't copying diff --git a/src/pj_initcache.c b/src/pj_initcache.c index 5dd46fad..71036f23 100644 --- a/src/pj_initcache.c +++ b/src/pj_initcache.c @@ -75,34 +75,34 @@ paralist *pj_clone_paralist( const paralist *list) void pj_clear_initcache() { - if( cache_alloc > 0 ) - { - int i; + if( cache_alloc > 0 ) + { + int i; - pj_acquire_lock(); + pj_acquire_lock(); - for( i = 0; i < cache_count; i++ ) - { - paralist *n, *t = cache_paralist[i]; + for( i = 0; i < cache_count; i++ ) + { + paralist *n, *t = cache_paralist[i]; - pj_dalloc( cache_key[i] ); - - /* free parameter list elements */ - for (; t != NULL; t = n) { - n = t->next; - pj_dalloc(t); - } - } - - pj_dalloc( cache_key ); - pj_dalloc( cache_paralist ); - cache_count = 0; - cache_alloc= 0; - cache_key = NULL; - cache_paralist = NULL; - - pj_release_lock(); - } + pj_dalloc( cache_key[i] ); + + /* free parameter list elements */ + for (; t != NULL; t = n) { + n = t->next; + pj_dalloc(t); + } + } + + pj_dalloc( cache_key ); + pj_dalloc( cache_paralist ); + cache_count = 0; + cache_alloc= 0; + cache_key = NULL; + cache_paralist = NULL; + + pj_release_lock(); + } } /************************************************************************/ @@ -114,22 +114,22 @@ void pj_clear_initcache() paralist *pj_search_initcache( const char *filekey ) { - int i; - paralist *result = NULL; + int i; + paralist *result = NULL; - pj_acquire_lock(); + pj_acquire_lock(); - for( i = 0; result == NULL && i < cache_count; i++) + for( i = 0; result == NULL && i < cache_count; i++) { - if( strcmp(filekey,cache_key[i]) == 0 ) + if( strcmp(filekey,cache_key[i]) == 0 ) { - result = pj_clone_paralist( cache_paralist[i] ); + result = pj_clone_paralist( cache_paralist[i] ); } } - pj_release_lock(); + pj_release_lock(); - return result; + return result; } /************************************************************************/ @@ -141,41 +141,41 @@ paralist *pj_search_initcache( const char *filekey ) void pj_insert_initcache( const char *filekey, const paralist *list ) { - pj_acquire_lock(); + pj_acquire_lock(); - /* - ** Grow list if required. - */ - if( cache_count == cache_alloc ) + /* + ** Grow list if required. + */ + if( cache_count == cache_alloc ) { - char **cache_key_new; - paralist **cache_paralist_new; - - cache_alloc = cache_alloc * 2 + 15; - - cache_key_new = (char **) pj_malloc(sizeof(char*) * cache_alloc); - memcpy( cache_key, cache_key_new, sizeof(char*) * cache_count); - pj_dalloc( cache_key ); - cache_key = cache_key_new; - - cache_paralist_new = (paralist **) - pj_malloc(sizeof(paralist*) * cache_alloc); - memcpy( cache_paralist_new, cache_paralist, - sizeof(paralist*) * cache_count ); - pj_dalloc( cache_paralist ); - cache_paralist = cache_paralist_new; + char **cache_key_new; + paralist **cache_paralist_new; + + cache_alloc = cache_alloc * 2 + 15; + + cache_key_new = (char **) pj_malloc(sizeof(char*) * cache_alloc); + memcpy( cache_key_new, cache_key, sizeof(char*) * cache_count); + pj_dalloc( cache_key ); + cache_key = cache_key_new; + + cache_paralist_new = (paralist **) + pj_malloc(sizeof(paralist*) * cache_alloc); + memcpy( cache_paralist_new, cache_paralist, + sizeof(paralist*) * cache_count ); + pj_dalloc( cache_paralist ); + cache_paralist = cache_paralist_new; } - /* - ** Duplicate the filekey and paralist, and insert in cache. - */ - cache_key[cache_count] = (char *) pj_malloc(strlen(filekey)+1); - strcpy( cache_key[cache_count], filekey ); + /* + ** Duplicate the filekey and paralist, and insert in cache. + */ + cache_key[cache_count] = (char *) pj_malloc(strlen(filekey)+1); + strcpy( cache_key[cache_count], filekey ); - cache_paralist[cache_count] = pj_clone_paralist( list ); + cache_paralist[cache_count] = pj_clone_paralist( list ); - cache_count++; + cache_count++; - pj_release_lock(); + pj_release_lock(); } |
