aboutsummaryrefslogtreecommitdiff
path: root/src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp
diff options
context:
space:
mode:
authorNarumol Prangnawarat <narumol.prangnawarat@arm.com>2021-12-17 17:27:37 +0000
committerFrancis Murtagh <francis.murtagh@arm.com>2022-01-11 11:59:22 +0000
commitb275da5afe480e994fe6cd897b3090c52f1bcdea (patch)
tree390246b981d5d39f79099b57a56c0f21c2932c05 /src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp
parent2048bcf8ed671b593ac9af2974e10319b9058b20 (diff)
downloadarmnn-b275da5afe480e994fe6cd897b3090c52f1bcdea.tar.gz
IVGCVSW-6675 Add functionality for CopyAndImportFactoryPair
to TensorHandleFactoryRegistry * Add RegisterCopyAndImportFactoryPair * Add GetMatchingImportFactoryId * Unit tests Signed-off-by: Narumol Prangnawarat <narumol.prangnawarat@arm.com> Change-Id: I91e71bdeadec8fedbce7088016c06a47a03bdbaa
Diffstat (limited to 'src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp')
-rw-r--r--src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp b/src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp
index 525db56216..2a7c6f36d9 100644
--- a/src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp
+++ b/src/backends/backendsCommon/TensorHandleFactoryRegistry.hpp
@@ -16,6 +16,8 @@ namespace armnn
//Forward
class IMemoryManager;
+using CopyAndImportFactoryPairs = std::map<ITensorHandleFactory::FactoryId, ITensorHandleFactory::FactoryId>;
+
///
class TensorHandleFactoryRegistry
{
@@ -39,6 +41,13 @@ public:
ITensorHandleFactory* GetFactory(ITensorHandleFactory::FactoryId id,
MemorySource memSource) const;
+ /// Register a pair of TensorHandleFactory Id for Memory Copy and TensorHandleFactory Id for Memory Import
+ void RegisterCopyAndImportFactoryPair(ITensorHandleFactory::FactoryId copyFactoryId,
+ ITensorHandleFactory::FactoryId importFactoryId);
+
+ /// Get a matching TensorHandleFatory Id for Memory Import given TensorHandleFactory Id for Memory Copy
+ ITensorHandleFactory::FactoryId GetMatchingImportFactoryId(ITensorHandleFactory::FactoryId copyFactoryId);
+
/// Aquire memory required for inference
void AquireMemory();
@@ -53,6 +62,7 @@ public:
private:
std::vector<std::unique_ptr<ITensorHandleFactory>> m_Factories;
std::vector<std::shared_ptr<IMemoryManager>> m_MemoryManagers;
+ CopyAndImportFactoryPairs m_FactoryMappings;
};
} // namespace armnn