diff options
author | Matthew Bentham <Matthew.Bentham@arm.com> | 2019-06-21 17:22:23 +0100 |
---|---|---|
committer | Matthew Bentham <matthew.bentham@arm.com> | 2019-07-04 09:10:46 +0000 |
commit | 7c1603a4e310c5b7b0d3bdddc0c80a63a7661107 (patch) | |
tree | 9be52766d80394d253b2b51f4ef8fd136272cf6e /src/backends/reference/RefTensorHandle.hpp | |
parent | f9ac3fd5676565b1065698158f8d54a27f24981c (diff) | |
download | armnn-7c1603a4e310c5b7b0d3bdddc0c80a63a7661107.tar.gz |
IVGCVSW-3307 Add RefMemoryManager
Simple pool memory manager for use in the reference backend,
in order to make the backend usable for testing large networks.
Change-Id: I5694da29052c60f95b57da595c64cc114d75b8ba
Signed-off-by: Matthew Bentham <Matthew.Bentham@arm.com>
Diffstat (limited to 'src/backends/reference/RefTensorHandle.hpp')
-rw-r--r-- | src/backends/reference/RefTensorHandle.hpp | 29 |
1 files changed, 16 insertions, 13 deletions
diff --git a/src/backends/reference/RefTensorHandle.hpp b/src/backends/reference/RefTensorHandle.hpp index 66d840ab35..ad47ee597f 100644 --- a/src/backends/reference/RefTensorHandle.hpp +++ b/src/backends/reference/RefTensorHandle.hpp @@ -6,6 +6,8 @@ #include <backendsCommon/CpuTensorHandle.hpp> +#include "RefMemoryManager.hpp" + namespace armnn { @@ -13,28 +15,25 @@ namespace armnn class RefTensorHandle : public ITensorHandle { public: - RefTensorHandle(const TensorInfo& tensorInfo); + RefTensorHandle(const TensorInfo& tensorInfo, std::shared_ptr<RefMemoryManager> &memoryManager); ~RefTensorHandle(); - virtual void Manage() override - {} + virtual void Manage() override; + + virtual void Allocate() override; virtual ITensorHandle* GetParent() const override { return nullptr; } - virtual const void* Map(bool /* blocking = true */) const override - { - return m_Memory; - } + virtual const void* Map(bool /* blocking = true */) const override; + using ITensorHandle::Map; virtual void Unmap() const override {} - virtual void Allocate() override; - TensorShape GetStrides() const override { return GetUnpaddedTensorStrides(m_TensorInfo); @@ -55,12 +54,16 @@ private: void CopyOutTo(void*) const override; void CopyInFrom(const void*) override; - RefTensorHandle(const RefTensorHandle& other) = delete; + void* GetPointer() const; - RefTensorHandle& operator=(const RefTensorHandle& other) = delete; + RefTensorHandle(const RefTensorHandle& other) = delete; // noncopyable + RefTensorHandle& operator=(const RefTensorHandle& other) = delete; //noncopyable TensorInfo m_TensorInfo; - void* m_Memory; + + std::shared_ptr<RefMemoryManager> m_MemoryManager; + RefMemoryManager::Pool* m_Pool; + mutable void *m_UnmanagedMemory; }; -}
\ No newline at end of file +} |