1; RUN: opt -mtriple amdgcn-unknown-amdhsa -analyze -divergence %s | FileCheck %s 2 3declare i32 @llvm.amdgcn.workitem.id.x() #0 4declare i32 @llvm.amdgcn.workitem.id.y() #0 5declare i32 @llvm.amdgcn.workitem.id.z() #0 6declare i32 @llvm.amdgcn.mbcnt.lo(i32, i32) #0 7declare i32 @llvm.amdgcn.mbcnt.hi(i32, i32) #0 8 9; CHECK: DIVERGENT: %id.x = call i32 @llvm.amdgcn.workitem.id.x() 10define void @workitem_id_x() #1 { 11 %id.x = call i32 @llvm.amdgcn.workitem.id.x() 12 store volatile i32 %id.x, i32 addrspace(1)* undef 13 ret void 14} 15 16; CHECK: DIVERGENT: %id.y = call i32 @llvm.amdgcn.workitem.id.y() 17define void @workitem_id_y() #1 { 18 %id.y = call i32 @llvm.amdgcn.workitem.id.y() 19 store volatile i32 %id.y, i32 addrspace(1)* undef 20 ret void 21} 22 23; CHECK: DIVERGENT: %id.z = call i32 @llvm.amdgcn.workitem.id.z() 24define void @workitem_id_z() #1 { 25 %id.z = call i32 @llvm.amdgcn.workitem.id.z() 26 store volatile i32 %id.z, i32 addrspace(1)* undef 27 ret void 28} 29 30; CHECK: DIVERGENT: %mbcnt.lo = call i32 @llvm.amdgcn.mbcnt.lo(i32 0, i32 0) 31define void @mbcnt_lo() #1 { 32 %mbcnt.lo = call i32 @llvm.amdgcn.mbcnt.lo(i32 0, i32 0) 33 store volatile i32 %mbcnt.lo, i32 addrspace(1)* undef 34 ret void 35} 36 37; CHECK: DIVERGENT: %mbcnt.hi = call i32 @llvm.amdgcn.mbcnt.hi(i32 0, i32 0) 38define void @mbcnt_hi() #1 { 39 %mbcnt.hi = call i32 @llvm.amdgcn.mbcnt.hi(i32 0, i32 0) 40 store volatile i32 %mbcnt.hi, i32 addrspace(1)* undef 41 ret void 42} 43 44attributes #0 = { nounwind readnone } 45attributes #1 = { nounwind } 46