2016-03-02 01:51:23 +08:00
|
|
|
; RUN: llc -mtriple=amdgcn--amdhsa -mcpu=fiji -verify-machineinstrs < %s | FileCheck %s
|
|
|
|
|
|
|
|
declare i32 @llvm.amdgcn.ds.permute(i32, i32) #0
|
|
|
|
|
|
|
|
; FUNC-LABEL: {{^}}ds_permute:
|
|
|
|
; CHECK: ds_permute_b32 v{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
|
|
|
|
define void @ds_permute(i32 addrspace(1)* %out, i32 %index, i32 %src) nounwind {
|
2016-03-18 00:43:50 +08:00
|
|
|
%permute = call i32 @llvm.amdgcn.ds.permute(i32 %index, i32 %src) #0
|
|
|
|
store i32 %permute, i32 addrspace(1)* %out, align 4
|
2016-03-02 01:51:23 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2016-03-18 00:43:50 +08:00
|
|
|
; FUNC-LABEL: {{^}}permute_no_waitcnt_test:
|
|
|
|
; CHECK: s_cbranch_scc1
|
|
|
|
; CHECK: ds_permute_b32 v{{[0-9]+}}, v{{[0-9]+}}, v{{[0-9]+}}
|
|
|
|
; CHECK-NOT: s_waitcnt
|
|
|
|
define void @permute_no_waitcnt_test(i32 addrspace(1)* %out, i32 %cond) {
|
|
|
|
entry:
|
|
|
|
|
|
|
|
%tmp = icmp eq i32 %cond, 0
|
|
|
|
br i1 %tmp, label %if, label %else
|
|
|
|
|
|
|
|
if: ; preds = %entry
|
|
|
|
%permute = call i32 @llvm.amdgcn.ds.permute(i32 0, i32 0) #0
|
|
|
|
br label %endif
|
|
|
|
|
|
|
|
else: ; preds = %entry
|
|
|
|
br label %endif
|
|
|
|
|
|
|
|
endif:
|
|
|
|
%val = phi i32 [ %permute, %if ], [0, %else] ; preds = %else, %if
|
|
|
|
store i32 %val, i32 addrspace(1)* %out, align 4
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-03-02 01:51:23 +08:00
|
|
|
attributes #0 = { nounwind readnone convergent }
|