blob: da04f22d93500035403d78776b8b936d9eb5d60e [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{
Finn Williamsb9af86e2021-05-26 18:38:12 +010011// add new capabilities here..
12const BackendCapabilities cpuRefCapabilities("CpuRef",
13 {
14 {"NonConstWeights", true},
Matthew Sloyan81beae32021-07-13 19:46:11 +010015 {"AsyncExecution", true},
Finn Williamsdbf5f312021-08-26 11:08:01 +010016 {"ProtectedContentAllocation", false},
17 {"ConstantTensorsAsInputs", true},
Finn Williams8636bc72021-10-02 15:06:39 +010018 {"PreImportIOTensors", true},
Finn Williamsb1aad422021-10-28 19:07:32 +010019 {"ExternallyManagedMemory", true},
Sadik Armaganb8a26d82021-10-04 15:13:11 +010020 {"MultiAxisPacking", false},
21 {"SingleAxisPacking", true}
Finn Williamsb9af86e2021-05-26 18:38:12 +010022 });
arovir014424b0a2018-10-04 10:46:04 +010023
Finn Williamsb9af86e2021-05-26 18:38:12 +010024const std::set<armnn::BackendCapability> oldCpuRefCapabilities {
25 armnn::BackendCapability::NonConstWeights,
Sadik Armaganf0a6dec2021-03-25 07:46:55 +000026};
27
Finn Williamsb9af86e2021-05-26 18:38:12 +010028
arovir014424b0a2018-10-04 10:46:04 +010029class RefBackend : public IBackendInternal
30{
31public:
David Beck9efb57d2018-11-05 13:40:33 +000032 RefBackend() = default;
33 ~RefBackend() = default;
arovir014424b0a2018-10-04 10:46:04 +010034
David Beck3cc9a622018-10-12 10:38:31 +010035 static const BackendId& GetIdStatic();
36 const BackendId& GetId() const override { return GetIdStatic(); }
arovir014424b0a2018-10-04 10:46:04 +010037
Aron Virginas-Tar56055192018-11-12 18:10:43 +000038 IBackendInternal::IMemoryManagerUniquePtr CreateMemoryManager() const override;
39
40 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
41 const IBackendInternal::IMemoryManagerSharedPtr& memoryManager = nullptr) const override;
42
Ferran Balaguerbfeb2712019-08-07 15:14:56 +010043 IBackendInternal::IWorkloadFactoryPtr CreateWorkloadFactory(
44 class TensorHandleFactoryRegistry& tensorHandleFactoryRegistry) const override;
45
David Beck263e3492018-11-09 14:46:40 +000046 IBackendInternal::IBackendContextPtr CreateBackendContext(const IRuntime::CreationOptions&) const override;
Aron Virginas-Tar56055192018-11-12 18:10:43 +000047
Colm Donelane49755b2020-01-29 15:22:43 +000048 IBackendInternal::IBackendProfilingContextPtr CreateBackendProfilingContext(
Colm Donelan1aff3932020-02-05 17:48:59 +000049 const IRuntime::CreationOptions& creationOptions, IBackendProfilingPtr& backendProfiling) override;
Colm Donelane49755b2020-01-29 15:22:43 +000050
David Beck111b5d92018-11-12 14:59:37 +000051 IBackendInternal::ILayerSupportSharedPtr GetLayerSupport() const override;
Matteo Martincighadddddb2019-01-24 14:06:23 +000052
Matteo Martincighc3ba50e2019-05-22 14:28:16 +010053 OptimizationViews OptimizeSubgraphView(const SubgraphView& subgraph) const override;
Ferran Balaguerbfeb2712019-08-07 15:14:56 +010054
55 std::vector<ITensorHandleFactory::FactoryId> GetHandleFactoryPreferences() const override;
56
57 void RegisterTensorHandleFactories(class TensorHandleFactoryRegistry& registry) override;
Sadik Armaganf0a6dec2021-03-25 07:46:55 +000058
Finn Williamsb9af86e2021-05-26 18:38:12 +010059 BackendCapabilities GetCapabilities() const override
60 {
61 return cpuRefCapabilities;
62 };
Francis Murtaghe8d7ccb2021-10-14 17:30:24 +010063
64 std::unique_ptr<ICustomAllocator> GetDefaultAllocator() const override;
arovir014424b0a2018-10-04 10:46:04 +010065};
66
Matteo Martincighadddddb2019-01-24 14:06:23 +000067} // namespace armnn