forked from OSchip/llvm-project
577 lines
19 KiB
LLVM
577 lines
19 KiB
LLVM
; RUN: llc -march=hexagon < %s | FileCheck %s
|
|
|
|
; --- Byte
|
|
|
|
; CHECK-LABEL: test_00:
|
|
; CHECK: q[[Q000:[0-3]]] = vcmp.eq(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q000]],v1,v2)
|
|
define <128 x i8> @test_00(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp eq <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_01:
|
|
; CHECK: q[[Q010:[0-3]]] = vcmp.eq(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q010]],v2,v1)
|
|
define <128 x i8> @test_01(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp ne <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_02:
|
|
; CHECK: q[[Q020:[0-3]]] = vcmp.gt(v1.b,v0.b)
|
|
; CHECK: v0 = vmux(q[[Q020]],v1,v2)
|
|
define <128 x i8> @test_02(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp slt <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_03:
|
|
; CHECK: q[[Q030:[0-3]]] = vcmp.gt(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q030]],v2,v1)
|
|
define <128 x i8> @test_03(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp sle <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_04:
|
|
; CHECK: q[[Q040:[0-3]]] = vcmp.gt(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q040]],v1,v2)
|
|
define <128 x i8> @test_04(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp sgt <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_05:
|
|
; CHECK: q[[Q050:[0-3]]] = vcmp.gt(v1.b,v0.b)
|
|
; CHECK: v0 = vmux(q[[Q050]],v2,v1)
|
|
define <128 x i8> @test_05(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp sge <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_06:
|
|
; CHECK: q[[Q060:[0-3]]] = vcmp.gt(v1.ub,v0.ub)
|
|
; CHECK: v0 = vmux(q[[Q060]],v1,v2)
|
|
define <128 x i8> @test_06(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp ult <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_07:
|
|
; CHECK: q[[Q070:[0-3]]] = vcmp.gt(v0.ub,v1.ub)
|
|
; CHECK: v0 = vmux(q[[Q070]],v2,v1)
|
|
define <128 x i8> @test_07(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp ule <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_08:
|
|
; CHECK: q[[Q080:[0-3]]] = vcmp.gt(v0.ub,v1.ub)
|
|
; CHECK: v0 = vmux(q[[Q080]],v1,v2)
|
|
define <128 x i8> @test_08(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp ugt <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_09:
|
|
; CHECK: q[[Q090:[0-3]]] = vcmp.gt(v1.ub,v0.ub)
|
|
; CHECK: v0 = vmux(q[[Q090]],v2,v1)
|
|
define <128 x i8> @test_09(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%t0 = icmp uge <128 x i8> %v0, %v1
|
|
%t1 = select <128 x i1> %t0, <128 x i8> %v1, <128 x i8> %v2
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0a:
|
|
; CHECK: q[[Q0A0:[0-3]]] &= vcmp.eq(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0A0]],v0,v1)
|
|
define <128 x i8> @test_0a(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp eq <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = and <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0b:
|
|
; CHECK: q[[Q0B0:[0-3]]] |= vcmp.eq(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0B0]],v0,v1)
|
|
define <128 x i8> @test_0b(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp eq <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = or <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0c:
|
|
; CHECK: q[[Q0C0:[0-3]]] ^= vcmp.eq(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0C0]],v0,v1)
|
|
define <128 x i8> @test_0c(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp eq <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = xor <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0d:
|
|
; CHECK: q[[Q0D0:[0-3]]] &= vcmp.gt(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0D0]],v0,v1)
|
|
define <128 x i8> @test_0d(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp sgt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = and <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0e:
|
|
; CHECK: q[[Q0E0:[0-3]]] |= vcmp.gt(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0E0]],v0,v1)
|
|
define <128 x i8> @test_0e(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp sgt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = or <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0f:
|
|
; CHECK: q[[Q0F0:[0-3]]] ^= vcmp.gt(v0.b,v1.b)
|
|
; CHECK: v0 = vmux(q[[Q0F0]],v0,v1)
|
|
define <128 x i8> @test_0f(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp sgt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = xor <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0g:
|
|
; CHECK: q[[Q0G0:[0-3]]] &= vcmp.gt(v0.ub,v1.ub)
|
|
; CHECK: v0 = vmux(q[[Q0G0]],v0,v1)
|
|
define <128 x i8> @test_0g(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp ugt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = and <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0h:
|
|
; CHECK: q[[Q0H0:[0-3]]] |= vcmp.gt(v0.ub,v1.ub)
|
|
; CHECK: v0 = vmux(q[[Q0H0]],v0,v1)
|
|
define <128 x i8> @test_0h(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp ugt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = or <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_0i:
|
|
; CHECK: q[[Q0I0:[0-3]]] ^= vcmp.gt(v0.ub,v1.ub)
|
|
; CHECK: v0 = vmux(q[[Q0I0]],v0,v1)
|
|
define <128 x i8> @test_0i(<128 x i8> %v0, <128 x i8> %v1, <128 x i8> %v2) #0 {
|
|
%q0 = icmp ugt <128 x i8> %v0, %v1
|
|
%q1 = trunc <128 x i8> %v2 to <128 x i1>
|
|
%q2 = xor <128 x i1> %q0, %q1
|
|
%t1 = select <128 x i1> %q2, <128 x i8> %v0, <128 x i8> %v1
|
|
ret <128 x i8> %t1
|
|
}
|
|
|
|
; --- Half
|
|
|
|
; CHECK-LABEL: test_10:
|
|
; CHECK: q[[Q100:[0-3]]] = vcmp.eq(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q100]],v1,v2)
|
|
define <64 x i16> @test_10(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp eq <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_11:
|
|
; CHECK: q[[Q110:[0-3]]] = vcmp.eq(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q110]],v2,v1)
|
|
define <64 x i16> @test_11(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp ne <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_12:
|
|
; CHECK: q[[Q120:[0-3]]] = vcmp.gt(v1.h,v0.h)
|
|
; CHECK: v0 = vmux(q[[Q120]],v1,v2)
|
|
define <64 x i16> @test_12(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp slt <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_13:
|
|
; CHECK: q[[Q130:[0-3]]] = vcmp.gt(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q130]],v2,v1)
|
|
define <64 x i16> @test_13(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp sle <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_14:
|
|
; CHECK: q[[Q140:[0-3]]] = vcmp.gt(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q140]],v1,v2)
|
|
define <64 x i16> @test_14(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp sgt <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_15:
|
|
; CHECK: q[[Q150:[0-3]]] = vcmp.gt(v1.h,v0.h)
|
|
; CHECK: v0 = vmux(q[[Q150]],v2,v1)
|
|
define <64 x i16> @test_15(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp sge <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_16:
|
|
; CHECK: q[[Q160:[0-3]]] = vcmp.gt(v1.uh,v0.uh)
|
|
; CHECK: v0 = vmux(q[[Q160]],v1,v2)
|
|
define <64 x i16> @test_16(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp ult <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_17:
|
|
; CHECK: q[[Q170:[0-3]]] = vcmp.gt(v0.uh,v1.uh)
|
|
; CHECK: v0 = vmux(q[[Q170]],v2,v1)
|
|
define <64 x i16> @test_17(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp ule <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_18:
|
|
; CHECK: q[[Q180:[0-3]]] = vcmp.gt(v0.uh,v1.uh)
|
|
; CHECK: v0 = vmux(q[[Q180]],v1,v2)
|
|
define <64 x i16> @test_18(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp ugt <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_19:
|
|
; CHECK: q[[Q190:[0-3]]] = vcmp.gt(v1.uh,v0.uh)
|
|
; CHECK: v0 = vmux(q[[Q190]],v2,v1)
|
|
define <64 x i16> @test_19(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%t0 = icmp uge <64 x i16> %v0, %v1
|
|
%t1 = select <64 x i1> %t0, <64 x i16> %v1, <64 x i16> %v2
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1a:
|
|
; CHECK: q[[Q1A0:[0-3]]] &= vcmp.eq(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1A0]],v0,v1)
|
|
define <64 x i16> @test_1a(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp eq <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = and <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1b:
|
|
; CHECK: q[[Q1B0:[0-3]]] |= vcmp.eq(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1B0]],v0,v1)
|
|
define <64 x i16> @test_1b(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp eq <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = or <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1c:
|
|
; CHECK: q[[Q1C0:[0-3]]] ^= vcmp.eq(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1C0]],v0,v1)
|
|
define <64 x i16> @test_1c(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp eq <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = xor <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1d:
|
|
; CHECK: q[[Q1D0:[0-3]]] &= vcmp.gt(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1D0]],v0,v1)
|
|
define <64 x i16> @test_1d(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp sgt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = and <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1e:
|
|
; CHECK: q[[Q1E0:[0-3]]] |= vcmp.gt(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1E0]],v0,v1)
|
|
define <64 x i16> @test_1e(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp sgt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = or <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1f:
|
|
; CHECK: q[[Q1F0:[0-3]]] ^= vcmp.gt(v0.h,v1.h)
|
|
; CHECK: v0 = vmux(q[[Q1F0]],v0,v1)
|
|
define <64 x i16> @test_1f(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp sgt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = xor <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1g:
|
|
; CHECK: q[[Q1G0:[0-3]]] &= vcmp.gt(v0.uh,v1.uh)
|
|
; CHECK: v0 = vmux(q[[Q1G0]],v0,v1)
|
|
define <64 x i16> @test_1g(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp ugt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = and <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1h:
|
|
; CHECK: q[[Q1H0:[0-3]]] |= vcmp.gt(v0.uh,v1.uh)
|
|
; CHECK: v0 = vmux(q[[Q1H0]],v0,v1)
|
|
define <64 x i16> @test_1h(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp ugt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = or <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_1i:
|
|
; CHECK: q[[Q1I0:[0-3]]] ^= vcmp.gt(v0.uh,v1.uh)
|
|
; CHECK: v0 = vmux(q[[Q1I0]],v0,v1)
|
|
define <64 x i16> @test_1i(<64 x i16> %v0, <64 x i16> %v1, <64 x i16> %v2) #0 {
|
|
%q0 = icmp ugt <64 x i16> %v0, %v1
|
|
%q1 = trunc <64 x i16> %v2 to <64 x i1>
|
|
%q2 = xor <64 x i1> %q0, %q1
|
|
%t1 = select <64 x i1> %q2, <64 x i16> %v0, <64 x i16> %v1
|
|
ret <64 x i16> %t1
|
|
}
|
|
|
|
; --- Word
|
|
|
|
; CHECK-LABEL: test_20:
|
|
; CHECK: q[[Q200:[0-3]]] = vcmp.eq(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q200]],v1,v2)
|
|
define <32 x i32> @test_20(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp eq <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_21:
|
|
; CHECK: q[[Q210:[0-3]]] = vcmp.eq(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q210]],v2,v1)
|
|
define <32 x i32> @test_21(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp ne <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_22:
|
|
; CHECK: q[[Q220:[0-3]]] = vcmp.gt(v1.w,v0.w)
|
|
; CHECK: v0 = vmux(q[[Q220]],v1,v2)
|
|
define <32 x i32> @test_22(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp slt <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_23:
|
|
; CHECK: q[[Q230:[0-3]]] = vcmp.gt(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q230]],v2,v1)
|
|
define <32 x i32> @test_23(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp sle <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_24:
|
|
; CHECK: q[[Q240:[0-3]]] = vcmp.gt(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q240]],v1,v2)
|
|
define <32 x i32> @test_24(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp sgt <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_25:
|
|
; CHECK: q[[Q250:[0-3]]] = vcmp.gt(v1.w,v0.w)
|
|
; CHECK: v0 = vmux(q[[Q250]],v2,v1)
|
|
define <32 x i32> @test_25(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp sge <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_26:
|
|
; CHECK: q[[Q260:[0-3]]] = vcmp.gt(v1.uw,v0.uw)
|
|
; CHECK: v0 = vmux(q[[Q260]],v1,v2)
|
|
define <32 x i32> @test_26(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp ult <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_27:
|
|
; CHECK: q[[Q270:[0-3]]] = vcmp.gt(v0.uw,v1.uw)
|
|
; CHECK: v0 = vmux(q[[Q270]],v2,v1)
|
|
define <32 x i32> @test_27(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp ule <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_28:
|
|
; CHECK: q[[Q280:[0-3]]] = vcmp.gt(v0.uw,v1.uw)
|
|
; CHECK: v0 = vmux(q[[Q280]],v1,v2)
|
|
define <32 x i32> @test_28(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp ugt <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_29:
|
|
; CHECK: q[[Q290:[0-3]]] = vcmp.gt(v1.uw,v0.uw)
|
|
; CHECK: v0 = vmux(q[[Q290]],v2,v1)
|
|
define <32 x i32> @test_29(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%t0 = icmp uge <32 x i32> %v0, %v1
|
|
%t1 = select <32 x i1> %t0, <32 x i32> %v1, <32 x i32> %v2
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2a:
|
|
; CHECK: q[[Q2A0:[0-3]]] &= vcmp.eq(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2A0]],v0,v1)
|
|
define <32 x i32> @test_2a(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp eq <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = and <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2b:
|
|
; CHECK: q[[Q2B0:[0-3]]] |= vcmp.eq(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2B0]],v0,v1)
|
|
define <32 x i32> @test_2b(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp eq <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = or <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2c:
|
|
; CHECK: q[[Q2C0:[0-3]]] ^= vcmp.eq(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2C0]],v0,v1)
|
|
define <32 x i32> @test_2c(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp eq <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = xor <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2d:
|
|
; CHECK: q[[Q2D0:[0-3]]] &= vcmp.gt(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2D0]],v0,v1)
|
|
define <32 x i32> @test_2d(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp sgt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = and <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2e:
|
|
; CHECK: q[[Q2E0:[0-3]]] |= vcmp.gt(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2E0]],v0,v1)
|
|
define <32 x i32> @test_2e(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp sgt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = or <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2f:
|
|
; CHECK: q[[Q2F0:[0-3]]] ^= vcmp.gt(v0.w,v1.w)
|
|
; CHECK: v0 = vmux(q[[Q2F0]],v0,v1)
|
|
define <32 x i32> @test_2f(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp sgt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = xor <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2g:
|
|
; CHECK: q[[Q2G0:[0-3]]] &= vcmp.gt(v0.uw,v1.uw)
|
|
; CHECK: v0 = vmux(q[[Q2G0]],v0,v1)
|
|
define <32 x i32> @test_2g(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp ugt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = and <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2h:
|
|
; CHECK: q[[Q2H0:[0-3]]] |= vcmp.gt(v0.uw,v1.uw)
|
|
; CHECK: v0 = vmux(q[[Q2H0]],v0,v1)
|
|
define <32 x i32> @test_2h(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp ugt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = or <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
; CHECK-LABEL: test_2i:
|
|
; CHECK: q[[Q2I0:[0-3]]] ^= vcmp.gt(v0.uw,v1.uw)
|
|
; CHECK: v0 = vmux(q[[Q2I0]],v0,v1)
|
|
define <32 x i32> @test_2i(<32 x i32> %v0, <32 x i32> %v1, <32 x i32> %v2) #0 {
|
|
%q0 = icmp ugt <32 x i32> %v0, %v1
|
|
%q1 = trunc <32 x i32> %v2 to <32 x i1>
|
|
%q2 = xor <32 x i1> %q0, %q1
|
|
%t1 = select <32 x i1> %q2, <32 x i32> %v0, <32 x i32> %v1
|
|
ret <32 x i32> %t1
|
|
}
|
|
|
|
attributes #0 = { nounwind readnone "target-cpu"="hexagonv60" "target-features"="+hvx,+hvx-length128b" }
|