From 7997a3527218ed821ec933ef3a5e6a3f07409b21 Mon Sep 17 00:00:00 2001 From: Matteo Martincigh Date: Wed, 17 Apr 2019 15:37:30 +0100 Subject: [PATCH] IVGCVSW-2980 Build ArmNN with the latest version of the driver stack library * Changed the pre-compiled object held by the pre-compiled layer into a unique pointer, so that now the layer has the ownership of it * Changed the pre-compiled object held by the descriptor and the workload into a naked pointer, to leave the ownership to the layer Change-Id: I4a582e45ca0aa3978e8e40b786c743a6eddce852 Signed-off-by: Matteo Martincigh --- src/armnn/ISubGraphConverter.hpp | 12 ++++++++---- src/armnn/layers/PreCompiledLayer.cpp | 14 ++++---------- src/armnn/layers/PreCompiledLayer.hpp | 10 ++++++---- src/backends/backendsCommon/WorkloadData.hpp | 2 +- 4 files changed, 19 insertions(+), 19 deletions(-) diff --git a/src/armnn/ISubGraphConverter.hpp b/src/armnn/ISubGraphConverter.hpp index 1d40c67..3a6866e 100644 --- a/src/armnn/ISubGraphConverter.hpp +++ b/src/armnn/ISubGraphConverter.hpp @@ -6,17 +6,21 @@ #pragma once #include +#include +#include namespace armnn { +using CompiledBlobDeleter = std::function; +using CompiledBlobPtr = std::unique_ptr; + class ISubGraphConverter { public: - virtual ~ISubGraphConverter() {}; + virtual ~ISubGraphConverter() {} - virtual std::shared_ptr GetOutput() = 0; + virtual std::vector GetOutput() = 0; }; -} - +} // namespace armnn diff --git a/src/armnn/layers/PreCompiledLayer.cpp b/src/armnn/layers/PreCompiledLayer.cpp index 1106421..29b3514 100644 --- a/src/armnn/layers/PreCompiledLayer.cpp +++ b/src/armnn/layers/PreCompiledLayer.cpp @@ -16,7 +16,6 @@ namespace armnn PreCompiledLayer::PreCompiledLayer(const PreCompiledDescriptor& param, const char* name) : LayerWithParameters(param.m_NumInputSlots, param.m_NumOutputSlots, LayerType::PreCompiled, param, name) - , m_PreCompiledObject(nullptr) {} PreCompiledLayer::~PreCompiledLayer() @@ -25,7 +24,7 @@ PreCompiledLayer::~PreCompiledLayer() PreCompiledLayer* PreCompiledLayer::Clone(Graph& graph) const { PreCompiledLayer* clone = CloneBase(graph, m_Param, GetName()); - clone->m_PreCompiledObject = this->m_PreCompiledObject; + clone->m_PreCompiledObject.reset(const_cast(this)->m_PreCompiledObject.release()); return clone; } @@ -33,7 +32,7 @@ std::unique_ptr PreCompiledLayer::CreateWorkload(const armnn::Graph& const armnn::IWorkloadFactory& factory) const { PreCompiledQueueDescriptor descriptor; - descriptor.m_PreCompiledObject = m_PreCompiledObject; + descriptor.m_PreCompiledObject = m_PreCompiledObject.get(); return factory.CreatePreCompiled(descriptor, PrepInfoAndDesc(descriptor, graph)); } @@ -43,14 +42,9 @@ void PreCompiledLayer::ValidateTensorShapesFromInputs() // we do not need to validate its input shapes } -std::shared_ptr PreCompiledLayer::GetPreCompiledObject() const +void PreCompiledLayer::SetPreCompiledObject(PreCompiledObjectPtr preCompiledObject) { - return m_PreCompiledObject; -} - -void PreCompiledLayer::SetPreCompiledObject(const std::shared_ptr& preCompiledObject) -{ - m_PreCompiledObject = preCompiledObject; + m_PreCompiledObject = std::move(preCompiledObject); } void PreCompiledLayer::Accept(ILayerVisitor& visitor) const diff --git a/src/armnn/layers/PreCompiledLayer.hpp b/src/armnn/layers/PreCompiledLayer.hpp index 854a78c..ec5a9d6 100644 --- a/src/armnn/layers/PreCompiledLayer.hpp +++ b/src/armnn/layers/PreCompiledLayer.hpp @@ -11,10 +11,14 @@ #include #include +#include namespace armnn { +using PreCompiledObjectDeleter = std::function; +using PreCompiledObjectPtr = std::unique_ptr; + class PreCompiledLayer : public LayerWithParameters { public: @@ -28,9 +32,7 @@ public: void ValidateTensorShapesFromInputs() override; - std::shared_ptr GetPreCompiledObject() const; - - void SetPreCompiledObject(const std::shared_ptr& preCompiledObject); + void SetPreCompiledObject(PreCompiledObjectPtr preCompiledObject); void Accept(ILayerVisitor& visitor) const override; @@ -38,7 +40,7 @@ private: PreCompiledLayer(const PreCompiledLayer& other) = delete; PreCompiledLayer& operator=(const PreCompiledLayer& other) = delete; - std::shared_ptr m_PreCompiledObject; + PreCompiledObjectPtr m_PreCompiledObject; }; } // namespace armnn diff --git a/src/backends/backendsCommon/WorkloadData.hpp b/src/backends/backendsCommon/WorkloadData.hpp index 1b5f86d..689c6d2 100644 --- a/src/backends/backendsCommon/WorkloadData.hpp +++ b/src/backends/backendsCommon/WorkloadData.hpp @@ -411,7 +411,7 @@ struct PreCompiledQueueDescriptor : QueueDescriptorWithParameters m_PreCompiledObject; + void* m_PreCompiledObject; void Validate(const WorkloadInfo& workloadInfo) const; }; -- 2.7.4