Pass allocation number to callback

This commit is contained in:
Daniel P. Berrange 2008-05-29 18:47:00 +00:00
parent 46f52f32b2
commit e8a0db81ef
4 changed files with 11 additions and 6 deletions

View File

@ -1,3 +1,8 @@
Thu May 29 14:46:00 EST 2008 Daniel P. Berrange <berrange@redhat.com>
* src/memory.h, src/memory.c, tests/testutils.c: Pass allocation
number to hook callback
Thu May 29 14:45:00 EST 2008 Daniel P. Berrange <berrange@redhat.com> Thu May 29 14:45:00 EST 2008 Daniel P. Berrange <berrange@redhat.com>
* src/buf.c: Convert to use new memory allocation APIs * src/buf.c: Convert to use new memory allocation APIs

View File

@ -30,7 +30,7 @@
static int testMallocNext = 0; static int testMallocNext = 0;
static int testMallocFailFirst = 0; static int testMallocFailFirst = 0;
static int testMallocFailLast = 0; static int testMallocFailLast = 0;
static void (*testMallocHook)(void*) = NULL; static void (*testMallocHook)(int, void*) = NULL;
static void *testMallocHookData = NULL; static void *testMallocHookData = NULL;
void virAllocTestInit(void) void virAllocTestInit(void)
@ -45,7 +45,7 @@ int virAllocTestCount(void)
return testMallocNext - 1; return testMallocNext - 1;
} }
void virAllocTestHook(void (*func)(void*), void *data) void virAllocTestHook(void (*func)(int, void*), void *data)
{ {
testMallocHook = func; testMallocHook = func;
testMallocHookData = data; testMallocHookData = data;
@ -69,7 +69,7 @@ static int virAllocTestFail(void)
testMallocNext <= testMallocFailLast; testMallocNext <= testMallocFailLast;
if (fail && testMallocHook) if (fail && testMallocHook)
(testMallocHook)(testMallocHookData); (testMallocHook)(testMallocNext, testMallocHookData);
testMallocNext++; testMallocNext++;
return fail; return fail;

View File

@ -83,7 +83,7 @@ void virFree(void *ptrptr);
void virAllocTestInit(void); void virAllocTestInit(void);
int virAllocTestCount(void); int virAllocTestCount(void);
void virAllocTestOOM(int n, int m); void virAllocTestOOM(int n, int m);
void virAllocTestHook(void (*func)(void*), void *data); void virAllocTestHook(void (*func)(int, void*), void *data);
#endif #endif

View File

@ -293,7 +293,7 @@ virtTestErrorFuncQuiet(void *data ATTRIBUTE_UNUSED,
{ } { }
static void static void
virtTestErrorHook(void *data ATTRIBUTE_UNUSED) virtTestErrorHook(int n, void *data ATTRIBUTE_UNUSED)
{ {
#if TEST_OOM_TRACE #if TEST_OOM_TRACE
void *trace[30]; void *trace[30];
@ -304,7 +304,7 @@ virtTestErrorHook(void *data ATTRIBUTE_UNUSED)
ntrace = backtrace(trace, ntrace); ntrace = backtrace(trace, ntrace);
symbols = backtrace_symbols(trace, ntrace); symbols = backtrace_symbols(trace, ntrace);
if (symbols) { if (symbols) {
fprintf(stderr, "Failing an allocation at:\n"); fprintf(stderr, "Failing allocation %d at:\n", n);
for (i = 0 ; i < ntrace ; i++) { for (i = 0 ; i < ntrace ; i++) {
if (symbols[i]) if (symbols[i])
fprintf(stderr, " TRACE: %s\n", symbols[i]); fprintf(stderr, " TRACE: %s\n", symbols[i]);