annotate gcc/testsuite/c-c++-common/cilk-plus/CK/spawner_inline.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run } */
kono
parents:
diff changeset
2 /* { dg-require-effective-target cilkplus_runtime } */
kono
parents:
diff changeset
3 /* { dg-options "-fcilkplus" } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #include <stdlib.h>
kono
parents:
diff changeset
6 #define DEFAULT_VALUE 30
kono
parents:
diff changeset
7 int fib (int n)
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 if (n<2)
kono
parents:
diff changeset
10 return n;
kono
parents:
diff changeset
11 else
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 int x, y;
kono
parents:
diff changeset
14 x = _Cilk_spawn fib (n-1);
kono
parents:
diff changeset
15 y = _Cilk_spawn fib (n-2);
kono
parents:
diff changeset
16 _Cilk_sync;
kono
parents:
diff changeset
17 return (x+y);
kono
parents:
diff changeset
18 return 5;
kono
parents:
diff changeset
19 }
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 int main_parallel (int argc, char *argv[])
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 int n, result;
kono
parents:
diff changeset
25 if (argc == 2)
kono
parents:
diff changeset
26 n = atoi(argv[1]);
kono
parents:
diff changeset
27 else
kono
parents:
diff changeset
28 n = DEFAULT_VALUE;
kono
parents:
diff changeset
29 result = _Cilk_spawn fib(n);
kono
parents:
diff changeset
30 _Cilk_sync;
kono
parents:
diff changeset
31 return result;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 int fib_serial (int n)
kono
parents:
diff changeset
35 {
kono
parents:
diff changeset
36 int x, y;
kono
parents:
diff changeset
37 if (n < 2)
kono
parents:
diff changeset
38 return n;
kono
parents:
diff changeset
39 else
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 x = fib (n-1);
kono
parents:
diff changeset
42 y = fib (n-2);
kono
parents:
diff changeset
43 return (x+y);
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int main_serial (int argc, char *argv[])
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 int n, result;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 if (argc == 2)
kono
parents:
diff changeset
52 n = atoi (argv[1]);
kono
parents:
diff changeset
53 else
kono
parents:
diff changeset
54 n = DEFAULT_VALUE;
kono
parents:
diff changeset
55 result = fib_serial (n);
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 return result;
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 int main (void)
kono
parents:
diff changeset
61 {
kono
parents:
diff changeset
62 if (main_serial (1, 0) != main_parallel (1,0))
kono
parents:
diff changeset
63 return 1;
kono
parents:
diff changeset
64 else
kono
parents:
diff changeset
65 return 0;
kono
parents:
diff changeset
66 }
kono
parents:
diff changeset
67