SDL_GetNumAllocations returns -1 when allocation counting is disabled

This commit is contained in:
Anonymous Maarten
2024-12-21 20:25:06 +01:00
committed by Sam Lantinga
parent a33144fbc9
commit f8d8bf8066
3 changed files with 15 additions and 19 deletions

View File

@@ -1542,7 +1542,8 @@ extern SDL_DECLSPEC void SDLCALL SDL_aligned_free(void *mem);
/** /**
* Get the number of outstanding (unfreed) allocations. * Get the number of outstanding (unfreed) allocations.
* *
* \returns the number of allocations. * \returns the number of allocations or
* -1 if allocation counting is disabled.
* *
* \threadsafety It is safe to call this function from any thread. * \threadsafety It is safe to call this function from any thread.
* *

View File

@@ -6353,8 +6353,8 @@ static struct
}; };
// Define this if you want to track the number of allocations active // Define this if you want to track the number of allocations active
// #define TRACK_ALLOCATION_COUNT // #define SDL_TRACK_ALLOCATION_COUNT
#ifdef TRACK_ALLOCATION_COUNT #ifdef SDL_TRACK_ALLOCATION_COUNT
#define INCREMENT_ALLOCATION_COUNT() (void)SDL_AtomicIncRef(&s_mem.num_allocations) #define INCREMENT_ALLOCATION_COUNT() (void)SDL_AtomicIncRef(&s_mem.num_allocations)
#define DECREMENT_ALLOCATION_COUNT() (void)SDL_AtomicDecRef(&s_mem.num_allocations) #define DECREMENT_ALLOCATION_COUNT() (void)SDL_AtomicDecRef(&s_mem.num_allocations)
#else #else
@@ -6428,7 +6428,11 @@ bool SDL_SetMemoryFunctions(SDL_malloc_func malloc_func,
int SDL_GetNumAllocations(void) int SDL_GetNumAllocations(void)
{ {
#ifdef SDL_TRACK_ALLOCATION_COUNT
return SDL_GetAtomicInt(&s_mem.num_allocations); return SDL_GetAtomicInt(&s_mem.num_allocations);
#else
return -1;
#endif
} }
void *SDL_malloc(size_t size) void *SDL_malloc(size_t size)

View File

@@ -71,11 +71,8 @@ static SDL_malloc_func SDL_malloc_orig = NULL;
static SDL_calloc_func SDL_calloc_orig = NULL; static SDL_calloc_func SDL_calloc_orig = NULL;
static SDL_realloc_func SDL_realloc_orig = NULL; static SDL_realloc_func SDL_realloc_orig = NULL;
static SDL_free_func SDL_free_orig = NULL; static SDL_free_func SDL_free_orig = NULL;
#ifdef TRACK_ALLOCATION_COUNT
static int s_previous_allocations = 0; static int s_previous_allocations = 0;
#else
static int s_unknown_frees = 0; static int s_unknown_frees = 0;
#endif
static SDL_tracked_allocation *s_tracked_allocations[256]; static SDL_tracked_allocation *s_tracked_allocations[256];
static bool s_randfill_allocations = false; static bool s_randfill_allocations = false;
static SDL_AtomicInt s_lock; static SDL_AtomicInt s_lock;
@@ -215,9 +212,9 @@ static void SDL_UntrackAllocation(void *mem)
} }
prev = entry; prev = entry;
} }
#ifndef TRACK_ALLOCATION_COUNT if (s_tracked_allocations < 0) {
s_unknown_frees += 1; s_unknown_frees += 1;
#endif }
UNLOCK_ALLOCATOR(); UNLOCK_ALLOCATOR();
} }
@@ -284,11 +281,9 @@ static void SDLCALL SDLTest_TrackedFree(void *ptr)
return; return;
} }
#ifdef TRACK_ALLOCATION_COUNT if (s_previous_allocations == 0) {
if (!s_previous_allocations) {
SDL_assert(SDL_IsAllocationTracked(ptr)); SDL_assert(SDL_IsAllocationTracked(ptr));
} }
#endif
SDL_UntrackAllocation(ptr); SDL_UntrackAllocation(ptr);
SDL_free_orig(ptr); SDL_free_orig(ptr);
} }
@@ -301,14 +296,12 @@ void SDLTest_TrackAllocations(void)
SDLTest_Crc32Init(&s_crc32_context); SDLTest_Crc32Init(&s_crc32_context);
#ifdef TRACK_ALLOCATION_COUNT
s_previous_allocations = SDL_GetNumAllocations(); s_previous_allocations = SDL_GetNumAllocations();
if (s_previous_allocations != 0) { if (s_previous_allocations < 0) {
SDL_Log("SDL was built without allocation count support, disabling free() validation");
} else if (s_previous_allocations != 0) {
SDL_Log("SDLTest_TrackAllocations(): There are %d previous allocations, disabling free() validation", s_previous_allocations); SDL_Log("SDLTest_TrackAllocations(): There are %d previous allocations, disabling free() validation", s_previous_allocations);
} }
#else
SDL_Log("SDL was built without allocation count support, disabling free() validation");
#endif
#ifdef SDLTEST_UNWIND_NO_PROC_NAME_BY_IP #ifdef SDLTEST_UNWIND_NO_PROC_NAME_BY_IP
do { do {
/* Don't use SDL_GetHint: SDL_malloc is off limits. */ /* Don't use SDL_GetHint: SDL_malloc is off limits. */
@@ -454,12 +447,10 @@ void SDLTest_LogAllocations(void)
} }
(void)SDL_snprintf(line, sizeof(line), "Total: %.2f Kb in %d allocations", total_allocated / 1024.0, count); (void)SDL_snprintf(line, sizeof(line), "Total: %.2f Kb in %d allocations", total_allocated / 1024.0, count);
ADD_LINE(); ADD_LINE();
#ifndef TRACK_ALLOCATION_COUNT
if (s_unknown_frees != 0) { if (s_unknown_frees != 0) {
(void)SDL_snprintf(line, sizeof(line), ", %d unknown frees", s_unknown_frees); (void)SDL_snprintf(line, sizeof(line), ", %d unknown frees", s_unknown_frees);
ADD_LINE(); ADD_LINE();
} }
#endif
(void)SDL_snprintf(line, sizeof(line), "\n"); (void)SDL_snprintf(line, sizeof(line), "\n");
ADD_LINE(); ADD_LINE();
#undef ADD_LINE #undef ADD_LINE