From 3694fd23d49d63e79fabb113270d41d8b1905608 Mon Sep 17 00:00:00 2001 From: Greg Eisenhauer Date: Mon, 3 Jul 2023 13:55:04 -0400 Subject: [PATCH] Merge pull request #3684 from eisenhauer/FixLeak Fix memory leak when there are Joined Arrays in streaming mode (cherry picked from commit 68b282cbb023e037d3cbdaed57aa7de28b2c7650) --- source/adios2/toolkit/format/bp5/BP5Deserializer.cpp | 10 ++++++++-- source/adios2/toolkit/format/bp5/BP5Deserializer.h | 1 + 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/source/adios2/toolkit/format/bp5/BP5Deserializer.cpp b/source/adios2/toolkit/format/bp5/BP5Deserializer.cpp index 9a0c98c432..863d619685 100644 --- a/source/adios2/toolkit/format/bp5/BP5Deserializer.cpp +++ b/source/adios2/toolkit/format/bp5/BP5Deserializer.cpp @@ -707,7 +707,7 @@ void BP5Deserializer::InstallMetaData(void *MetadataBlock, size_t BlockLen, m_JoinedDimenOffsetArrays = new std::vector(); m_JoinedDimenOffsetArrays->resize(writerCohortSize); JoinedDimArray[Step] = m_JoinedDimenOffsetArrays; - m_FreeableMBA = nullptr; + m_FreeableJDOA = nullptr; } } else @@ -725,7 +725,7 @@ void BP5Deserializer::InstallMetaData(void *MetadataBlock, size_t BlockLen, if (!m_JoinedDimenOffsetArrays) { m_JoinedDimenOffsetArrays = new std::vector(); - m_FreeableMBA = m_JoinedDimenOffsetArrays; + m_FreeableJDOA = m_JoinedDimenOffsetArrays; } if (writerCohortSize > m_JoinedDimenOffsetArrays->size()) { @@ -2001,7 +2001,13 @@ BP5Deserializer::~BP5Deserializer() delete VarRec.second; } if (m_FreeableMBA) + { delete m_FreeableMBA; + } + if (m_FreeableJDOA) + { + delete m_FreeableJDOA; + } for (auto &step : MetadataBaseArray) { delete step; diff --git a/source/adios2/toolkit/format/bp5/BP5Deserializer.h b/source/adios2/toolkit/format/bp5/BP5Deserializer.h index b7f6e2e082..d1c932dc79 100644 --- a/source/adios2/toolkit/format/bp5/BP5Deserializer.h +++ b/source/adios2/toolkit/format/bp5/BP5Deserializer.h @@ -174,6 +174,7 @@ class BP5Deserializer : virtual public BP5Base std::vector *m_FreeableMBA = nullptr; std::vector *m_JoinedDimenOffsetArrays = nullptr; + std::vector *m_FreeableJDOA = nullptr; // for random access mode, for each timestep, for each writerrank, what // metameta info applies to the metadata