// Copyright (C) 2023 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. #pragma once #include #include #include #include namespace dittosuite { class Multiprocessing : public Instruction { public: inline static const std::string kName = "multiprocessing"; explicit Multiprocessing(const Params& params, std::vector> instructions, std::vector thread_params); std::unique_ptr CollectResults(const std::string& prefix) override; private: void SetUpSingle() override; void RunSingle() override; void TearDownSingle(bool is_last) override; std::vector> instructions_; std::vector thread_params_; std::vector> pipe_fds_; unsigned int instruction_id_; pthread_barrier_t* barrier_execution_; pthread_barrier_t* barrier_execution_end_; pthread_mutex_t* initialization_mutex_; bool is_manager_; }; } // namespace dittosuite