blob: 252d87edea93b189c11ce443bd29ad9e2492d7db [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
Sadik Armaganaede8ca2021-03-31 16:12:13 +010012const std::set<armnn::BackendCapability> gpuAccCapabilities {
13 // add new capabilities here..
14};
15
arovir014424b0a2018-10-04 10:46:04 +010016class ClBackend : public IBackendInternal
17{
18public:
David Beck9efb57d2018-11-05 13:40:33 +000019 ClBackend() = default;
20 ~ClBackend() = default;
arovir014424b0a2018-10-04 10:46:04 +010021
David Beck3cc9a622018-10-12 10:38:31 +010022 static const BackendId& GetIdStatic();
23 const BackendId& GetId() const override { return GetIdStatic(); }
arovir014424b0a2018-10-04 10:46:04 +010024
Aron Virginas-Tar56055192018-11-12 18:10:43 +000025 IBackendInternal::IMemoryManagerUniquePtr CreateMemoryManager() const override;
26
27 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
28 const IBackendInternal::IMemoryManagerSharedPtr& memoryManager = nullptr) const override;
29
Jan Eilerse9f0f0f2019-08-16 10:28:37 +010030 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
31 TensorHandleFactoryRegistry& registry) const override;
32
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010033 IWorkloadFactoryPtr CreateWorkloadFactory(const IMemoryManagerSharedPtr& memoryManager,
34 const ModelOptions& modelOptions) const override;
Sadik Armagan04a72972020-09-14 15:44:18 +010035
36 IWorkloadFactoryPtr CreateWorkloadFactory(class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry,
37 const ModelOptions& modelOptions) const override;
38
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010039 IWorkloadFactoryPtr CreateWorkloadFactory(class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry,
40 const ModelOptions& modelOptions,
41 MemorySourceFlags inputFlags,
42 MemorySourceFlags outputFlags) const override;
43
Jan Eilerse9f0f0f2019-08-16 10:28:37 +010044 std::vector<ITensorHandleFactory::FactoryId> GetHandleFactoryPreferences() const override;
45
46 void RegisterTensorHandleFactories(TensorHandleFactoryRegistry& registry) override;
47
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +010048 void RegisterTensorHandleFactories(TensorHandleFactoryRegistry& registry,
49 MemorySourceFlags inputFlags,
50 MemorySourceFlags outputFlags) override;
51
David Beck1b61be52018-11-08 09:19:14 +000052 IBackendInternal::IBackendContextPtr CreateBackendContext(const IRuntime::CreationOptions&) const override;
Colm Donelan1aff3932020-02-05 17:48:59 +000053 IBackendInternal::IBackendProfilingContextPtr CreateBackendProfilingContext(
54 const IRuntime::CreationOptions&, IBackendProfilingPtr& backendProfiling) override;
Aron Virginas-Tar56055192018-11-12 18:10:43 +000055
David Beck263e3492018-11-09 14:46:40 +000056 IBackendInternal::Optimizations GetOptimizations() const override;
David Beck111b5d92018-11-12 14:59:37 +000057 IBackendInternal::ILayerSupportSharedPtr GetLayerSupport() const override;
Sadik Armagan045f6be2020-09-10 13:37:32 +010058 IBackendInternal::ILayerSupportSharedPtr GetLayerSupport(const ModelOptions& modelOptions) const override;
Matteo Martincighadddddb2019-01-24 14:06:23 +000059
Mike Kelly07810fc2020-11-12 10:58:48 +000060 OptimizationViews OptimizeSubgraphView(const SubgraphView& subgraph,
61 const ModelOptions& modelOptions) const override;
Sadik Armagan045f6be2020-09-10 13:37:32 +010062
63 IBackendInternal::IBackendSpecificModelContextPtr CreateBackendSpecificModelContext(
64 const ModelOptions& modelOptions) const override;
Sadik Armaganaede8ca2021-03-31 16:12:13 +010065
66 bool HasCapability(BackendCapability capabilityClass) const override;
arovir014424b0a2018-10-04 10:46:04 +010067};
68
Matteo Martincighadddddb2019-01-24 14:06:23 +000069} // namespace armnn