diff options
Diffstat (limited to 'src/backends')
-rw-r--r-- | src/backends/backendsCommon/test/CompatibilityTests.cpp | 2 | ||||
-rw-r--r-- | src/backends/cl/ClBackend.cpp | 10 | ||||
-rw-r--r-- | src/backends/cl/ClBackend.hpp | 6 | ||||
-rw-r--r-- | src/backends/neon/NeonBackend.cpp | 10 | ||||
-rw-r--r-- | src/backends/neon/NeonBackend.hpp | 6 | ||||
-rw-r--r-- | src/backends/reference/RefBackend.cpp | 4 | ||||
-rw-r--r-- | src/backends/reference/RefBackend.hpp | 2 |
7 files changed, 37 insertions, 3 deletions
diff --git a/src/backends/backendsCommon/test/CompatibilityTests.cpp b/src/backends/backendsCommon/test/CompatibilityTests.cpp index 915a0151d9..0f889f416c 100644 --- a/src/backends/backendsCommon/test/CompatibilityTests.cpp +++ b/src/backends/backendsCommon/test/CompatibilityTests.cpp @@ -125,6 +125,8 @@ BOOST_AUTO_TEST_CASE(Ref_Backends_Capability_Test) { auto refBackend = std::make_unique<RefBackend>(); BOOST_CHECK(refBackend->HasCapability(armnn::BackendCapability::NonConstWeights)); + + BOOST_CHECK(!refBackend->HasCapability(armnn::BackendCapability::AsyncExecution)); } #endif diff --git a/src/backends/cl/ClBackend.cpp b/src/backends/cl/ClBackend.cpp index 928760ef5f..33aff2731d 100644 --- a/src/backends/cl/ClBackend.cpp +++ b/src/backends/cl/ClBackend.cpp @@ -141,6 +141,16 @@ IBackendInternal::ILayerSupportSharedPtr ClBackend::GetLayerSupport(const ModelO return layerSupport; } +bool ClBackend::HasCapability(BackendCapability capabilityClass) const +{ + auto search = gpuAccCapabilities.find(capabilityClass); + if (search != gpuAccCapabilities.end()) + { + return true; + } + return false; +} + OptimizationViews ClBackend::OptimizeSubgraphView(const SubgraphView& subgraph, const ModelOptions& modelOptions) const { diff --git a/src/backends/cl/ClBackend.hpp b/src/backends/cl/ClBackend.hpp index 2b19fc5b33..f9a5745eb3 100644 --- a/src/backends/cl/ClBackend.hpp +++ b/src/backends/cl/ClBackend.hpp @@ -9,6 +9,10 @@ namespace armnn { +const std::set<armnn::BackendCapability> gpuAccCapabilities { + // add new capabilities here.. +}; + class ClBackend : public IBackendInternal { public: @@ -49,6 +53,8 @@ public: IBackendInternal::IBackendSpecificModelContextPtr CreateBackendSpecificModelContext( const ModelOptions& modelOptions) const override; + + bool HasCapability(BackendCapability capabilityClass) const override; }; } // namespace armnn diff --git a/src/backends/neon/NeonBackend.cpp b/src/backends/neon/NeonBackend.cpp index d48b32bb45..a1299fb458 100644 --- a/src/backends/neon/NeonBackend.cpp +++ b/src/backends/neon/NeonBackend.cpp @@ -131,6 +131,16 @@ IBackendInternal::ILayerSupportSharedPtr NeonBackend::GetLayerSupport(const Mode return layerSupport; } +bool NeonBackend::HasCapability(BackendCapability capabilityClass) const +{ + auto search = cpuAccCapabilities.find(capabilityClass); + if (search != cpuAccCapabilities.end()) + { + return true; + } + return false; +} + OptimizationViews NeonBackend::OptimizeSubgraphView(const SubgraphView& subgraph) const { OptimizationViews optimizationViews; diff --git a/src/backends/neon/NeonBackend.hpp b/src/backends/neon/NeonBackend.hpp index 42c6666930..34606f992c 100644 --- a/src/backends/neon/NeonBackend.hpp +++ b/src/backends/neon/NeonBackend.hpp @@ -9,6 +9,10 @@ namespace armnn { +const std::set<armnn::BackendCapability> cpuAccCapabilities { + // add new capabilities here.. +}; + class NeonBackend : public IBackendInternal { public: @@ -47,6 +51,8 @@ public: IBackendInternal::IBackendSpecificModelContextPtr CreateBackendSpecificModelContext( const ModelOptions& modelOptions) const override; + + bool HasCapability(BackendCapability capabilityClass) const override; }; } // namespace armnn diff --git a/src/backends/reference/RefBackend.cpp b/src/backends/reference/RefBackend.cpp index 53c55ab26a..85c6a2e1e4 100644 --- a/src/backends/reference/RefBackend.cpp +++ b/src/backends/reference/RefBackend.cpp @@ -71,8 +71,8 @@ IBackendInternal::ILayerSupportSharedPtr RefBackend::GetLayerSupport() const bool RefBackend::HasCapability(BackendCapability capabilityClass) const { - auto search = backendCapabilities.find(capabilityClass); - if (search != backendCapabilities.end()) + auto search = cpuRefCapabilities.find(capabilityClass); + if (search != cpuRefCapabilities.end()) { return true; } diff --git a/src/backends/reference/RefBackend.hpp b/src/backends/reference/RefBackend.hpp index c92936ca0c..3143173061 100644 --- a/src/backends/reference/RefBackend.hpp +++ b/src/backends/reference/RefBackend.hpp @@ -9,7 +9,7 @@ namespace armnn { -const std::set<armnn::BackendCapability> backendCapabilities { +const std::set<armnn::BackendCapability> cpuRefCapabilities { armnn::BackendCapability::NonConstWeights, }; |