blob: 937e5178bb57116b319cf21f8f745244032b5c2a [file] [log] [blame]
narpra01db2b1602019-01-23 15:23:11 +00001//
Matthew Sloyan2d213a72022-06-30 17:13:04 +01002// Copyright © 2022 Arm Ltd and Contributors. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5
narpra01db2b1602019-01-23 15:23:11 +00006#include "RefConstantWorkload.hpp"
telsoa014fcda012018-03-09 14:13:49 +00007
8#include "RefWorkloadUtils.hpp"
9
10#include <armnn/Types.hpp>
11
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010012#include <armnn/utility/Assert.hpp>
telsoa014fcda012018-03-09 14:13:49 +000013
14#include <cstring>
15
16namespace armnn
17{
18
Nina Drozd58ef2c62019-05-16 12:09:18 +010019RefConstantWorkload::RefConstantWorkload(
20 const ConstantQueueDescriptor& descriptor, const WorkloadInfo& info)
Finn Williams73c547d2022-02-15 20:47:34 +000021 : RefBaseWorkload<ConstantQueueDescriptor>(descriptor, info) {}
Nina Drozd58ef2c62019-05-16 12:09:18 +010022
Nina Drozd58ef2c62019-05-16 12:09:18 +010023void RefConstantWorkload::Execute() const
24{
Finn Williamsb8181f72021-04-07 10:23:21 +010025 Execute(m_Data.m_Outputs);
26}
27
Matthew Sloyan2d213a72022-06-30 17:13:04 +010028void RefConstantWorkload::ExecuteAsync(ExecutionData& executionData)
Finn Williamsb8181f72021-04-07 10:23:21 +010029{
Matthew Sloyan2d213a72022-06-30 17:13:04 +010030 WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
31 Execute(workingMemDescriptor->m_Outputs);
Finn Williamsb8181f72021-04-07 10:23:21 +010032}
33
34void RefConstantWorkload::Execute(std::vector<ITensorHandle*> outputs) const
35{
36 memcpy(outputs[0]->Map(), m_Data.m_LayerOutput->GetConstTensor<void>(), GetTensorInfo(outputs[0]).GetNumBytes());
37
Nina Drozd58ef2c62019-05-16 12:09:18 +010038 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefConstantWorkload_Execute");
39}
telsoa014fcda012018-03-09 14:13:49 +000040
41} //namespace armnn