Fix memory tracker with omp (#844)
This PR fixes hypre memory tracker with OMP threading.
This commit is contained in:
parent
1eabaf5f33
commit
2391e4703f
@ -914,6 +914,8 @@ typedef struct
|
||||
hypre_MemoryTrackerQueue queue[HYPRE_MEMORY_NUM_EVENTS];
|
||||
} hypre_MemoryTracker;
|
||||
|
||||
extern hypre_MemoryTracker *_hypre_memory_tracker;
|
||||
|
||||
#define hypre_TAlloc(type, count, location) \
|
||||
( \
|
||||
{ \
|
||||
|
||||
@ -8,22 +8,6 @@
|
||||
#include "_hypre_utilities.h"
|
||||
#include "_hypre_utilities.hpp"
|
||||
|
||||
#ifdef HYPRE_USING_MEMORY_TRACKER
|
||||
hypre_MemoryTracker *_hypre_memory_tracker = NULL;
|
||||
|
||||
/* accessor to the global ``_hypre_memory_tracker'' */
|
||||
hypre_MemoryTracker*
|
||||
hypre_memory_tracker(void)
|
||||
{
|
||||
if (!_hypre_memory_tracker)
|
||||
{
|
||||
_hypre_memory_tracker = hypre_MemoryTrackerCreate();
|
||||
}
|
||||
|
||||
return _hypre_memory_tracker;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* global variable _hypre_handle:
|
||||
* Outside this file, do NOT access it directly,
|
||||
* but use hypre_handle() instead (see handle.h) */
|
||||
|
||||
@ -16,6 +16,25 @@
|
||||
|
||||
#if defined(HYPRE_USING_MEMORY_TRACKER)
|
||||
|
||||
hypre_MemoryTracker *_hypre_memory_tracker = NULL;
|
||||
|
||||
/* accessor to the global ``_hypre_memory_tracker'' */
|
||||
hypre_MemoryTracker*
|
||||
hypre_memory_tracker(void)
|
||||
{
|
||||
#ifdef HYPRE_USING_OPENMP
|
||||
#pragma omp critical
|
||||
#endif
|
||||
{
|
||||
if (!_hypre_memory_tracker)
|
||||
{
|
||||
_hypre_memory_tracker = hypre_MemoryTrackerCreate();
|
||||
}
|
||||
}
|
||||
|
||||
return _hypre_memory_tracker;
|
||||
}
|
||||
|
||||
size_t hypre_total_bytes[hypre_NUM_MEMORY_LOCATION];
|
||||
size_t hypre_peak_bytes[hypre_NUM_MEMORY_LOCATION];
|
||||
size_t hypre_current_bytes[hypre_NUM_MEMORY_LOCATION];
|
||||
@ -252,6 +271,10 @@ hypre_MemoryTrackerInsert2(const char *action,
|
||||
|
||||
hypre_MemoryTrackerQueue *queue = &tracker->queue[q];
|
||||
|
||||
#ifdef HYPRE_USING_OPENMP
|
||||
#pragma omp critical
|
||||
#endif
|
||||
{
|
||||
/* resize if not enough space */
|
||||
|
||||
if (queue->alloced_size <= queue->actual_size)
|
||||
@ -291,6 +314,7 @@ hypre_MemoryTrackerInsert2(const char *action,
|
||||
/* increase the queue length by 1 */
|
||||
queue->actual_size ++;
|
||||
}
|
||||
}
|
||||
|
||||
HYPRE_Int
|
||||
hypre_PrintMemoryTracker( size_t *totl_bytes_o,
|
||||
|
||||
@ -69,6 +69,8 @@ typedef struct
|
||||
hypre_MemoryTrackerQueue queue[HYPRE_MEMORY_NUM_EVENTS];
|
||||
} hypre_MemoryTracker;
|
||||
|
||||
extern hypre_MemoryTracker *_hypre_memory_tracker;
|
||||
|
||||
#define hypre_TAlloc(type, count, location) \
|
||||
( \
|
||||
{ \
|
||||
|
||||
Loading…
Reference in New Issue
Block a user