// Copyright (C) 2021 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include namespace dittosuite { Multithreading::Multithreading(SyscallInterface& syscall, int repeat, std::vector> instructions) : Instruction(syscall, kName, repeat), instructions_(std::move(instructions)) {} void Multithreading::SetUpSingle() { for (const auto& instruction : instructions_) { instruction->SetUp(); } threads_.clear(); Instruction::SetUpSingle(); } void Multithreading::RunSingle() { pthread_barrier_init(&barrier_, NULL, instructions_.size()); for (const auto& instruction : instructions_) { threads_.push_back(std::move(instruction->SpawnThread(&barrier_))); } } void Multithreading::TearDownSingle() { for (auto& thread : threads_) { thread.join(); } Instruction::TearDownSingle(); pthread_barrier_destroy(&barrier_); for (const auto& instruction : instructions_) { instruction->TearDown(); } } std::unique_ptr Multithreading::CollectResults(const std::string& prefix) { auto result = std::make_unique(prefix + name_, repeat_); result->AddMeasurement("duration", TimespecToDoubleNanos(time_sampler_.GetSamples())); for (std::size_t i = 0; i < instructions_.size(); ++i) { result->AddSubResult(instructions_[i]->CollectResults(std::to_string(i) + "/")); } return result; } } // namespace dittosuite