1*6fa2df46SAndroid Build Coastguard Worker // Copyright (C) 2023 The Android Open Source Project 2*6fa2df46SAndroid Build Coastguard Worker // 3*6fa2df46SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 4*6fa2df46SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 5*6fa2df46SAndroid Build Coastguard Worker // You may obtain a copy of the License at 6*6fa2df46SAndroid Build Coastguard Worker // 7*6fa2df46SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 8*6fa2df46SAndroid Build Coastguard Worker // 9*6fa2df46SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 10*6fa2df46SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 11*6fa2df46SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*6fa2df46SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 13*6fa2df46SAndroid Build Coastguard Worker // limitations under the License. 14*6fa2df46SAndroid Build Coastguard Worker 15*6fa2df46SAndroid Build Coastguard Worker #pragma once 16*6fa2df46SAndroid Build Coastguard Worker 17*6fa2df46SAndroid Build Coastguard Worker #include <ditto/instruction.h> 18*6fa2df46SAndroid Build Coastguard Worker 19*6fa2df46SAndroid Build Coastguard Worker namespace dittosuite { 20*6fa2df46SAndroid Build Coastguard Worker 21*6fa2df46SAndroid Build Coastguard Worker class CpuWork : public Instruction { 22*6fa2df46SAndroid Build Coastguard Worker public: 23*6fa2df46SAndroid Build Coastguard Worker inline static const std::string kName; 24*6fa2df46SAndroid Build Coastguard Worker 25*6fa2df46SAndroid Build Coastguard Worker explicit CpuWork(const std::string &name, const Params& params); 26*6fa2df46SAndroid Build Coastguard Worker 27*6fa2df46SAndroid Build Coastguard Worker private: 28*6fa2df46SAndroid Build Coastguard Worker virtual void RunSingle() = 0; 29*6fa2df46SAndroid Build Coastguard Worker }; 30*6fa2df46SAndroid Build Coastguard Worker 31*6fa2df46SAndroid Build Coastguard Worker class CpuWorkCycles : public CpuWork { 32*6fa2df46SAndroid Build Coastguard Worker public: 33*6fa2df46SAndroid Build Coastguard Worker inline static const std::string kName = "cpu_work_cycles"; 34*6fa2df46SAndroid Build Coastguard Worker 35*6fa2df46SAndroid Build Coastguard Worker explicit CpuWorkCycles(const Params& params, uint64_t cycles); 36*6fa2df46SAndroid Build Coastguard Worker 37*6fa2df46SAndroid Build Coastguard Worker private: 38*6fa2df46SAndroid Build Coastguard Worker uint64_t cycles_; 39*6fa2df46SAndroid Build Coastguard Worker 40*6fa2df46SAndroid Build Coastguard Worker void RunSingle() override; 41*6fa2df46SAndroid Build Coastguard Worker }; 42*6fa2df46SAndroid Build Coastguard Worker 43*6fa2df46SAndroid Build Coastguard Worker class CpuWorkDurationUs : public CpuWork { 44*6fa2df46SAndroid Build Coastguard Worker public: 45*6fa2df46SAndroid Build Coastguard Worker inline static const std::string kName = "cpu_work_duration"; 46*6fa2df46SAndroid Build Coastguard Worker 47*6fa2df46SAndroid Build Coastguard Worker explicit CpuWorkDurationUs(const Params& params, uint64_t duration_us); 48*6fa2df46SAndroid Build Coastguard Worker 49*6fa2df46SAndroid Build Coastguard Worker private: 50*6fa2df46SAndroid Build Coastguard Worker timespec work_time_; 51*6fa2df46SAndroid Build Coastguard Worker 52*6fa2df46SAndroid Build Coastguard Worker void RunSingle() override; 53*6fa2df46SAndroid Build Coastguard Worker }; 54*6fa2df46SAndroid Build Coastguard Worker 55*6fa2df46SAndroid Build Coastguard Worker class CpuWorkUtilization : public CpuWork { 56*6fa2df46SAndroid Build Coastguard Worker public: 57*6fa2df46SAndroid Build Coastguard Worker inline static const std::string kName = "cpu_work_utilization"; 58*6fa2df46SAndroid Build Coastguard Worker 59*6fa2df46SAndroid Build Coastguard Worker explicit CpuWorkUtilization(const Params& params, double utilization); 60*6fa2df46SAndroid Build Coastguard Worker 61*6fa2df46SAndroid Build Coastguard Worker private: 62*6fa2df46SAndroid Build Coastguard Worker timespec work_time_; 63*6fa2df46SAndroid Build Coastguard Worker 64*6fa2df46SAndroid Build Coastguard Worker void RunSingle() override; 65*6fa2df46SAndroid Build Coastguard Worker }; 66*6fa2df46SAndroid Build Coastguard Worker 67*6fa2df46SAndroid Build Coastguard Worker } // namespace dittosuite 68