MFEM  v4.5.1
Finite element discretization library
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Pages
Public Member Functions | Static Public Member Functions | Friends | List of all members
mfem::MemoryManager Class Reference

#include <mem_manager.hpp>

Public Member Functions

 MemoryManager ()
 
 ~MemoryManager ()
 
void Init ()
 Initialize the memory manager. More...
 
void Configure (const MemoryType h_mt, const MemoryType d_mt)
 Configure the Memory manager with given default host and device types. This method will be called when configuring a device. More...
 
void Destroy ()
 Free all the device memories. More...
 
bool IsKnown (const void *h_ptr)
 Return true if the pointer is known by the memory manager. More...
 
bool IsAlias (const void *h_ptr)
 Return true if the pointer is known by the memory manager as an alias. More...
 
void RegisterCheck (void *h_ptr)
 Check if the host pointer has been registered in the memory manager. More...
 
int PrintPtrs (std::ostream &out=mfem::out)
 
int PrintAliases (std::ostream &out=mfem::out)
 

Static Public Member Functions

static MemoryType GetDualMemoryType (MemoryType mt)
 Return the dual MemoryType of the given one, mt. More...
 
static void SetDualMemoryType (MemoryType mt, MemoryType dual_mt)
 Set the dual memory type of mt to be dual_mt. More...
 
static void SetUmpireHostAllocatorName (const char *h_name)
 Set the host Umpire allocator name used with MemoryType::HOST_UMPIRE. More...
 
static void SetUmpireDeviceAllocatorName (const char *d_name)
 Set the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE. More...
 
static void SetUmpireDevice2AllocatorName (const char *d_name)
 Set the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE_2. More...
 
static const char * GetUmpireHostAllocatorName ()
 Get the host Umpire allocator name used with MemoryType::HOST_UMPIRE. More...
 
static const char * GetUmpireDeviceAllocatorName ()
 Get the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE. More...
 
static const char * GetUmpireDevice2AllocatorName ()
 Get the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE_2. More...
 
static MemoryType GetHostMemoryType ()
 
static MemoryType GetDeviceMemoryType ()
 

Friends

template<typename T >
class Memory
 

Detailed Description

The MFEM memory manager class. Host-side pointers are inserted into this manager which keeps track of the associated device pointer, and where the data currently resides.

Definition at line 581 of file mem_manager.hpp.

Constructor & Destructor Documentation

mfem::MemoryManager::MemoryManager ( )

Definition at line 1520 of file mem_manager.cpp.

mfem::MemoryManager::~MemoryManager ( )

Definition at line 1522 of file mem_manager.cpp.

Member Function Documentation

void mfem::MemoryManager::Configure ( const MemoryType  h_mt,
const MemoryType  d_mt 
)

Configure the Memory manager with given default host and device types. This method will be called when configuring a device.

The host and device MemoryTypes, h_mt and d_mt, are set to be dual to each other.

Definition at line 1555 of file mem_manager.cpp.

void mfem::MemoryManager::Destroy ( )

Free all the device memories.

Definition at line 1574 of file mem_manager.cpp.

static MemoryType mfem::MemoryManager::GetDeviceMemoryType ( )
inlinestatic

Definition at line 830 of file mem_manager.hpp.

static MemoryType mfem::MemoryManager::GetDualMemoryType ( MemoryType  mt)
inlinestatic

Return the dual MemoryType of the given one, mt.

The default dual memory types are:

memory type dual type
HOST DEVICE
HOST_32 DEVICE
HOST_64 DEVICE
HOST_DEBUG DEVICE_DEBUG
HOST_UMPIRE DEVICE_UMPIRE
HOST_PINNED DEVICE
MANAGED MANAGED
DEVICE HOST
DEVICE_DEBUG HOST_DEBUG
DEVICE_UMPIRE HOST_UMPIRE
DEVICE_UMPIRE_2 HOST_UMPIRE

The dual types can be modified before device configuration using the method SetDualMemoryType() or by calling Device::SetMemoryTypes().

Definition at line 773 of file mem_manager.hpp.

static MemoryType mfem::MemoryManager::GetHostMemoryType ( )
inlinestatic

Definition at line 829 of file mem_manager.hpp.

static const char* mfem::MemoryManager::GetUmpireDevice2AllocatorName ( )
inlinestatic

Get the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE_2.

Definition at line 806 of file mem_manager.hpp.

static const char* mfem::MemoryManager::GetUmpireDeviceAllocatorName ( )
inlinestatic

Get the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE.

Definition at line 804 of file mem_manager.hpp.

static const char* mfem::MemoryManager::GetUmpireHostAllocatorName ( )
inlinestatic

Get the host Umpire allocator name used with MemoryType::HOST_UMPIRE.

Definition at line 802 of file mem_manager.hpp.

void mfem::MemoryManager::Init ( )

Initialize the memory manager.

Definition at line 1511 of file mem_manager.cpp.

bool mfem::MemoryManager::IsAlias ( const void *  h_ptr)
inline

Return true if the pointer is known by the memory manager as an alias.

Definition at line 816 of file mem_manager.hpp.

bool mfem::MemoryManager::IsKnown ( const void *  h_ptr)
inline

Return true if the pointer is known by the memory manager.

Definition at line 813 of file mem_manager.hpp.

int mfem::MemoryManager::PrintAliases ( std::ostream &  out = mfem::out)

Prints all aliases known by the memory manager returning the number of printed pointers

Definition at line 1635 of file mem_manager.cpp.

int mfem::MemoryManager::PrintPtrs ( std::ostream &  out = mfem::out)

Prints all pointers known by the memory manager, returning the number of printed pointers

Definition at line 1620 of file mem_manager.cpp.

void mfem::MemoryManager::RegisterCheck ( void *  h_ptr)

Check if the host pointer has been registered in the memory manager.

Definition at line 1609 of file mem_manager.cpp.

void mfem::MemoryManager::SetDualMemoryType ( MemoryType  mt,
MemoryType  dual_mt 
)
static

Set the dual memory type of mt to be dual_mt.

This method can only be called before configuration, i.e. before calling Configure(), which is typically done during Device construction.

One of the types must be a host MemoryType and the other must be a device MemoryType or both types must be the same host memory type. The latter case is only allowed for convenience in setting up pure host execution, so the actual dual is not updated.

Definition at line 1524 of file mem_manager.cpp.

static void mfem::MemoryManager::SetUmpireDevice2AllocatorName ( const char *  d_name)
inlinestatic

Set the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE_2.

Definition at line 799 of file mem_manager.hpp.

static void mfem::MemoryManager::SetUmpireDeviceAllocatorName ( const char *  d_name)
inlinestatic

Set the device Umpire allocator name used with MemoryType::DEVICE_UMPIRE.

Definition at line 797 of file mem_manager.hpp.

static void mfem::MemoryManager::SetUmpireHostAllocatorName ( const char *  h_name)
inlinestatic

Set the host Umpire allocator name used with MemoryType::HOST_UMPIRE.

Definition at line 795 of file mem_manager.hpp.

Friends And Related Function Documentation

template<typename T >
friend class Memory
friend

Definition at line 588 of file mem_manager.hpp.


The documentation for this class was generated from the following files: