1484543d1Sopenharmony_ci/* 2484543d1Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 3484543d1Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4484543d1Sopenharmony_ci * you may not use this file except in compliance with the License. 5484543d1Sopenharmony_ci * You may obtain a copy of the License at 6484543d1Sopenharmony_ci * 7484543d1Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8484543d1Sopenharmony_ci * 9484543d1Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10484543d1Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11484543d1Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12484543d1Sopenharmony_ci * See the License for the specific language governing permissions and 13484543d1Sopenharmony_ci * limitations under the License. 14484543d1Sopenharmony_ci */ 15484543d1Sopenharmony_ci 16484543d1Sopenharmony_ci#include "ffrt_inner.h" 17484543d1Sopenharmony_ci#include "common.h" 18484543d1Sopenharmony_ci 19484543d1Sopenharmony_ciconstexpr uint32_t FORK_JOIN_COUNT = 10000; 20484543d1Sopenharmony_ci 21484543d1Sopenharmony_civoid ForkJoin() 22484543d1Sopenharmony_ci{ 23484543d1Sopenharmony_ci PreHotFFRT(); 24484543d1Sopenharmony_ci 25484543d1Sopenharmony_ci TIME_BEGIN(t); 26484543d1Sopenharmony_ci for (uint32_t r = 0; r < REPEAT; r++) { 27484543d1Sopenharmony_ci for (uint32_t i = 0; i < FORK_JOIN_COUNT; i++) { 28484543d1Sopenharmony_ci ffrt::submit([=]() { simulate_task_compute_time(COMPUTE_TIME_US); }, {}, {}); 29484543d1Sopenharmony_ci } 30484543d1Sopenharmony_ci ffrt::wait(); 31484543d1Sopenharmony_ci } 32484543d1Sopenharmony_ci TIME_END_INFO(t, "fork_join"); 33484543d1Sopenharmony_ci} 34484543d1Sopenharmony_ci 35484543d1Sopenharmony_civoid ForkJoinWorker() 36484543d1Sopenharmony_ci{ 37484543d1Sopenharmony_ci PreHotFFRT(); 38484543d1Sopenharmony_ci 39484543d1Sopenharmony_ci TIME_BEGIN(t); 40484543d1Sopenharmony_ci for (uint32_t r = 0; r < REPEAT; r++) { 41484543d1Sopenharmony_ci ffrt::submit( 42484543d1Sopenharmony_ci [&]() { 43484543d1Sopenharmony_ci for (uint32_t i = 0; i < FORK_JOIN_COUNT; i++) { 44484543d1Sopenharmony_ci ffrt::submit([=]() { simulate_task_compute_time(COMPUTE_TIME_US); }, {}, {}); 45484543d1Sopenharmony_ci } 46484543d1Sopenharmony_ci ffrt::wait(); 47484543d1Sopenharmony_ci }, 48484543d1Sopenharmony_ci {}, {&r}); 49484543d1Sopenharmony_ci ffrt::wait({&r}); 50484543d1Sopenharmony_ci } 51484543d1Sopenharmony_ci TIME_END_INFO(t, "fork_join_worker_submit"); 52484543d1Sopenharmony_ci} 53484543d1Sopenharmony_ci 54484543d1Sopenharmony_ciint main() 55484543d1Sopenharmony_ci{ 56484543d1Sopenharmony_ci GetEnvs(); 57484543d1Sopenharmony_ci ForkJoin(); 58484543d1Sopenharmony_ci ForkJoinWorker(); 59484543d1Sopenharmony_ci}