blob: db03cfeff0cbeef5285a6b58b0a9018fa5afe663 [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#pragma once
6
Matteo Martincighe5b8eb92019-11-28 15:45:42 +00007#include <armnn/backends/IBackendInternal.hpp>
arovir014424b0a2018-10-04 10:46:04 +01008
9namespace armnn
10{
11
Finn Williamsb9af86e2021-05-26 18:38:12 +010012// add new capabilities here..
13const BackendCapabilities gpuAccCapabilities("GpuAcc",
14 {
15 {"NonConstWeights", false},
16 {"AsyncExecution", false}
17 });
Sadik Armaganaede8ca2021-03-31 16:12:13 +010018
arovir014424b0a2018-10-04 10:46:04 +010019class ClBackend : public IBackendInternal
20{
21public:
David Beck9efb57d2018-11-05 13:40:33 +000022 ClBackend() = default;
23 ~ClBackend() = default;
arovir014424b0a2018-10-04 10:46:04 +010024
David Beck3cc9a622018-10-12 10:38:31 +010025 static const BackendId& GetIdStatic();
26 const BackendId& GetId() const override { return GetIdStatic(); }
arovir014424b0a2018-10-04 10:46:04 +010027
Aron Virginas-Tar56055192018-11-12 18:10:43 +000028 IBackendInternal::IMemoryManagerUniquePtr CreateMemoryManager() const override;
29
30 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
31 const IBackendInternal::IMemoryManagerSharedPtr& memoryManager = nullptr) const override;
32
Jan Eilerse9f0f0f2019-08-16 10:28:37 +010033 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
34 TensorHandleFactoryRegistry& registry) const override;
35
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010036 IWorkloadFactoryPtr CreateWorkloadFactory(const IMemoryManagerSharedPtr& memoryManager,
37 const ModelOptions& modelOptions) const override;
Sadik Armagan04a72972020-09-14 15:44:18 +010038
39 IWorkloadFactoryPtr CreateWorkloadFactory(class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry,
40 const ModelOptions& modelOptions) const override;
41
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010042 IWorkloadFactoryPtr CreateWorkloadFactory(class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry,
43 const ModelOptions& modelOptions,
44 MemorySourceFlags inputFlags,
45 MemorySourceFlags outputFlags) const override;
46
Jan Eilerse9f0f0f2019-08-16 10:28:37 +010047 std::vector<ITensorHandleFactory::FactoryId> GetHandleFactoryPreferences() const override;
48
49 void RegisterTensorHandleFactories(TensorHandleFactoryRegistry& registry) override;
50
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010051 void RegisterTensorHandleFactories(TensorHandleFactoryRegistry& registry,
52 MemorySourceFlags inputFlags,
53 MemorySourceFlags outputFlags) override;
54
David Beck1b61be52018-11-08 09:19:14 +000055 IBackendInternal::IBackendContextPtr CreateBackendContext(const IRuntime::CreationOptions&) const override;
Colm Donelan1aff3932020-02-05 17:48:59 +000056 IBackendInternal::IBackendProfilingContextPtr CreateBackendProfilingContext(
57 const IRuntime::CreationOptions&, IBackendProfilingPtr& backendProfiling) override;
Aron Virginas-Tar56055192018-11-12 18:10:43 +000058
David Beck263e3492018-11-09 14:46:40 +000059 IBackendInternal::Optimizations GetOptimizations() const override;
David Beck111b5d92018-11-12 14:59:37 +000060 IBackendInternal::ILayerSupportSharedPtr GetLayerSupport() const override;
Sadik Armagan045f6be2020-09-10 13:37:32 +010061 IBackendInternal::ILayerSupportSharedPtr GetLayerSupport(const ModelOptions& modelOptions) const override;
Matteo Martincighadddddb2019-01-24 14:06:23 +000062
Mike Kelly07810fc2020-11-12 10:58:48 +000063 OptimizationViews OptimizeSubgraphView(const SubgraphView& subgraph,
64 const ModelOptions& modelOptions) const override;
Sadik Armagan045f6be2020-09-10 13:37:32 +010065
66 IBackendInternal::IBackendSpecificModelContextPtr CreateBackendSpecificModelContext(
67 const ModelOptions& modelOptions) const override;
Sadik Armaganaede8ca2021-03-31 16:12:13 +010068
Finn Williamsb9af86e2021-05-26 18:38:12 +010069 BackendCapabilities GetCapabilities() const override
70 {
71 return gpuAccCapabilities;
72 };
arovir014424b0a2018-10-04 10:46:04 +010073};
74
Matteo Martincighadddddb2019-01-24 14:06:23 +000075} // namespace armnn