xref: /aosp_15_r20/external/armnn/src/backends/cl/workloads/ClChannelShuffleWorkload.hpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1 //
2 // Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #pragma once
7 
8 #include "ClBaseWorkload.hpp"
9 
10 #include <arm_compute/core/Error.h>
11 #include <arm_compute/runtime/CL/functions/CLChannelShuffleLayer.h>
12 
13 namespace armnn
14 {
15 
16 arm_compute::Status ClChannelShuffleValidate(const TensorInfo& input,
17                                              const TensorInfo& output,
18                                              const ChannelShuffleDescriptor& descriptor);
19 
20 class ClChannelShuffleWorkload : public ClBaseWorkload<ChannelShuffleQueueDescriptor>
21 {
22 public:
23     ClChannelShuffleWorkload(const ChannelShuffleQueueDescriptor& descriptor,
24                              const WorkloadInfo& info,
25                              const arm_compute::CLCompileContext& clCompileContext);
26     virtual void Execute() const override;
27 
28 private:
29     mutable arm_compute::CLChannelShuffleLayer m_ChannelShuffleLayer;
30 };
31 
32 } // namespace armnn
33