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}