blob: 66a0e3ef6df9899761529241fda083eb7bf2d3e8 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=aarch64 < %s | FileCheck %s
define <4 x i32> @dup_trunc_sext_v4i32(<4 x i32> %a, <4 x i32> %b, <4 x i32> %x, <4 x i32> %y) {
; CHECK-LABEL: dup_trunc_sext_v4i32:
; CHECK: // %bb.0:
; CHECK-NEXT: cmgt v0.4s, v1.4s, v0.4s
; CHECK-NEXT: dup v0.4s, v0.s[2]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = icmp slt <4 x i32> %a, %b
%splat = shufflevector <4 x i1> %cmp, <4 x i1> poison, <4 x i32> <i32 2, i32 2, i32 2, i32 2>
%sel = select <4 x i1> %splat, <4 x i32> %x, <4 x i32> %y
ret <4 x i32> %sel
}
define <2 x i64> @dup_trunc_sext_v2i64(<2 x i64> %a, <2 x i64> %b, <2 x i64> %x, <2 x i64> %y) {
; CHECK-LABEL: dup_trunc_sext_v2i64:
; CHECK: // %bb.0:
; CHECK-NEXT: cmgt v0.2d, v1.2d, v0.2d
; CHECK-NEXT: dup v0.2d, v0.d[0]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = icmp slt <2 x i64> %a, %b
%splat = shufflevector <2 x i1> %cmp, <2 x i1> poison, <2 x i32> <i32 0, i32 0>
%sel = select <2 x i1> %splat, <2 x i64> %x, <2 x i64> %y
ret <2 x i64> %sel
}
define <4 x float> @dup_trunc_sext_v4f32(<4 x float> %a, <4 x float> %b, <4 x float> %x, <4 x float> %y) {
; CHECK-LABEL: dup_trunc_sext_v4f32:
; CHECK: // %bb.0:
; CHECK-NEXT: fcmge v0.4s, v1.4s, v0.4s
; CHECK-NEXT: dup v0.4s, v0.s[3]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = fcmp ole <4 x float> %a, %b
%splat = shufflevector <4 x i1> %cmp, <4 x i1> poison, <4 x i32> <i32 3, i32 3, i32 3, i32 3>
%sel = select <4 x i1> %splat, <4 x float> %x, <4 x float> %y
ret <4 x float> %sel
}
define <2 x double> @dup_trunc_sext_v2f64(<2 x double> %a, <2 x double> %b, <2 x double> %x, <2 x double> %y) {
; CHECK-LABEL: dup_trunc_sext_v2f64:
; CHECK: // %bb.0:
; CHECK-NEXT: fcmge v0.2d, v1.2d, v0.2d
; CHECK-NEXT: dup v0.2d, v0.d[1]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = fcmp ole <2 x double> %a, %b
%splat = shufflevector <2 x i1> %cmp, <2 x i1> poison, <2 x i32> <i32 1, i32 1>
%sel = select <2 x i1> %splat, <2 x double> %x, <2 x double> %y
ret <2 x double> %sel
}
define <4 x i32> @dup_trunc_sext_v4i32_idx0(<4 x i32> %a, <4 x i32> %b, <4 x i32> %x, <4 x i32> %y) {
; CHECK-LABEL: dup_trunc_sext_v4i32_idx0:
; CHECK: // %bb.0:
; CHECK-NEXT: cmgt v0.4s, v1.4s, v0.4s
; CHECK-NEXT: dup v0.4s, v0.s[0]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = icmp slt <4 x i32> %a, %b
%splat = shufflevector <4 x i1> %cmp, <4 x i1> poison, <4 x i32> zeroinitializer
%sel = select <4 x i1> %splat, <4 x i32> %x, <4 x i32> %y
ret <4 x i32> %sel
}
define <8 x i16> @dup_trunc_sext_v8i16(<8 x i16> %a, <8 x i16> %b, <8 x i16> %x, <8 x i16> %y) {
; CHECK-LABEL: dup_trunc_sext_v8i16:
; CHECK: // %bb.0:
; CHECK-NEXT: cmgt v0.8h, v1.8h, v0.8h
; CHECK-NEXT: dup v0.8h, v0.h[2]
; CHECK-NEXT: bsl v0.16b, v2.16b, v3.16b
; CHECK-NEXT: ret
%cmp = icmp slt <8 x i16> %a, %b
%splat = shufflevector <8 x i1> %cmp, <8 x i1> poison, <8 x i32> <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2>
%sel = select <8 x i1> %splat, <8 x i16> %x, <8 x i16> %y
ret <8 x i16> %sel
}
define <2 x i64> @negative_sext_i32(<2 x i64> %mask) {
; CHECK-LABEL: negative_sext_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: xtn v0.2s, v0.2d
; CHECK-NEXT: dup v0.2s, v0.s[1]
; CHECK-NEXT: sshll v0.2d, v0.2s, #0
; CHECK-NEXT: ret
%trunc = trunc <2 x i64> %mask to <2 x i32>
%splat = shufflevector <2 x i32> %trunc, <2 x i32> poison, <2 x i32> <i32 1, i32 1>
%ext = sext <2 x i32> %splat to <2 x i64>
ret <2 x i64> %ext
}
define <2 x i64> @dup_trunc_zext_i32(<2 x i64> %a) {
; CHECK-LABEL: dup_trunc_zext_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: ushr v0.2d, v0.2d, #32
; CHECK-NEXT: dup v0.2d, v0.d[1]
; CHECK-NEXT: ret
%shifted = lshr <2 x i64> %a, <i64 32, i64 32>
%trunc = trunc <2 x i64> %shifted to <2 x i32>
%splat = shufflevector <2 x i32> %trunc, <2 x i32> poison, <2 x i32> <i32 1, i32 1>
%ext = zext <2 x i32> %splat to <2 x i64>
ret <2 x i64> %ext
}
define <2 x i64> @negative_zext_i32(<2 x i64> %mask) {
; CHECK-LABEL: negative_zext_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: xtn v0.2s, v0.2d
; CHECK-NEXT: dup v0.2s, v0.s[1]
; CHECK-NEXT: ushll v0.2d, v0.2s, #0
; CHECK-NEXT: ret
%trunc = trunc <2 x i64> %mask to <2 x i32>
%splat = shufflevector <2 x i32> %trunc, <2 x i32> poison, <2 x i32> <i32 1, i32 1>
%ext = zext <2 x i32> %splat to <2 x i64>
ret <2 x i64> %ext
}