[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / smrd_vmem_war.ll
blob2e0633d6b70b20c940b84c5ac7529642f35db795
1 ; RUN: llc  -mtriple=amdgcn -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck %s -check-prefix=GCN
3 ; GCN-LABEL: ; %bb.0:
4 ; GCN: s_load_dword s{{[0-9]+}}, s{{\[}}[[ADDR_LO:[0-9]+]]{{\:}}[[ADDR_HI:[0-9]+]]{{\]}}, 0x0
5 ; GCN: s_waitcnt lgkmcnt(0)
6 ; GCN: global_store_dword v
8 define amdgpu_kernel void @zot(i32 addrspace(1)* nocapture %arg, i64 addrspace(1)* nocapture %arg1) {
9 bb:
10   %tmp = call i32 @llvm.amdgcn.workitem.id.x()
11   %tmp2 = icmp eq i32 %tmp, 0
12   br i1 %tmp2, label %bb3, label %bb8
14 bb3:                                              ; preds = %bb
15   %tmp4 = load i32, i32 addrspace(1)* %arg, align 4
16   store i32 0, i32 addrspace(1)* %arg, align 4
17   %tmp5 = zext i32 %tmp4 to i64
18   %tmp6 = load i64, i64 addrspace(1)* %arg1, align 8
19   %tmp7 = add i64 %tmp6, %tmp5
20   store i64 %tmp7, i64 addrspace(1)* %arg1, align 8
21   br label %bb8
23 bb8:                                              ; preds = %bb3, %bb
24   ret void
26 ; Function Attrs: nounwind readnone speculatable
27 declare i32 @llvm.amdgcn.workitem.id.x() #0
29 attributes #0 = { nounwind readnone speculatable }