1 //
2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5
6 #include "ClReshapeWorkload.hpp"
7 #include <cl/ClTensorHandle.hpp>
8 #include <armnn/backends/TensorHandle.hpp>
9
10 #include "ClWorkloadUtils.hpp"
11
12 namespace armnn
13 {
14
ClReshapeWorkloadValidate(const TensorInfo & input,const TensorInfo & output)15 arm_compute::Status ClReshapeWorkloadValidate(const TensorInfo& input,
16 const TensorInfo& output)
17 {
18 const arm_compute::TensorInfo aclInputInfo = armcomputetensorutils::BuildArmComputeTensorInfo(input);
19 const arm_compute::TensorInfo aclOutputInfo = armcomputetensorutils::BuildArmComputeTensorInfo(output);
20
21 return arm_compute::CLReshapeLayer::validate(&aclInputInfo, &aclOutputInfo);
22 }
23
ClReshapeWorkload(const ReshapeQueueDescriptor & descriptor,const WorkloadInfo & info,const arm_compute::CLCompileContext & clCompileContext)24 ClReshapeWorkload::ClReshapeWorkload(const ReshapeQueueDescriptor& descriptor,
25 const WorkloadInfo& info,
26 const arm_compute::CLCompileContext& clCompileContext)
27 : ClBaseWorkload<ReshapeQueueDescriptor>(descriptor, info)
28 {
29 m_Data.ValidateInputsOutputs("ClReshapeWorkload", 1, 1);
30
31 arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
32 arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
33
34 {
35 ARMNN_SCOPED_PROFILING_EVENT(Compute::Undefined, "ClReshapeWorkload_configure");
36 m_Layer.configure(clCompileContext, &input, &output);
37 }
38 }
39
Execute() const40 void ClReshapeWorkload::Execute() const
41 {
42 ARMNN_SCOPED_PROFILING_EVENT_CL_GUID("ClReshapeWorkload_Execute", this->GetGuid());
43 RunClFunction(m_Layer, CHECK_LOCATION());
44 }
45
46 } //namespace armnn
47