From 6b779f0e437127bfa71a529e9b848b5e41683ab8 Mon Sep 17 00:00:00 2001 From: David Beck Date: Tue, 9 Oct 2018 17:20:21 +0100 Subject: IVGCVSW-1989 : implement backend creation and registry for Ref,Cl and Neon !armnn:152557 Change-Id: Ic6b99cddee1597c85de76034d9332fe1bf3aceb1 --- src/backends/neon/NeonBackend.cpp | 23 +++++++++++++++++++++-- src/backends/neon/NeonBackend.hpp | 8 +++----- 2 files changed, 24 insertions(+), 7 deletions(-) (limited to 'src/backends/neon') diff --git a/src/backends/neon/NeonBackend.cpp b/src/backends/neon/NeonBackend.cpp index 1137145aa2..b4f1897704 100644 --- a/src/backends/neon/NeonBackend.cpp +++ b/src/backends/neon/NeonBackend.cpp @@ -4,11 +4,26 @@ // #include "NeonBackend.hpp" +#include +#include namespace armnn { -const std::string NeonBackend::s_Id = "arm_compute_neon"; +namespace +{ + +static const std::string s_Id = "CpuAcc"; + +static BackendRegistry::Helper g_RegisterHelper{ + s_Id, + []() + { + return IBackendUniquePtr(new NeonBackend, &NeonBackend::Destroy); + } +}; + +} const std::string& NeonBackend::GetId() const { @@ -22,8 +37,12 @@ const ILayerSupport& NeonBackend::GetLayerSupport() const std::unique_ptr NeonBackend::CreateWorkloadFactory() const { - // TODO implement return nullptr; } +void NeonBackend::Destroy(IBackend* backend) +{ + delete boost::polymorphic_downcast(backend); +} + } // namespace armnn \ No newline at end of file diff --git a/src/backends/neon/NeonBackend.hpp b/src/backends/neon/NeonBackend.hpp index 86fccf0e51..5d4bd5dfcc 100644 --- a/src/backends/neon/NeonBackend.hpp +++ b/src/backends/neon/NeonBackend.hpp @@ -4,8 +4,7 @@ // #pragma once -#include "backends/IBackendInternal.hpp" - +#include #include "NeonLayerSupport.hpp" namespace armnn @@ -23,10 +22,9 @@ public: std::unique_ptr CreateWorkloadFactory() const override; -private: - static const std::string s_Id; + static void Destroy(IBackend* backend); - // TODO initialize +private: NeonLayerSupport m_LayerSupport; }; -- cgit v1.2.1