llvm.org GIT mirror llvm / 717969d
Merging r181576: ------------------------------------------------------------------------ r181576 | tstellar | 2013-05-09 19:09:24 -0700 (Thu, 09 May 2013) | 10 lines R600: Expand vselect for v4i32 and v2i32 v2: Add vselect v4i32 test Patch by: Aaron Watry Reviewed-by: Tom Stellard <thomas.stellard@amd.com> Signed-off-by: Aaron Watry <awatry@gmail.com> NOTE: This is a candidate for the 3.3 branch. ------------------------------------------------------------------------ git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_33@181950 91177308-0d34-0410-b5e6-96231b3b80d8 Bill Wendling 7 years ago
2 changed file(s) with 20 addition(s) and 0 deletion(s). Raw diff Collapse all Expand all
7676
7777 setOperationAction(ISD::SELECT, MVT::i32, Custom);
7878 setOperationAction(ISD::SELECT, MVT::f32, Custom);
79
80 setOperationAction(ISD::VSELECT, MVT::v4i32, Expand);
81 setOperationAction(ISD::VSELECT, MVT::v2i32, Expand);
7982
8083 // Legalize loads and stores to the private address space.
8184 setOperationAction(ISD::LOAD, MVT::i32, Custom);
0 ;RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s
1
2 ; CHECK: @test_select_v4i32
3 ; CHECK: CNDE_INT T{{[0-9]+\.[XYZW], PV\.[xyzw], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
4 ; CHECK: CNDE_INT * T{{[0-9]+\.[XYZW], PV\.[xyzw], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
5 ; CHECK: CNDE_INT * T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
6 ; CHECK: CNDE_INT * T{{[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW], T[0-9]+\.[XYZW]}}
7
8 define void @test_select_v4i32(<4 x i32> addrspace(1)* %out, <4 x i32> addrspace(1)* %in0, <4 x i32> addrspace(1)* %in1) {
9 entry:
10 %0 = load <4 x i32> addrspace(1)* %in0
11 %1 = load <4 x i32> addrspace(1)* %in1
12 %cmp = icmp ne <4 x i32> %0, %1
13 %result = select <4 x i1> %cmp, <4 x i32> %0, <4 x i32> %1
14 store <4 x i32> %result, <4 x i32> addrspace(1)* %out
15 ret void
16 }