blob: 571dbb219a4d9ff63fa31b151bcf8e4acefd6aed [file] [log] [blame]
narpra01db2b1602019-01-23 15:23:11 +00001//
telsoa014fcda012018-03-09 14:13:49 +00002// Copyright © 2017 Arm Ltd. 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
28void RefConstantWorkload::ExecuteAsync(WorkingMemDescriptor &workingMemDescriptor)
29{
30 Execute(workingMemDescriptor.m_Outputs);
31}
32
33void RefConstantWorkload::Execute(std::vector<ITensorHandle*> outputs) const
34{
35 memcpy(outputs[0]->Map(), m_Data.m_LayerOutput->GetConstTensor<void>(), GetTensorInfo(outputs[0]).GetNumBytes());
36
Nina Drozd58ef2c62019-05-16 12:09:18 +010037 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefConstantWorkload_Execute");
38}
telsoa014fcda012018-03-09 14:13:49 +000039
40} //namespace armnn