From a4c09d168029dccac872b5816b21f8298f73f5e9 Mon Sep 17 00:00:00 2001 From: Azaezel Date: Mon, 1 Jun 2015 23:45:49 -0500 Subject: [PATCH] leak prevention according to: https://vld.codeplex.com/ apparently we weren't freeing the entirety of the ProfilerData linked list when resetting the Profiler, and that was leading to a pinhole leak per profiled block --- Engine/source/platform/profiler.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/Engine/source/platform/profiler.cpp b/Engine/source/platform/profiler.cpp index 8284ffb34..ae35035f7 100644 --- a/Engine/source/platform/profiler.cpp +++ b/Engine/source/platform/profiler.cpp @@ -212,11 +212,14 @@ Profiler::~Profiler() void Profiler::reset() { mEnabled = false; // in case we're in a profiler call. - while(mProfileList) + ProfilerData * head = mProfileList; + ProfilerData * curr = NULL; + while ((curr = head) != NULL) { - free(mProfileList); - mProfileList = NULL; + head = head->mNextProfilerData; + free(curr); } + for(ProfilerRootData *walk = ProfilerRootData::sRootList; walk; walk = walk->mNextRoot) { walk->mFirstProfilerData = 0;