blob: 1d482974e1bc67633682cc4e00f9b11bb13624f6 [file] [log] [blame]
arovir014424b0a2018-10-04 10:46:04 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "NeonBackend.hpp"
David Beck3e9e1152018-10-17 14:17:50 +01007#include "NeonBackendId.hpp"
arovir01a0944792018-10-11 15:00:58 +01008#include "NeonWorkloadFactory.hpp"
David Beck111b5d92018-11-12 14:59:37 +00009#include "NeonLayerSupport.hpp"
Narumol Prangnawarat4e3e8182019-08-14 12:25:50 +010010#include "NeonTensorHandleFactory.hpp"
arovir01a0944792018-10-11 15:00:58 +010011
Matteo Martincighc601aa62019-10-29 15:03:22 +000012#include <armnn/BackendRegistry.hpp>
13
Aron Virginas-Tar56055192018-11-12 18:10:43 +000014#include <aclCommon/BaseMemoryManager.hpp>
15
Matteo Martincighe5b8eb92019-11-28 15:45:42 +000016#include <armnn/backends/IBackendContext.hpp>
17#include <armnn/backends/IMemoryManager.hpp>
Aron Virginas-Tar56055192018-11-12 18:10:43 +000018
David Beck263e3492018-11-09 14:46:40 +000019#include <Optimizer.hpp>
arovir01a0944792018-10-11 15:00:58 +010020
Aron Virginas-Tar56055192018-11-12 18:10:43 +000021#include <arm_compute/runtime/Allocator.h>
22
David Beck9efb57d2018-11-05 13:40:33 +000023#include <boost/cast.hpp>
Aron Virginas-Tar56055192018-11-12 18:10:43 +000024#include <boost/polymorphic_pointer_cast.hpp>
David Beck9efb57d2018-11-05 13:40:33 +000025
arovir014424b0a2018-10-04 10:46:04 +010026namespace armnn
27{
28
David Beck3cc9a622018-10-12 10:38:31 +010029const BackendId& NeonBackend::GetIdStatic()
arovir014424b0a2018-10-04 10:46:04 +010030{
David Beck3e9e1152018-10-17 14:17:50 +010031 static const BackendId s_Id{NeonBackendId()};
arovir014424b0a2018-10-04 10:46:04 +010032 return s_Id;
33}
34
Aron Virginas-Tar56055192018-11-12 18:10:43 +000035IBackendInternal::IMemoryManagerUniquePtr NeonBackend::CreateMemoryManager() const
arovir014424b0a2018-10-04 10:46:04 +010036{
Aron Virginas-Tar56055192018-11-12 18:10:43 +000037 return std::make_unique<NeonMemoryManager>(std::make_unique<arm_compute::Allocator>(),
Sadik Armagan13a9fa62019-04-26 16:04:34 +010038 BaseMemoryManager::MemoryAffinity::Offset);
Aron Virginas-Tar56055192018-11-12 18:10:43 +000039}
40
41IBackendInternal::IWorkloadFactoryPtr NeonBackend::CreateWorkloadFactory(
42 const IBackendInternal::IMemoryManagerSharedPtr& memoryManager) const
43{
44 return std::make_unique<NeonWorkloadFactory>(
45 boost::polymorphic_pointer_downcast<NeonMemoryManager>(memoryManager));
arovir014424b0a2018-10-04 10:46:04 +010046}
47
Narumol Prangnawarat4e3e8182019-08-14 12:25:50 +010048IBackendInternal::IWorkloadFactoryPtr NeonBackend::CreateWorkloadFactory(
49 class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry) const
50{
51 auto memoryManager = std::make_shared<NeonMemoryManager>(std::make_unique<arm_compute::Allocator>(),
52 BaseMemoryManager::MemoryAffinity::Offset);
53
54 tensorHandleFactoryRegistry.RegisterMemoryManager(memoryManager);
55 return std::make_unique<NeonWorkloadFactory>(
56 boost::polymorphic_pointer_downcast<NeonMemoryManager>(memoryManager));
57}
58
David Beck263e3492018-11-09 14:46:40 +000059IBackendInternal::IBackendContextPtr NeonBackend::CreateBackendContext(const IRuntime::CreationOptions&) const
60{
61 return IBackendContextPtr{};
62}
63
Colm Donelane49755b2020-01-29 15:22:43 +000064IBackendInternal::IBackendProfilingContextPtr NeonBackend::CreateBackendProfilingContext(
65 const IRuntime::CreationOptions&,
66 armnn::profiling::IBackendProfiling&) const
67{
68 return IBackendProfilingContextPtr{};
69}
70
David Beck263e3492018-11-09 14:46:40 +000071IBackendInternal::Optimizations NeonBackend::GetOptimizations() const
72{
73 return Optimizations{};
74}
75
David Beck111b5d92018-11-12 14:59:37 +000076IBackendInternal::ILayerSupportSharedPtr NeonBackend::GetLayerSupport() const
77{
78 static ILayerSupportSharedPtr layerSupport{new NeonLayerSupport};
79 return layerSupport;
80}
81
Matteo Martincighc3ba50e2019-05-22 14:28:16 +010082OptimizationViews NeonBackend::OptimizeSubgraphView(const SubgraphView& subgraph) const
Matteo Martincighadddddb2019-01-24 14:06:23 +000083{
Matteo Martincighc3ba50e2019-05-22 14:28:16 +010084 OptimizationViews optimizationViews;
Matteo Martincighadddddb2019-01-24 14:06:23 +000085
Matteo Martincighc3ba50e2019-05-22 14:28:16 +010086 optimizationViews.AddUntouchedSubgraph(SubgraphView(subgraph));
87
88 return optimizationViews;
Matteo Martincighadddddb2019-01-24 14:06:23 +000089}
90
Narumol Prangnawarat4e3e8182019-08-14 12:25:50 +010091std::vector<ITensorHandleFactory::FactoryId> NeonBackend::GetHandleFactoryPreferences() const
92{
Jan Eilers146b2e12019-08-16 10:45:30 +010093 return std::vector<ITensorHandleFactory::FactoryId>() = {"Arm/Neon/TensorHandleFactory",
94 "Arm/Cl/TensorHandleFactory"};
Narumol Prangnawarat4e3e8182019-08-14 12:25:50 +010095}
96
97void NeonBackend::RegisterTensorHandleFactories(class TensorHandleFactoryRegistry& registry)
98{
99 auto memoryManager = std::make_shared<NeonMemoryManager>(std::make_unique<arm_compute::Allocator>(),
100 BaseMemoryManager::MemoryAffinity::Offset);
101
102 registry.RegisterMemoryManager(memoryManager);
Jan Eilerse9f0f0f2019-08-16 10:28:37 +0100103 registry.RegisterFactory(std::make_unique<NeonTensorHandleFactory>(memoryManager));
Narumol Prangnawarat4e3e8182019-08-14 12:25:50 +0100104}
105
Matthew Bentham42bad952018-12-17 09:23:36 +0000106} // namespace armnn