1 // RUN: %compile-run-and-check
2 
3 #include <omp.h>
4 #include <stdio.h>
5 
6 int main() {
7   int res = 0;
8 
9 #pragma omp parallel num_threads(2) reduction(+:res)
10   {
11     int tid = omp_get_thread_num();
12 #pragma omp target teams distribute reduction(+:res)
13     for (int i = tid; i < 2; i++)
14       ++res;
15   }
16   // The first thread makes 2 iterations, the second - 1. Expected result of the
17   // reduction res is 3.
18 
19   // CHECK: res = 3.
20   printf("res = %d.\n", res);
21   return 0;
22 }
23