| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 | 
 | ; RUN: llc < %s -march=nvptx64 -mcpu=sm_100a -mattr=+ptx86 | FileCheck --check-prefixes=CHECK %s | 
 | ; RUN: llc < %s -march=nvptx64 -mcpu=sm_103a -mattr=+ptx88 | FileCheck --check-prefixes=CHECK %s | 
 | ; RUN: %if ptxas-sm_100a && ptxas-isa-8.6 %{ llc < %s -march=nvptx64 -mcpu=sm_100a -mattr=+ptx86 | %ptxas-verify -arch=sm_100a %} | 
 | ; RUN: %if ptxas-sm_103a && ptxas-isa-8.8 %{ llc < %s -march=nvptx64 -mcpu=sm_103a -mattr=+ptx88 | %ptxas-verify -arch=sm_103a %} | 
 |  | 
 | declare void @llvm.nvvm.tcgen05.fence.before.thread.sync() | 
 | declare void @llvm.nvvm.tcgen05.fence.after.thread.sync() | 
 | declare void @llvm.nvvm.tcgen05.wait.ld() | 
 | declare void @llvm.nvvm.tcgen05.wait.st() | 
 |  | 
 | ; CHECK-LABEL: test_tcgen05_fence | 
 | define void @test_tcgen05_fence() { | 
 | ; CHECK-LABEL: test_tcgen05_fence( | 
 | ; CHECK:       { | 
 | ; CHECK-EMPTY: | 
 | ; CHECK-EMPTY: | 
 | ; CHECK-NEXT:  // %bb.0: | 
 | ; CHECK-NEXT:    tcgen05.fence::before_thread_sync; | 
 | ; CHECK-NEXT:    tcgen05.fence::after_thread_sync; | 
 | ; CHECK-NEXT:    ret; | 
 |   call void @llvm.nvvm.tcgen05.fence.before.thread.sync() | 
 |  | 
 |   call void @llvm.nvvm.tcgen05.fence.after.thread.sync() | 
 |  | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-LABEL: test_tcgen05_wait | 
 | define void @test_tcgen05_wait() { | 
 | ; CHECK-LABEL: test_tcgen05_wait( | 
 | ; CHECK:       { | 
 | ; CHECK-EMPTY: | 
 | ; CHECK-EMPTY: | 
 | ; CHECK-NEXT:  // %bb.0: | 
 | ; CHECK-NEXT:    tcgen05.wait::ld.sync.aligned; | 
 | ; CHECK-NEXT:    tcgen05.wait::st.sync.aligned; | 
 | ; CHECK-NEXT:    ret; | 
 |   call void @llvm.nvvm.tcgen05.wait.ld() | 
 |  | 
 |   call void @llvm.nvvm.tcgen05.wait.st() | 
 |  | 
 |   ret void | 
 | } |