blob: 9efe027157155e07700041a461a0326eae826aac [file] [log] [blame]
module &module:1:0:$full:$large:$default;
/* Tests for fbarrier. */
/* { dg-do compile } */
/* { dg-options "-fdump-tree-gimple" } */
fbarrier &fb_module_scope;
prog function &subfunction(arg_u32 %return_value)() {
workitemflatabsid_u32 $s3;
cvt_b1_u32 $c1, $s3;
cbr_width(all)_b1 $c1, @skip_fbar;
waitfbar &fb_module_scope;
@skip_fbar:
st_arg_u32 $s3, [%return_value];
ret;
};
prog kernel &kernel(kernarg_u64 %input_ptr, kernarg_u64 %output_ptr)
{
fbarrier %fb_func_scope;
ld_kernarg_u64 $d0, [%input_ptr];
ld_global_u32 $s0, [$d0];
workitemflatabsid_u32 $s1;
cvt_b1_u32 $c1, $s1;
cbr_width(all)_b1 $c1, @skip_init;
initfbar &fb_module_scope;
initfbar %fb_func_scope;
joinfbar &fb_module_scope;
@skip_init:
barrier_width(all);
joinfbar %fb_func_scope;
{
arg_u32 %return_value;
call &subfunction(%return_value)();
ld_arg_u32 $s1, [%return_value];
}
arrivefbar %fb_func_scope;
ld_kernarg_u64 $d1, [%output_ptr];
st_global_u32 $s1, [$d0];
workitemflatabsid_u32 $s1;
cvt_b1_u32 $c0, $s1;
cbr_width(all)_b1 $c0, @skip_fini;
releasefbar &fb_module_scope;
releasefbar %fb_func_scope;
@skip_fini:
};
/* fbarriers are allocated from the group memory in the order of
appearance. The current implementation allocates 32B per fbarrier. */
/* { dg-final { scan-tree-dump "__hsail_waitfbar \\\(0, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "__hsail_initfbar \\\(0, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "__hsail_initfbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "__hsail_joinfbar \\\(0, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "@skip_init:\[\n ]+__builtin___hsail_barrier \\\(__context\\\);\[\n ]+__builtin___hsail_joinfbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "__hsail_arrivefbar \\\(__group_local_offset, __context\\\);" "gimple"} } */
/* { dg-final { scan-tree-dump "__hsail_releasefbar \\\(0, __context\\\);\[\n ]+__builtin___hsail_releasefbar \\\(__group_local_offset, __context\\\);" "gimple"} } */