annotate gcc/testsuite/brig.dg/test/gimple/function_calls.hsail @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
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 /* Function calls and argument passing. */
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 prog function &subfunction(arg_u32 %return_value)(arg_f32 %float_arg, arg_f64 %double_arg, arg_f16 %half_arg) {
kono
parents:
diff changeset
9 ld_arg_f32 $s0, [%float_arg];
kono
parents:
diff changeset
10 cvt_u32_f32 $s0, $s0;
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 ld_arg_f64 $d0, [%double_arg];
kono
parents:
diff changeset
13 cvt_u32_f64 $s1, $d0;
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 ld_arg_f16 $s2, [%half_arg];
kono
parents:
diff changeset
16 cvt_u32_f16 $s2, $s2;
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 add_u32 $s3, $s0, $s1;
kono
parents:
diff changeset
19 add_u32 $s3, $s3, $s2;
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 st_arg_u32 $s3, [%return_value];
kono
parents:
diff changeset
22 ret;
kono
parents:
diff changeset
23 };
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 prog kernel &kernel(kernarg_u64 %input_ptr, kernarg_u64 %output_ptr)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 ld_kernarg_u64 $d0, [%input_ptr];
kono
parents:
diff changeset
28 ld_global_u32 $s0, [$d0];
kono
parents:
diff changeset
29 {
kono
parents:
diff changeset
30 arg_f32 %float_arg;
kono
parents:
diff changeset
31 arg_f64 %double_arg;
kono
parents:
diff changeset
32 arg_f16 %half_arg;
kono
parents:
diff changeset
33 arg_u32 %return_value;
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 st_arg_f32 12.0f, [%float_arg];
kono
parents:
diff changeset
36 st_arg_f64 640.0d, [%double_arg];
kono
parents:
diff changeset
37 st_arg_f16 12.0h, [%half_arg];
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 call &subfunction(%return_value)(%float_arg, %double_arg, %half_arg);
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 ld_arg_u32 $s1, [%return_value];
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43 ld_kernarg_u64 $d1, [%output_ptr];
kono
parents:
diff changeset
44 st_global_u32 $s1, [$d0];
kono
parents:
diff changeset
45 };
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /* The generated function call should have the incoming arguments and three hidden arguments. */
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 /* { dg-final { scan-tree-dump "_\[0-9\]+ = subfunction \\\(_kernel.float_arg.\[_0-9\]+, _kernel.double_arg.\[_0-9\]+, _kernel.half_arg.\[_0-9\]+, __context, __group_base_addr, group_local_offset.*, __private_base_addr\\\);" "gimple"} } */
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 /* The callee should refer directly to the scalar arguments when it reads them. */
kono
parents:
diff changeset
52 /* { dg-final { scan-tree-dump "= float_arg;" "gimple"} } */
kono
parents:
diff changeset
53 /* { dg-final { scan-tree-dump "= double_arg;" "gimple"} } */
kono
parents:
diff changeset
54 /* { dg-final { scan-tree-dump "= half_arg;" "gimple"} } */
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 /* The return value is stored to a temporary before returned. */
kono
parents:
diff changeset
57 /* { dg-final { scan-tree-dump "_retvalue_temp = s3;" "gimple"} } */
kono
parents:
diff changeset
58 /* { dg-final { scan-tree-dump "D.\[0-9\]+ = _retvalue_temp;" "gimple"} } */
kono
parents:
diff changeset
59 /* { dg-final { scan-tree-dump "return D.\[0-9\]+;" "gimple"} } */