annotate gcc/testsuite/brig.dg/test/gimple/fbarrier.hsail @ 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 module &module:1:0:$full:$large:$default;
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 /* Tests for fbarrier. */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 /* { dg-do compile } */
kono
parents:
diff changeset
6 /* { dg-options "-fdump-tree-gimple" } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 fbarrier &fb_module_scope;
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 prog function &subfunction(arg_u32 %return_value)() {
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 workitemflatabsid_u32 $s3;
kono
parents:
diff changeset
13 cvt_b1_u32 $c1, $s3;
kono
parents:
diff changeset
14 cbr_width(all)_b1 $c1, @skip_fbar;
kono
parents:
diff changeset
15 waitfbar &fb_module_scope;
kono
parents:
diff changeset
16 @skip_fbar:
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 st_arg_u32 $s3, [%return_value];
kono
parents:
diff changeset
19 ret;
kono
parents:
diff changeset
20 };
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 prog kernel &kernel(kernarg_u64 %input_ptr, kernarg_u64 %output_ptr)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 fbarrier %fb_func_scope;
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 ld_kernarg_u64 $d0, [%input_ptr];
kono
parents:
diff changeset
27 ld_global_u32 $s0, [$d0];
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 workitemflatabsid_u32 $s1;
kono
parents:
diff changeset
30 cvt_b1_u32 $c1, $s1;
kono
parents:
diff changeset
31 cbr_width(all)_b1 $c1, @skip_init;
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 initfbar &fb_module_scope;
kono
parents:
diff changeset
34 initfbar %fb_func_scope;
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 joinfbar &fb_module_scope;
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 @skip_init:
kono
parents:
diff changeset
39 barrier_width(all);
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 joinfbar %fb_func_scope;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 arg_u32 %return_value;
kono
parents:
diff changeset
45 call &subfunction(%return_value)();
kono
parents:
diff changeset
46 ld_arg_u32 $s1, [%return_value];
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48 arrivefbar %fb_func_scope;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 ld_kernarg_u64 $d1, [%output_ptr];
kono
parents:
diff changeset
51 st_global_u32 $s1, [$d0];
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 workitemflatabsid_u32 $s1;
kono
parents:
diff changeset
54 cvt_b1_u32 $c0, $s1;
kono
parents:
diff changeset
55 cbr_width(all)_b1 $c0, @skip_fini;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 releasefbar &fb_module_scope;
kono
parents:
diff changeset
58 releasefbar %fb_func_scope;
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 @skip_fini:
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 };
kono
parents:
diff changeset
63 /* fbarriers are allocated from the group memory in the order of
kono
parents:
diff changeset
64 appearance. The current implementation allocates 32B per fbarrier. */
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 /* { dg-final { scan-tree-dump "__hsail_waitfbar \\\(0, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
67 /* { dg-final { scan-tree-dump "__hsail_initfbar \\\(0, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
68 /* { dg-final { scan-tree-dump "__hsail_initfbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
69 /* { dg-final { scan-tree-dump "__hsail_joinfbar \\\(0, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
70 /* { dg-final { scan-tree-dump "@skip_init:\[\n ]+__builtin___hsail_barrier \\\(__context\\\);\[\n ]+__builtin___hsail_joinfbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 /* { dg-final { scan-tree-dump "__hsail_arrivefbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 /* { dg-final { scan-tree-dump "__hsail_releasefbar \\\(0, __context\\\);\[\n ]+__builtin___hsail_releasefbar \\\(__group_local_offset, __context\\\);" "gimple"} } */