GBE: Remove some noduplicate to let inline works
authorRuiling Song <ruiling.song@intel.com>
Wed, 8 Jan 2014 06:58:07 +0000 (14:58 +0800)
committerZhigang Gong <zhigang.gong@intel.com>
Wed, 8 Jan 2014 06:25:43 +0000 (14:25 +0800)
llvm Inliner seems won't inline a function if it contains noduplicate function calls.
So, we just keep the noduplicate for barrier itself. then barrier() could still be inlined.

Signed-off-by: Ruiling Song <ruiling.song@intel.com>
Reviewed-by: Zhigang Gong <zhigang.gong@linux.intel.com>
backend/src/ocl_barrier.ll

index b493597..9f46347 100644 (file)
@@ -6,16 +6,16 @@
 
 declare i32 @_get_local_mem_fence() nounwind alwaysinline
 declare i32 @_get_global_mem_fence() nounwind alwaysinline
-declare void @__gen_ocl_barrier_local() nounwind noduplicate alwaysinline
-declare void @__gen_ocl_barrier_global() nounwind noduplicate alwaysinline
-declare void @__gen_ocl_barrier_local_and_global() nounwind noduplicate alwaysinline
+declare void @__gen_ocl_barrier_local() nounwind alwaysinline
+declare void @__gen_ocl_barrier_global() nounwind alwaysinline
+declare void @__gen_ocl_barrier_local_and_global() nounwind alwaysinline
 
 define void @barrier(i32 %flags) nounwind noduplicate alwaysinline {
   %1 = icmp eq i32 %flags, 3
   br i1 %1, label %barrier_local_global, label %barrier_local_check
 
 barrier_local_global:
-  call void @__gen_ocl_barrier_local_and_global() noduplicate
+  call void @__gen_ocl_barrier_local_and_global()
   br label %done
 
 barrier_local_check:
@@ -23,7 +23,7 @@ barrier_local_check:
   br i1 %2, label %barrier_local, label %barrier_global_check
 
 barrier_local:
-  call void @__gen_ocl_barrier_local() noduplicate
+  call void @__gen_ocl_barrier_local()
   br label %done
 
 barrier_global_check:
@@ -31,7 +31,7 @@ barrier_global_check:
   br i1 %3, label %barrier_global, label %done
 
 barrier_global:
-  call void @__gen_ocl_barrier_global() noduplicate
+  call void @__gen_ocl_barrier_global()
   br label %done
 
 done: