ArmNN
 21.02
RefTensorHandle Class Reference

#include <RefTensorHandle.hpp>

Inheritance diagram for RefTensorHandle:
ITensorHandle

Public Member Functions

 RefTensorHandle (const TensorInfo &tensorInfo, std::shared_ptr< RefMemoryManager > &memoryManager)
 
 RefTensorHandle (const TensorInfo &tensorInfo, MemorySourceFlags importFlags)
 
 ~RefTensorHandle ()
 
virtual void Manage () override
 Indicate to the memory manager that this resource is active. More...
 
virtual void Allocate () override
 Indicate to the memory manager that this resource is no longer active. More...
 
virtual ITensorHandleGetParent () const override
 Get the parent tensor if this is a subtensor. More...
 
virtual const void * Map (bool) const override
 Map the tensor data for access. More...
 
virtual void Unmap () const override
 Unmap the tensor data. More...
 
TensorShape GetStrides () const override
 Get the strides for each dimension ordered from largest to smallest where the smallest value is the same as the size of a single element in the tensor. More...
 
TensorShape GetShape () const override
 Get the number of elements for each dimension ordered from slowest iterating dimension to fastest iterating dimension. More...
 
const TensorInfoGetTensorInfo () const
 
virtual MemorySourceFlags GetImportFlags () const override
 Get flags describing supported import sources. More...
 
virtual bool Import (void *memory, MemorySource source) override
 Import externally allocated memory. More...
 
- Public Member Functions inherited from ITensorHandle
virtual ~ITensorHandle ()
 
void * Map (bool blocking=true)
 Map the tensor data for access. More...
 
void Unmap ()
 Unmap the tensor data that was previously mapped with call to Map(). More...
 

Detailed Description

Definition at line 15 of file RefTensorHandle.hpp.

Constructor & Destructor Documentation

◆ RefTensorHandle() [1/2]

RefTensorHandle ( const TensorInfo tensorInfo,
std::shared_ptr< RefMemoryManager > &  memoryManager 
)

Definition at line 10 of file RefTensorHandle.cpp.

Referenced by RefTensorHandle::GetImportFlags().

10  :
11  m_TensorInfo(tensorInfo),
12  m_MemoryManager(memoryManager),
13  m_Pool(nullptr),
14  m_UnmanagedMemory(nullptr),
15  m_ImportFlags(static_cast<MemorySourceFlags>(MemorySource::Undefined)),
16  m_Imported(false),
17  m_IsImportEnabled(false)
18 {
19 
20 }

◆ RefTensorHandle() [2/2]

RefTensorHandle ( const TensorInfo tensorInfo,
MemorySourceFlags  importFlags 
)

Definition at line 22 of file RefTensorHandle.cpp.

24  : m_TensorInfo(tensorInfo),
25  m_Pool(nullptr),
26  m_UnmanagedMemory(nullptr),
27  m_ImportFlags(importFlags),
28  m_Imported(false),
29  m_IsImportEnabled(true)
30 {
31 
32 }

◆ ~RefTensorHandle()

Definition at line 34 of file RefTensorHandle.cpp.

35 {
36  if (!m_Pool)
37  {
38  // unmanaged
39  if (!m_Imported)
40  {
41  ::operator delete(m_UnmanagedMemory);
42  }
43  }
44 }

Member Function Documentation

◆ Allocate()

void Allocate ( )
overridevirtual

Indicate to the memory manager that this resource is no longer active.

This is used to compute overlapping lifetimes of resources.

Implements ITensorHandle.

Definition at line 57 of file RefTensorHandle.cpp.

References TensorInfo::GetNumBytes().

58 {
59  // If import is enabled, do not allocate the tensor
60  if (!m_IsImportEnabled)
61  {
62 
63  if (!m_UnmanagedMemory)
64  {
65  if (!m_Pool)
66  {
67  // unmanaged
68  m_UnmanagedMemory = ::operator new(m_TensorInfo.GetNumBytes());
69  }
70  else
71  {
72  m_MemoryManager->Allocate(m_Pool);
73  }
74  }
75  else
76  {
77  throw InvalidArgumentException("RefTensorHandle::Allocate Trying to allocate a RefTensorHandle"
78  "that already has allocated memory.");
79  }
80  }
81 }
unsigned int GetNumBytes() const
Definition: Tensor.cpp:418

◆ GetImportFlags()

virtual MemorySourceFlags GetImportFlags ( ) const
inlineoverridevirtual

Get flags describing supported import sources.

Reimplemented from ITensorHandle.

Definition at line 54 of file RefTensorHandle.hpp.

References RefTensorHandle::Import(), and RefTensorHandle::RefTensorHandle().

55  {
56  return m_ImportFlags;
57  }

◆ GetParent()

virtual ITensorHandle* GetParent ( ) const
inlineoverridevirtual

Get the parent tensor if this is a subtensor.

