• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1;RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck --check-prefix=EG-CHECK %s
2
3; CHECK: @setcc_v2i32
4; EG-CHECK-DAG: SETE_INT * T{{[0-9]+\.[XYZW]}}, KC0[3].X, KC0[3].Z
5; EG-CHECK-DAG: SETE_INT * T{{[0-9]+\.[XYZW]}}, KC0[2].W, KC0[3].Y
6
7define void @setcc_v2i32(<2 x i32> addrspace(1)* %out, <2 x i32> %a, <2 x i32> %b) {
8  %result = icmp eq <2 x i32> %a, %b
9  %sext = sext <2 x i1> %result to <2 x i32>
10  store <2 x i32> %sext, <2 x i32> addrspace(1)* %out
11  ret void
12}
13
14; CHECK: @setcc_v4i32
15; EG-CHECK-DAG: SETE_INT T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
16; EG-CHECK-DAG: SETE_INT * T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
17; EG-CHECK-DAG: SETE_INT * T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
18; EG-CHECK-DAG: SETE_INT * T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
19
20define void @setcc_v4i32(<4 x i32> addrspace(1)* %out, <4 x i32> addrspace(1)* %in) {
21  %b_ptr = getelementptr <4 x i32> addrspace(1)* %in, i32 1
22  %a = load <4 x i32> addrspace(1) * %in
23  %b = load <4 x i32> addrspace(1) * %b_ptr
24  %result = icmp eq <4 x i32> %a, %b
25  %sext = sext <4 x i1> %result to <4 x i32>
26  store <4 x i32> %sext, <4 x i32> addrspace(1)* %out
27  ret void
28}
29