diff options
author | danielk1977 <danielk1977@noemail.net> | 2008-06-25 14:26:07 +0000 |
---|---|---|
committer | danielk1977 <danielk1977@noemail.net> | 2008-06-25 14:26:07 +0000 |
commit | c66c0e14a69504fecfe19cfd0e031e94c1b0b1e3 (patch) | |
tree | 55edb443e6b63863bf505e432a4e29e7bf12d6c7 /src/test_malloc.c | |
parent | 32155ef0ff75d468632d0f1428be1bc4888060a1 (diff) | |
download | sqlite-c66c0e14a69504fecfe19cfd0e031e94c1b0b1e3.tar.gz sqlite-c66c0e14a69504fecfe19cfd0e031e94c1b0b1e3.zip |
Fix the allocator in mem5.c so that it can be enabled at run time using the sqlite3_config() function. (CVS 5304)
FossilOrigin-Name: 30ff6bb0b2d1068d28e86ac90bb9f454e4537a2d
Diffstat (limited to 'src/test_malloc.c')
-rw-r--r-- | src/test_malloc.c | 87 |
1 files changed, 53 insertions, 34 deletions
diff --git a/src/test_malloc.c b/src/test_malloc.c index 95b44ac5f..dbb6fecf4 100644 --- a/src/test_malloc.c +++ b/src/test_malloc.c @@ -13,7 +13,7 @@ ** This file contains code used to implement test interfaces to the ** memory allocation subsystem. ** -** $Id: test_malloc.c,v 1.30 2008/06/25 10:34:35 danielk1977 Exp $ +** $Id: test_malloc.c,v 1.31 2008/06/25 14:26:09 danielk1977 Exp $ */ #include "sqliteInt.h" #include "tcl.h" @@ -931,18 +931,20 @@ static int test_config_pagecache( } /* -** Usage: sqlite3_config_memsys3 NBYTE +** Usage: +** +** sqlite3_config_memsys3 NBYTE +** sqlite3_config_memsys5 NBYTE ** */ static int test_config_memsys3( - void * clientData, + void * clientData, Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[] ){ int sz, rc; - Tcl_Obj *pResult; - static char buf[1000000]; + static char buf[1048576]; if( objc!=2 ){ Tcl_WrongNumArgs(interp, 1, objv, "NBYTE"); return TCL_ERROR; @@ -956,14 +958,17 @@ static int test_config_memsys3( if( sz>sizeof(buf) ){ sz = sizeof(buf); } - rc = sqlite3_config(SQLITE_CONFIG_MEMSYS3, buf, sz); + rc = sqlite3_config((int)clientData, buf, sz); } Tcl_SetResult(interp, (char *)sqlite3TestErrorName(rc), TCL_VOLATILE); return TCL_OK; } /* -** Usage: sqlite3_dump_memsys3 FILENAME +** Usage: +** +** sqlite3_dump_memsys3 FILENAME +** sqlite3_dump_memsys5 FILENAME ** ** Write a summary of unfreed memsys3 allocations to FILENAME. */ @@ -977,13 +982,23 @@ static int test_dump_memsys3( Tcl_WrongNumArgs(interp, 1, objv, "FILENAME"); return TCL_ERROR; } -#if defined(SQLITE_MEMDEBUG) || defined(SQLITE_MEMORY_SIZE) \ - || defined(SQLITE_POW2_MEMORY_SIZE) - { - extern void sqlite3Memsys3Dump(const char*); - sqlite3Memsys3Dump(Tcl_GetString(objv[1])); - } + + switch( (int)clientData ){ + case SQLITE_CONFIG_MEMSYS3: { +#ifdef SQLITE_ENABLE_MEMSYS3 + extern void sqlite3Memsys3Dump(const char*); + sqlite3Memsys3Dump(Tcl_GetString(objv[1])); + break; #endif + } + case SQLITE_CONFIG_MEMSYS5: { +#ifdef SQLITE_ENABLE_MEMSYS5 + extern void sqlite3Memsys5Dump(const char*); + sqlite3Memsys5Dump(Tcl_GetString(objv[1])); + break; +#endif + } + } return TCL_OK; } @@ -1069,31 +1084,35 @@ int Sqlitetest_malloc_Init(Tcl_Interp *interp){ static struct { char *zName; Tcl_ObjCmdProc *xProc; + int clientData; } aObjCmd[] = { - { "sqlite3_malloc", test_malloc }, - { "sqlite3_realloc", test_realloc }, - { "sqlite3_free", test_free }, - { "memset", test_memset }, - { "memget", test_memget }, - { "sqlite3_memory_used", test_memory_used }, - { "sqlite3_memory_highwater", test_memory_highwater }, - { "sqlite3_memdebug_backtrace", test_memdebug_backtrace }, - { "sqlite3_memdebug_dump", test_memdebug_dump }, - { "sqlite3_memdebug_fail", test_memdebug_fail }, - { "sqlite3_memdebug_pending", test_memdebug_pending }, - { "sqlite3_memdebug_settitle", test_memdebug_settitle }, - { "sqlite3_memdebug_malloc_count", test_memdebug_malloc_count }, - { "sqlite3_memdebug_log", test_memdebug_log }, - { "sqlite3_config_scratch", test_config_scratch }, - { "sqlite3_config_pagecache", test_config_pagecache }, - { "sqlite3_config_memsys3", test_config_memsys3 }, - { "sqlite3_dump_memsys3", test_dump_memsys3 }, - { "sqlite3_status", test_status }, - { "install_malloc_faultsim", test_install_malloc_faultsim }, + { "sqlite3_malloc", test_malloc ,0. }, + { "sqlite3_realloc", test_realloc ,0. }, + { "sqlite3_free", test_free ,0. }, + { "memset", test_memset ,0. }, + { "memget", test_memget ,0. }, + { "sqlite3_memory_used", test_memory_used ,0. }, + { "sqlite3_memory_highwater", test_memory_highwater ,0. }, + { "sqlite3_memdebug_backtrace", test_memdebug_backtrace ,0. }, + { "sqlite3_memdebug_dump", test_memdebug_dump ,0. }, + { "sqlite3_memdebug_fail", test_memdebug_fail ,0. }, + { "sqlite3_memdebug_pending", test_memdebug_pending ,0. }, + { "sqlite3_memdebug_settitle", test_memdebug_settitle ,0. }, + { "sqlite3_memdebug_malloc_count", test_memdebug_malloc_count ,0. }, + { "sqlite3_memdebug_log", test_memdebug_log ,0. }, + { "sqlite3_config_scratch", test_config_scratch ,0. }, + { "sqlite3_config_pagecache", test_config_pagecache ,0. }, + { "sqlite3_status", test_status ,0. }, + { "install_malloc_faultsim", test_install_malloc_faultsim ,0. }, + { "sqlite3_config_memsys3", test_config_memsys3, SQLITE_CONFIG_MEMSYS3 }, + { "sqlite3_config_memsys5", test_config_memsys3, SQLITE_CONFIG_MEMSYS5 }, + { "sqlite3_dump_memsys3", test_dump_memsys3 , SQLITE_CONFIG_MEMSYS3 }, + { "sqlite3_dump_memsys5", test_dump_memsys3 , SQLITE_CONFIG_MEMSYS5 } }; int i; for(i=0; i<sizeof(aObjCmd)/sizeof(aObjCmd[0]); i++){ - Tcl_CreateObjCommand(interp, aObjCmd[i].zName, aObjCmd[i].xProc, 0, 0); + ClientData c = (ClientData)aObjCmd[i].clientData; + Tcl_CreateObjCommand(interp, aObjCmd[i].zName, aObjCmd[i].xProc, c, 0); } return TCL_OK; } |