diff options
author | Francis Murtagh <francis.murtagh@arm.com> | 2022-08-12 13:54:17 +0100 |
---|---|---|
committer | Nikhil Raj <nikhil.raj@arm.com> | 2022-09-07 14:08:58 +0100 |
commit | 9270d9e52fc1d946cf543c11df71bcc1f7b38544 (patch) | |
tree | 4b763ed4d200f76e170462a1b84a476d1c73a648 /src/backends/tosaReference/TosaRefTensorHandle.hpp | |
parent | ce8204a528b3973b2dbf258095ab048a061263ea (diff) | |
download | armnn-9270d9e52fc1d946cf543c11df71bcc1f7b38544.tar.gz |
IVGCVSW-7159 Implement simple TOSA Reference Backend skeleton
* Added files based on RefBackend
* Added PreCompiled Workload skeleton
* Increment ABI version of armnnTestUtils for CreateInput which had
been left as pure virtual, added base implementation for it.
* Add IsTosaLayerSupported() for Addition
Change-Id: I4c963adf3f50593d17ecdf21554502a64ad3bd76
Diffstat (limited to 'src/backends/tosaReference/TosaRefTensorHandle.hpp')
-rw-r--r-- | src/backends/tosaReference/TosaRefTensorHandle.hpp | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/src/backends/tosaReference/TosaRefTensorHandle.hpp b/src/backends/tosaReference/TosaRefTensorHandle.hpp new file mode 100644 index 0000000000..431d56bd37 --- /dev/null +++ b/src/backends/tosaReference/TosaRefTensorHandle.hpp @@ -0,0 +1,82 @@ +// +// Copyright © 2022 Arm Ltd and Contributors. All rights reserved. +// SPDX-License-Identifier: MIT +// +#pragma once + +#include <armnn/backends/TensorHandle.hpp> + +#include "TosaRefMemoryManager.hpp" + +namespace armnn +{ + +// An implementation of ITensorHandle with simple "bump the pointer" memory-management behaviour +class TosaRefTensorHandle : public ITensorHandle +{ +public: + TosaRefTensorHandle(const TensorInfo& tensorInfo, std::shared_ptr<TosaRefMemoryManager> &memoryManager); + + TosaRefTensorHandle(const TensorInfo& tensorInfo, MemorySourceFlags importFlags); + + ~TosaRefTensorHandle(); + + virtual void Manage() override; + + virtual void Allocate() override; + + virtual ITensorHandle* GetParent() const override + { + return nullptr; + } + + virtual const void* Map(bool /* blocking = true */) const override; + using ITensorHandle::Map; + + virtual void Unmap() const override + {} + + TensorShape GetStrides() const override + { + return GetUnpaddedTensorStrides(m_TensorInfo); + } + + TensorShape GetShape() const override + { + return m_TensorInfo.GetShape(); + } + + const TensorInfo& GetTensorInfo() const + { + return m_TensorInfo; + } + + virtual MemorySourceFlags GetImportFlags() const override + { + return m_ImportFlags; + } + + virtual bool Import(void* memory, MemorySource source) override; + virtual bool CanBeImported(void* memory, MemorySource source) override; + +private: + // Only used for testing + void CopyOutTo(void*) const override; + void CopyInFrom(const void*) override; + + void* GetPointer() const; + + TosaRefTensorHandle(const TosaRefTensorHandle& other) = delete; // noncopyable + TosaRefTensorHandle& operator=(const TosaRefTensorHandle& other) = delete; //noncopyable + + TensorInfo m_TensorInfo; + + std::shared_ptr<TosaRefMemoryManager> m_MemoryManager; + TosaRefMemoryManager::Pool* m_Pool; + mutable void* m_UnmanagedMemory; + MemorySourceFlags m_ImportFlags; + bool m_Imported; + bool m_IsImportEnabled; +}; + +} |