diff options
Diffstat (limited to 'src/armnn')
-rw-r--r-- | src/armnn/ExecutionFrame.cpp | 49 | ||||
-rw-r--r-- | src/armnn/ExecutionFrame.hpp | 42 | ||||
-rw-r--r-- | src/armnn/test/ExecutionFrameTest.cpp | 38 |
3 files changed, 129 insertions, 0 deletions
diff --git a/src/armnn/ExecutionFrame.cpp b/src/armnn/ExecutionFrame.cpp new file mode 100644 index 0000000000..4d952b22d9 --- /dev/null +++ b/src/armnn/ExecutionFrame.cpp @@ -0,0 +1,49 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "ExecutionFrame.hpp" + +using namespace std; + +namespace armnn +{ +ExecutionFrame::ExecutionFrame() {} + +IExecutionFrame* ExecutionFrame::ExecuteWorkloads(IExecutionFrame* previousFrame) +{ + for (auto& workload: m_WorkloadQueue) + { + workload->Execute(); + } + return m_NextExecutionFrame; +} + +void ExecutionFrame::PostAllocationConfigure() +{ + for (auto&& workloadPtr: m_WorkloadQueue) + { + workloadPtr.get()->PostAllocationConfigure(); + } +} + +void ExecutionFrame::RegisterDebugCallback(const DebugCallbackFunction& func) +{ + for (auto&& workloadPtr: m_WorkloadQueue) + { + workloadPtr.get()->RegisterDebugCallback(func); + } +} + +void ExecutionFrame::AddWorkloadToQueue(std::unique_ptr<IWorkload> workload) +{ + m_WorkloadQueue.push_back(move(workload)); +} + +void ExecutionFrame::SetNextExecutionFrame(IExecutionFrame* nextExecutionFrame) +{ + m_NextExecutionFrame = nextExecutionFrame; +} + +}
\ No newline at end of file diff --git a/src/armnn/ExecutionFrame.hpp b/src/armnn/ExecutionFrame.hpp new file mode 100644 index 0000000000..c7e7780235 --- /dev/null +++ b/src/armnn/ExecutionFrame.hpp @@ -0,0 +1,42 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#pragma once + +#include <backendsCommon/Workload.hpp> + +namespace armnn +{ + +using WorkloadQueue = std::vector< std::unique_ptr<IWorkload> >; + +/// ExecutionFrame interface to enqueue a workload computation. +class IExecutionFrame +{ + +public: + ~IExecutionFrame() {} + + virtual IExecutionFrame* ExecuteWorkloads(IExecutionFrame* previousFrame) = 0; + virtual void PostAllocationConfigure() {}; + virtual void RegisterDebugCallback(const DebugCallbackFunction& func) {}; +}; + +class ExecutionFrame: public IExecutionFrame +{ +public: + ExecutionFrame(); + + IExecutionFrame* ExecuteWorkloads(IExecutionFrame* previousFrame) override ; + void PostAllocationConfigure() override; + void RegisterDebugCallback(const DebugCallbackFunction& func) override ; + void AddWorkloadToQueue(std::unique_ptr<IWorkload> workload); + void SetNextExecutionFrame(IExecutionFrame* nextExecutionFrame); +private: + WorkloadQueue m_WorkloadQueue; + IExecutionFrame* m_NextExecutionFrame = nullptr; +}; + +}
\ No newline at end of file diff --git a/src/armnn/test/ExecutionFrameTest.cpp b/src/armnn/test/ExecutionFrameTest.cpp new file mode 100644 index 0000000000..c3480217a8 --- /dev/null +++ b/src/armnn/test/ExecutionFrameTest.cpp @@ -0,0 +1,38 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include <boost/test/unit_test.hpp> + +#include <ExecutionFrame.hpp> + +// Test that the values set in m_NextExecutionFrame are correct. +// The execution order is given by the m_NextExecutionFrame in each ExecutionFrame. +// A +// | +// B +// | +// C +BOOST_AUTO_TEST_CASE(NextExecutionFrameTest) +{ + armnn::ExecutionFrame executionFrameA; + armnn::ExecutionFrame executionFrameB; + armnn::ExecutionFrame executionFrameC; + + executionFrameA.SetNextExecutionFrame(&executionFrameB); + executionFrameB.SetNextExecutionFrame(&executionFrameC); + //not setting C to check that the default setting is nullptr. + + auto nextExecutionFrameA = executionFrameA.ExecuteWorkloads(nullptr); + auto nextExecutionFrameB = executionFrameB.ExecuteWorkloads(&executionFrameA); + auto nextExecutionFrameC = executionFrameC.ExecuteWorkloads(&executionFrameB); + + BOOST_CHECK_EQUAL(nextExecutionFrameA, &executionFrameB); + BOOST_CHECK_EQUAL(nextExecutionFrameB, &executionFrameC); + + BOOST_CHECK(!nextExecutionFrameC); + + BOOST_CHECK_NE(nextExecutionFrameA, &executionFrameC); +} + |