Returns
a pointer to the parent tensor. Otherwise nullptr if not a subtensor.

Implements ITensorHandle.

Definition at line 28 of file RefTensorHandle.hpp.

References RefTensorHandle::Map(), and ITensorHandle::Map().

29  {
30  return nullptr;
31  }

◆ GetShape()

TensorShape GetShape ( ) const
inlineoverridevirtual

Get the number of elements for each dimension ordered from slowest iterating dimension to fastest iterating dimension.

Returns
a TensorShape filled with the number of elements for each dimension.

Implements ITensorHandle.

Definition at line 44 of file RefTensorHandle.hpp.

References TensorInfo::GetShape().

45  {
46  return m_TensorInfo.GetShape();
47  }
const TensorShape & GetShape() const
Definition: Tensor.hpp:187

◆ GetStrides()

TensorShape GetStrides ( ) const
inlineoverridevirtual

Get the strides for each dimension ordered from largest to smallest where the smallest value is the same as the size of a single element in the tensor.

Returns
a TensorShape filled with the strides for each dimension

Implements ITensorHandle.

Definition at line 39 of file RefTensorHandle.hpp.

References armnn::GetUnpaddedTensorStrides().

40  {
41  return GetUnpaddedTensorStrides(m_TensorInfo);
42  }
TensorShape GetUnpaddedTensorStrides(const TensorInfo &tensorInfo)

◆ GetTensorInfo()

const TensorInfo& GetTensorInfo ( ) const
inline

Definition at line 49 of file RefTensorHandle.hpp.

Referenced by armnn::GetTensorInfo().

50  {
51  return m_TensorInfo;
52  }

◆ Import()

bool Import ( void *  memory,
MemorySource  source 
)
overridevirtual

Import externally allocated memory.

Parameters
memorybase address of the memory being imported.
sourcesource of the allocation for the memory being imported.
Returns
true on success or false on failure

Reimplemented from ITensorHandle.

Definition at line 118 of file RefTensorHandle.cpp.

References armnn::Malloc.

Referenced by RefTensorHandle::GetImportFlags().

119 {
120  if (m_ImportFlags & static_cast<MemorySourceFlags>(source))
121  {
122  if (m_IsImportEnabled && source == MemorySource::Malloc)
123  {
124  // Check memory alignment
125  constexpr uintptr_t alignment = sizeof(size_t);
126  if (reinterpret_cast<uintptr_t>(memory) % alignment)
127  {
128  if (m_Imported)
129  {
130  m_Imported = false;
131  m_UnmanagedMemory = nullptr;
132  }
133 
134  return false;
135  }
136 
137  // m_UnmanagedMemory not yet allocated.
138  if (!m_Imported && !m_UnmanagedMemory)
139  {
140  m_UnmanagedMemory = memory;
141  m_Imported = true;
142  return true;
143  }
144 
145  // m_UnmanagedMemory initially allocated with Allocate().
146  if (!m_Imported && m_UnmanagedMemory)
147  {
148  return false;
149  }
150 
151  // m_UnmanagedMemory previously imported.
152  if (m_Imported)
153  {
154  m_UnmanagedMemory = memory;
155  return true;
156  }
157  }
158  }
159 
160  return false;
161 }

◆ Manage()

void Manage ( )
overridevirtual

Indicate to the memory manager that this resource is active.

This is used to compute overlapping lifetimes of resources.

Implements ITensorHandle.

Definition at line 46 of file RefTensorHandle.cpp.

References ARMNN_ASSERT_MSG, and TensorInfo::GetNumBytes().

47 {
48  if (!m_IsImportEnabled)
49  {
50  ARMNN_ASSERT_MSG(!m_Pool, "RefTensorHandle::Manage() called twice");
51  ARMNN_ASSERT_MSG(!m_UnmanagedMemory, "RefTensorHandle::Manage() called after Allocate()");
52 
53  m_Pool = m_MemoryManager->Manage(m_TensorInfo.GetNumBytes());
54  }
55 }
unsigned int GetNumBytes() const
Definition: Tensor.cpp:418
#define ARMNN_ASSERT_MSG(COND, MSG)
Definition: Assert.hpp:15

◆ Map()

const void * Map ( bool  blocking) const
overridevirtual

Map the tensor data for access.

Parameters
blockinghint to block the calling thread until all other accesses are complete. (backend dependent)
Returns
pointer to the first element of the mapped data.

Implements ITensorHandle.

Definition at line 83 of file RefTensorHandle.cpp.

References ARMNN_ASSERT, and TensorInfo::GetNumBytes().

Referenced by RefTensorHandle::GetParent().

84 {
85  return GetPointer();
86 }

◆ Unmap()

virtual void Unmap ( ) const
inlineoverridevirtual

Unmap the tensor data.

Implements ITensorHandle.

Definition at line 36 of file RefTensorHandle.hpp.

37  {}

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