• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; RUN: llc -march=r600 -mcpu=SI -verify-machineinstrs < %s | FileCheck -check-prefix=SI -check-prefix=FUNC %s
2
3declare i32 @llvm.cttz.i32(i32, i1) nounwind readnone
4declare <2 x i32> @llvm.cttz.v2i32(<2 x i32>, i1) nounwind readnone
5declare <4 x i32> @llvm.cttz.v4i32(<4 x i32>, i1) nounwind readnone
6
7; FUNC-LABEL: @s_cttz_zero_undef_i32:
8; SI: S_LOAD_DWORD [[VAL:s[0-9]+]],
9; SI: S_FF1_I32_B32 [[SRESULT:s[0-9]+]], [[VAL]]
10; SI: V_MOV_B32_e32 [[VRESULT:v[0-9]+]], [[SRESULT]]
11; SI: BUFFER_STORE_DWORD [[VRESULT]],
12; SI: S_ENDPGM
13define void @s_cttz_zero_undef_i32(i32 addrspace(1)* noalias %out, i32 %val) nounwind {
14  %cttz = call i32 @llvm.cttz.i32(i32 %val, i1 true) nounwind readnone
15  store i32 %cttz, i32 addrspace(1)* %out, align 4
16  ret void
17}
18
19; FUNC-LABEL: @v_cttz_zero_undef_i32:
20; SI: BUFFER_LOAD_DWORD [[VAL:v[0-9]+]],
21; SI: V_FFBL_B32_e32 [[RESULT:v[0-9]+]], [[VAL]]
22; SI: BUFFER_STORE_DWORD [[RESULT]],
23; SI: S_ENDPGM
24define void @v_cttz_zero_undef_i32(i32 addrspace(1)* noalias %out, i32 addrspace(1)* noalias %valptr) nounwind {
25  %val = load i32 addrspace(1)* %valptr, align 4
26  %cttz = call i32 @llvm.cttz.i32(i32 %val, i1 true) nounwind readnone
27  store i32 %cttz, i32 addrspace(1)* %out, align 4
28  ret void
29}
30
31; FUNC-LABEL: @v_cttz_zero_undef_v2i32:
32; SI: BUFFER_LOAD_DWORDX2
33; SI: V_FFBL_B32_e32
34; SI: V_FFBL_B32_e32
35; SI: BUFFER_STORE_DWORDX2
36; SI: S_ENDPGM
37define void @v_cttz_zero_undef_v2i32(<2 x i32> addrspace(1)* noalias %out, <2 x i32> addrspace(1)* noalias %valptr) nounwind {
38  %val = load <2 x i32> addrspace(1)* %valptr, align 8
39  %cttz = call <2 x i32> @llvm.cttz.v2i32(<2 x i32> %val, i1 true) nounwind readnone
40  store <2 x i32> %cttz, <2 x i32> addrspace(1)* %out, align 8
41  ret void
42}
43
44; FUNC-LABEL: @v_cttz_zero_undef_v4i32:
45; SI: BUFFER_LOAD_DWORDX4
46; SI: V_FFBL_B32_e32
47; SI: V_FFBL_B32_e32
48; SI: V_FFBL_B32_e32
49; SI: V_FFBL_B32_e32
50; SI: BUFFER_STORE_DWORDX4
51; SI: S_ENDPGM
52define void @v_cttz_zero_undef_v4i32(<4 x i32> addrspace(1)* noalias %out, <4 x i32> addrspace(1)* noalias %valptr) nounwind {
53  %val = load <4 x i32> addrspace(1)* %valptr, align 16
54  %cttz = call <4 x i32> @llvm.cttz.v4i32(<4 x i32> %val, i1 true) nounwind readnone
55  store <4 x i32> %cttz, <4 x i32> addrspace(1)* %out, align 16
56  ret void
57}
58