1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 19:12:56 +02:00

[SVE] Fix some logical arithmetic tests

There were some right-shift tests in

  CodeGen/AArch64/sve-int-arith-imm.ll

that were being folded away because we were shifting all the bits
out to the right. I've updated the tests to ensure this doesn't
happen.
This commit is contained in:
David Sherwood 2021-01-26 10:59:36 +00:00
parent b39ef35f86
commit 569d971cc6

View File

@ -1,3 +1,4 @@
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=aarch64-linux-gnu -mattr=+sve < %s 2>%t | FileCheck %s
; RUN: FileCheck --check-prefix=WARN --allow-empty %s <%t
@ -8,9 +9,10 @@
; SMAX
;
define <vscale x 16 x i8> @smax_i8_pos(<vscale x 16 x i8> %a) {
; CHECK-LABEL: smax_i8_pos
; CHECK: smax z0.b, z0.b, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i8_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.b, z0.b, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 27, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 16 x i8> %a, %splat
@ -19,9 +21,10 @@ define <vscale x 16 x i8> @smax_i8_pos(<vscale x 16 x i8> %a) {
}
define <vscale x 16 x i8> @smax_i8_neg(<vscale x 16 x i8> %a) {
; CHECK-LABEL: smax_i8_neg
; CHECK: smax z0.b, z0.b, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i8_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.b, z0.b, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 -58, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 16 x i8> %a, %splat
@ -30,9 +33,10 @@ define <vscale x 16 x i8> @smax_i8_neg(<vscale x 16 x i8> %a) {
}
define <vscale x 8 x i16> @smax_i16_pos(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smax_i16_pos
; CHECK: smax z0.h, z0.h, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i16_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.h, z0.h, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 27, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 8 x i16> %a, %splat
@ -41,9 +45,10 @@ define <vscale x 8 x i16> @smax_i16_pos(<vscale x 8 x i16> %a) {
}
define <vscale x 8 x i16> @smax_i16_neg(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smax_i16_neg
; CHECK: smax z0.h, z0.h, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i16_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.h, z0.h, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 -58, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 8 x i16> %a, %splat
@ -53,7 +58,8 @@ define <vscale x 8 x i16> @smax_i16_neg(<vscale x 8 x i16> %a) {
define <vscale x 8 x i16> @smax_i16_out_of_range(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smax_i16_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.h, w8
; CHECK-NEXT: ptrue p0.h
; CHECK-NEXT: smax z0.h, p0/m, z0.h, z1.h
@ -66,9 +72,10 @@ define <vscale x 8 x i16> @smax_i16_out_of_range(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @smax_i32_pos(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smax_i32_pos
; CHECK: smax z0.s, z0.s, #27
; CHECK: ret
; CHECK-LABEL: smax_i32_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.s, z0.s, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 27, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 4 x i32> %a, %splat
@ -77,9 +84,10 @@ define <vscale x 4 x i32> @smax_i32_pos(<vscale x 4 x i32> %a) {
}
define <vscale x 4 x i32> @smax_i32_neg(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smax_i32_neg
; CHECK: smax z0.s, z0.s, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i32_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.s, z0.s, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 -58, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 4 x i32> %a, %splat
@ -89,7 +97,8 @@ define <vscale x 4 x i32> @smax_i32_neg(<vscale x 4 x i32> %a) {
define <vscale x 4 x i32> @smax_i32_out_of_range(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smax_i32_out_of_range:
; CHECK: mov w8, #-129
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #-129
; CHECK-NEXT: mov z1.s, w8
; CHECK-NEXT: ptrue p0.s
; CHECK-NEXT: smax z0.s, p0/m, z0.s, z1.s
@ -102,9 +111,10 @@ define <vscale x 4 x i32> @smax_i32_out_of_range(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @smax_i64_pos(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smax_i64_pos
; CHECK: smax z0.d, z0.d, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i64_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.d, z0.d, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 27, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 2 x i64> %a, %splat
@ -113,9 +123,10 @@ define <vscale x 2 x i64> @smax_i64_pos(<vscale x 2 x i64> %a) {
}
define <vscale x 2 x i64> @smax_i64_neg(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smax_i64_neg
; CHECK: smax z0.d, z0.d, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smax_i64_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smax z0.d, z0.d, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 -58, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp sgt <vscale x 2 x i64> %a, %splat
@ -125,7 +136,8 @@ define <vscale x 2 x i64> @smax_i64_neg(<vscale x 2 x i64> %a) {
define <vscale x 2 x i64> @smax_i64_out_of_range(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smax_i64_out_of_range:
; CHECK: mov w8, #65535
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #65535
; CHECK-NEXT: mov z1.d, x8
; CHECK-NEXT: ptrue p0.d
; CHECK-NEXT: smax z0.d, p0/m, z0.d, z1.d
@ -141,9 +153,10 @@ define <vscale x 2 x i64> @smax_i64_out_of_range(<vscale x 2 x i64> %a) {
; SMIN
;
define <vscale x 16 x i8> @smin_i8_pos(<vscale x 16 x i8> %a) {
; CHECK-LABEL: smin_i8_pos
; CHECK: smin z0.b, z0.b, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i8_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.b, z0.b, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 27, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp slt <vscale x 16 x i8> %a, %splat
@ -152,9 +165,10 @@ define <vscale x 16 x i8> @smin_i8_pos(<vscale x 16 x i8> %a) {
}
define <vscale x 16 x i8> @smin_i8_neg(<vscale x 16 x i8> %a) {
; CHECK-LABEL: smin_i8_neg
; CHECK: smin z0.b, z0.b, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i8_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.b, z0.b, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 -58, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp slt <vscale x 16 x i8> %a, %splat
@ -163,9 +177,10 @@ define <vscale x 16 x i8> @smin_i8_neg(<vscale x 16 x i8> %a) {
}
define <vscale x 8 x i16> @smin_i16_pos(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smin_i16_pos
; CHECK: smin z0.h, z0.h, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i16_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.h, z0.h, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 27, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp slt <vscale x 8 x i16> %a, %splat
@ -174,9 +189,10 @@ define <vscale x 8 x i16> @smin_i16_pos(<vscale x 8 x i16> %a) {
}
define <vscale x 8 x i16> @smin_i16_neg(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smin_i16_neg
; CHECK: smin z0.h, z0.h, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i16_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.h, z0.h, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 -58, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp slt <vscale x 8 x i16> %a, %splat
@ -186,7 +202,8 @@ define <vscale x 8 x i16> @smin_i16_neg(<vscale x 8 x i16> %a) {
define <vscale x 8 x i16> @smin_i16_out_of_range(<vscale x 8 x i16> %a) {
; CHECK-LABEL: smin_i16_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.h, w8
; CHECK-NEXT: ptrue p0.h
; CHECK-NEXT: smin z0.h, p0/m, z0.h, z1.h
@ -199,9 +216,10 @@ define <vscale x 8 x i16> @smin_i16_out_of_range(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @smin_i32_pos(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smin_i32_pos
; CHECK: smin z0.s, z0.s, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i32_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.s, z0.s, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 27, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp slt <vscale x 4 x i32> %a, %splat
@ -210,9 +228,10 @@ define <vscale x 4 x i32> @smin_i32_pos(<vscale x 4 x i32> %a) {
}
define <vscale x 4 x i32> @smin_i32_neg(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smin_i32_neg
; CHECK: smin z0.s, z0.s, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i32_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.s, z0.s, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 -58, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp slt <vscale x 4 x i32> %a, %splat
@ -222,7 +241,8 @@ define <vscale x 4 x i32> @smin_i32_neg(<vscale x 4 x i32> %a) {
define <vscale x 4 x i32> @smin_i32_out_of_range(<vscale x 4 x i32> %a) {
; CHECK-LABEL: smin_i32_out_of_range:
; CHECK: mov w8, #-129
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #-129
; CHECK-NEXT: mov z1.s, w8
; CHECK-NEXT: ptrue p0.s
; CHECK-NEXT: smin z0.s, p0/m, z0.s, z1.s
@ -235,9 +255,10 @@ define <vscale x 4 x i32> @smin_i32_out_of_range(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @smin_i64_pos(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smin_i64_pos
; CHECK: smin z0.d, z0.d, #27
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i64_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.d, z0.d, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 27, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp slt <vscale x 2 x i64> %a, %splat
@ -246,9 +267,10 @@ define <vscale x 2 x i64> @smin_i64_pos(<vscale x 2 x i64> %a) {
}
define <vscale x 2 x i64> @smin_i64_neg(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smin_i64_neg
; CHECK: smin z0.d, z0.d, #-58
; CHECK-NEXT: ret
; CHECK-LABEL: smin_i64_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: smin z0.d, z0.d, #-58
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 -58, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp slt <vscale x 2 x i64> %a, %splat
@ -258,7 +280,8 @@ define <vscale x 2 x i64> @smin_i64_neg(<vscale x 2 x i64> %a) {
define <vscale x 2 x i64> @smin_i64_out_of_range(<vscale x 2 x i64> %a) {
; CHECK-LABEL: smin_i64_out_of_range:
; CHECK: mov w8, #65535
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #65535
; CHECK-NEXT: mov z1.d, x8
; CHECK-NEXT: ptrue p0.d
; CHECK-NEXT: smin z0.d, p0/m, z0.d, z1.d
@ -274,9 +297,10 @@ define <vscale x 2 x i64> @smin_i64_out_of_range(<vscale x 2 x i64> %a) {
; UMAX
;
define <vscale x 16 x i8> @umax_i8_pos(<vscale x 16 x i8> %a) {
; CHECK-LABEL: umax_i8_pos
; CHECK: umax z0.b, z0.b, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umax_i8_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umax z0.b, z0.b, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 27, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp ugt <vscale x 16 x i8> %a, %splat
@ -285,9 +309,10 @@ define <vscale x 16 x i8> @umax_i8_pos(<vscale x 16 x i8> %a) {
}
define <vscale x 16 x i8> @umax_i8_large(<vscale x 16 x i8> %a) {
; CHECK-LABEL: umax_i8_large
; CHECK: umax z0.b, z0.b, #129
; CHECK-NEXT: ret
; CHECK-LABEL: umax_i8_large:
; CHECK: // %bb.0:
; CHECK-NEXT: umax z0.b, z0.b, #129
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 129, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp ugt <vscale x 16 x i8> %a, %splat
@ -296,9 +321,10 @@ define <vscale x 16 x i8> @umax_i8_large(<vscale x 16 x i8> %a) {
}
define <vscale x 8 x i16> @umax_i16_pos(<vscale x 8 x i16> %a) {
; CHECK-LABEL: umax_i16_pos
; CHECK: umax z0.h, z0.h, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umax_i16_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umax z0.h, z0.h, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 27, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp ugt <vscale x 8 x i16> %a, %splat
@ -308,7 +334,8 @@ define <vscale x 8 x i16> @umax_i16_pos(<vscale x 8 x i16> %a) {
define <vscale x 8 x i16> @umax_i16_out_of_range(<vscale x 8 x i16> %a) {
; CHECK-LABEL: umax_i16_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.h, w8
; CHECK-NEXT: ptrue p0.h
; CHECK-NEXT: umax z0.h, p0/m, z0.h, z1.h
@ -321,9 +348,10 @@ define <vscale x 8 x i16> @umax_i16_out_of_range(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @umax_i32_pos(<vscale x 4 x i32> %a) {
; CHECK-LABEL: umax_i32_pos
; CHECK: umax z0.s, z0.s, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umax_i32_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umax z0.s, z0.s, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 27, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp ugt <vscale x 4 x i32> %a, %splat
@ -333,7 +361,8 @@ define <vscale x 4 x i32> @umax_i32_pos(<vscale x 4 x i32> %a) {
define <vscale x 4 x i32> @umax_i32_out_of_range(<vscale x 4 x i32> %a) {
; CHECK-LABEL: umax_i32_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.s, w8
; CHECK-NEXT: ptrue p0.s
; CHECK-NEXT: umax z0.s, p0/m, z0.s, z1.s
@ -346,9 +375,10 @@ define <vscale x 4 x i32> @umax_i32_out_of_range(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @umax_i64_pos(<vscale x 2 x i64> %a) {
; CHECK-LABEL: umax_i64_pos
; CHECK: umax z0.d, z0.d, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umax_i64_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umax z0.d, z0.d, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 27, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp ugt <vscale x 2 x i64> %a, %splat
@ -358,7 +388,8 @@ define <vscale x 2 x i64> @umax_i64_pos(<vscale x 2 x i64> %a) {
define <vscale x 2 x i64> @umax_i64_out_of_range(<vscale x 2 x i64> %a) {
; CHECK-LABEL: umax_i64_out_of_range:
; CHECK: mov w8, #65535
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #65535
; CHECK-NEXT: mov z1.d, x8
; CHECK-NEXT: ptrue p0.d
; CHECK-NEXT: umax z0.d, p0/m, z0.d, z1.d
@ -374,9 +405,10 @@ define <vscale x 2 x i64> @umax_i64_out_of_range(<vscale x 2 x i64> %a) {
; UMIN
;
define <vscale x 16 x i8> @umin_i8_pos(<vscale x 16 x i8> %a) {
; CHECK-LABEL: umin_i8_pos
; CHECK: umin z0.b, z0.b, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umin_i8_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umin z0.b, z0.b, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 27, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp ult <vscale x 16 x i8> %a, %splat
@ -385,9 +417,10 @@ define <vscale x 16 x i8> @umin_i8_pos(<vscale x 16 x i8> %a) {
}
define <vscale x 16 x i8> @umin_i8_large(<vscale x 16 x i8> %a) {
; CHECK-LABEL: umin_i8_large
; CHECK: umin z0.b, z0.b, #129
; CHECK-NEXT: ret
; CHECK-LABEL: umin_i8_large:
; CHECK: // %bb.0:
; CHECK-NEXT: umin z0.b, z0.b, #129
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 129, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%cmp = icmp ult <vscale x 16 x i8> %a, %splat
@ -396,9 +429,10 @@ define <vscale x 16 x i8> @umin_i8_large(<vscale x 16 x i8> %a) {
}
define <vscale x 8 x i16> @umin_i16_pos(<vscale x 8 x i16> %a) {
; CHECK-LABEL: umin_i16_pos
; CHECK: umin z0.h, z0.h, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umin_i16_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umin z0.h, z0.h, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 27, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%cmp = icmp ult <vscale x 8 x i16> %a, %splat
@ -408,7 +442,8 @@ define <vscale x 8 x i16> @umin_i16_pos(<vscale x 8 x i16> %a) {
define <vscale x 8 x i16> @umin_i16_out_of_range(<vscale x 8 x i16> %a) {
; CHECK-LABEL: umin_i16_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.h, w8
; CHECK-NEXT: ptrue p0.h
; CHECK-NEXT: umin z0.h, p0/m, z0.h, z1.h
@ -421,9 +456,10 @@ define <vscale x 8 x i16> @umin_i16_out_of_range(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @umin_i32_pos(<vscale x 4 x i32> %a) {
; CHECK-LABEL: umin_i32_pos
; CHECK: umin z0.s, z0.s, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umin_i32_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umin z0.s, z0.s, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 27, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%cmp = icmp ult <vscale x 4 x i32> %a, %splat
@ -433,7 +469,8 @@ define <vscale x 4 x i32> @umin_i32_pos(<vscale x 4 x i32> %a) {
define <vscale x 4 x i32> @umin_i32_out_of_range(<vscale x 4 x i32> %a) {
; CHECK-LABEL: umin_i32_out_of_range:
; CHECK: mov w8, #257
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #257
; CHECK-NEXT: mov z1.s, w8
; CHECK-NEXT: ptrue p0.s
; CHECK-NEXT: umin z0.s, p0/m, z0.s, z1.s
@ -446,9 +483,10 @@ define <vscale x 4 x i32> @umin_i32_out_of_range(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @umin_i64_pos(<vscale x 2 x i64> %a) {
; CHECK-LABEL: umin_i64_pos
; CHECK: umin z0.d, z0.d, #27
; CHECK-NEXT: ret
; CHECK-LABEL: umin_i64_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: umin z0.d, z0.d, #27
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 27, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%cmp = icmp ult <vscale x 2 x i64> %a, %splat
@ -458,7 +496,8 @@ define <vscale x 2 x i64> @umin_i64_pos(<vscale x 2 x i64> %a) {
define <vscale x 2 x i64> @umin_i64_out_of_range(<vscale x 2 x i64> %a) {
; CHECK-LABEL: umin_i64_out_of_range:
; CHECK: mov w8, #65535
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #65535
; CHECK-NEXT: mov z1.d, x8
; CHECK-NEXT: ptrue p0.d
; CHECK-NEXT: umin z0.d, p0/m, z0.d, z1.d
@ -474,9 +513,10 @@ define <vscale x 2 x i64> @umin_i64_out_of_range(<vscale x 2 x i64> %a) {
; MUL
;
define <vscale x 16 x i8> @mul_i8_neg(<vscale x 16 x i8> %a) {
; CHECK-LABEL: mul_i8_neg
; CHECK: mul z0.b, z0.b, #-17
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i8_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.b, z0.b, #-17
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 -17, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%res = mul <vscale x 16 x i8> %a, %splat
@ -484,9 +524,10 @@ define <vscale x 16 x i8> @mul_i8_neg(<vscale x 16 x i8> %a) {
}
define <vscale x 16 x i8> @mul_i8_pos(<vscale x 16 x i8> %a) {
; CHECK-LABEL: mul_i8_pos
; CHECK: mul z0.b, z0.b, #105
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i8_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.b, z0.b, #105
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 105, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%res = mul <vscale x 16 x i8> %a, %splat
@ -494,9 +535,10 @@ define <vscale x 16 x i8> @mul_i8_pos(<vscale x 16 x i8> %a) {
}
define <vscale x 8 x i16> @mul_i16_neg(<vscale x 8 x i16> %a) {
; CHECK-LABEL: mul_i16_neg
; CHECK: mul z0.h, z0.h, #-17
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i16_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.h, z0.h, #-17
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 -17, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%res = mul <vscale x 8 x i16> %a, %splat
@ -504,9 +546,10 @@ define <vscale x 8 x i16> @mul_i16_neg(<vscale x 8 x i16> %a) {
}
define <vscale x 8 x i16> @mul_i16_pos(<vscale x 8 x i16> %a) {
; CHECK-LABEL: mul_i16_pos
; CHECK: mul z0.h, z0.h, #105
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i16_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.h, z0.h, #105
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 105, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%res = mul <vscale x 8 x i16> %a, %splat
@ -514,9 +557,10 @@ define <vscale x 8 x i16> @mul_i16_pos(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @mul_i32_neg(<vscale x 4 x i32> %a) {
; CHECK-LABEL: mul_i32_neg
; CHECK: mul z0.s, z0.s, #-17
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i32_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.s, z0.s, #-17
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 -17, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%res = mul <vscale x 4 x i32> %a, %splat
@ -524,9 +568,10 @@ define <vscale x 4 x i32> @mul_i32_neg(<vscale x 4 x i32> %a) {
}
define <vscale x 4 x i32> @mul_i32_pos(<vscale x 4 x i32> %a) {
; CHECK-LABEL: mul_i32_pos
; CHECK: mul z0.s, z0.s, #105
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i32_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.s, z0.s, #105
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 105, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%res = mul <vscale x 4 x i32> %a, %splat
@ -534,9 +579,10 @@ define <vscale x 4 x i32> @mul_i32_pos(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @mul_i64_neg(<vscale x 2 x i64> %a) {
; CHECK-LABEL: mul_i64_neg
; CHECK: mul z0.d, z0.d, #-17
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i64_neg:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.d, z0.d, #-17
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 -17, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%res = mul <vscale x 2 x i64> %a, %splat
@ -544,9 +590,10 @@ define <vscale x 2 x i64> @mul_i64_neg(<vscale x 2 x i64> %a) {
}
define <vscale x 2 x i64> @mul_i64_pos(<vscale x 2 x i64> %a) {
; CHECK-LABEL: mul_i64_pos
; CHECK: mul z0.d, z0.d, #105
; CHECK-NEXT: ret
; CHECK-LABEL: mul_i64_pos:
; CHECK: // %bb.0:
; CHECK-NEXT: mul z0.d, z0.d, #105
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 105, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%res = mul <vscale x 2 x i64> %a, %splat
@ -554,11 +601,13 @@ define <vscale x 2 x i64> @mul_i64_pos(<vscale x 2 x i64> %a) {
}
define <vscale x 8 x i16> @mul_i16_range(<vscale x 8 x i16> %a) {
; CHECK-LABEL: mul_i16_range
; CHECK: mov w[[W:[0-9]+]], #255
; CHECK-NEXT: mov z1.h, w[[W]]
; CHECK: ptrue p0.h
; CHECK-NEXT: mul z0.h, p0/m, z0.h, z1.h
; CHECK-LABEL: mul_i16_range:
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #255
; CHECK-NEXT: mov z1.h, w8
; CHECK-NEXT: ptrue p0.h
; CHECK-NEXT: mul z0.h, p0/m, z0.h, z1.h
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 255, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%res = mul <vscale x 8 x i16> %a, %splat
@ -566,11 +615,13 @@ define <vscale x 8 x i16> @mul_i16_range(<vscale x 8 x i16> %a) {
}
define <vscale x 4 x i32> @mul_i32_range(<vscale x 4 x i32> %a) {
; CHECK-LABEL: mul_i32_range
; CHECK: mov w[[W:[0-9]+]], #255
; CHECK-NEXT: mov z1.s, w[[W]]
; CHECK: ptrue p0.s
; CHECK-NEXT: mul z0.s, p0/m, z0.s, z1.s
; CHECK-LABEL: mul_i32_range:
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #255
; CHECK-NEXT: mov z1.s, w8
; CHECK-NEXT: ptrue p0.s
; CHECK-NEXT: mul z0.s, p0/m, z0.s, z1.s
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 255, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%res = mul <vscale x 4 x i32> %a, %splat
@ -578,11 +629,13 @@ define <vscale x 4 x i32> @mul_i32_range(<vscale x 4 x i32> %a) {
}
define <vscale x 2 x i64> @mul_i64_range(<vscale x 2 x i64> %a) {
; CHECK-LABEL: mul_i64_range
; CHECK: mov w[[W:[0-9]+]], #255
; CHECK-NEXT: mov z1.d, x[[W]]
; CHECK: ptrue p0.d
; CHECK-NEXT: mul z0.d, p0/m, z0.d, z1.d
; CHECK-LABEL: mul_i64_range:
; CHECK: // %bb.0:
; CHECK-NEXT: mov w8, #255
; CHECK-NEXT: mov z1.d, x8
; CHECK-NEXT: ptrue p0.d
; CHECK-NEXT: mul z0.d, p0/m, z0.d, z1.d
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 255, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%res = mul <vscale x 2 x i64> %a, %splat
@ -592,40 +645,44 @@ define <vscale x 2 x i64> @mul_i64_range(<vscale x 2 x i64> %a) {
; ASR
define <vscale x 16 x i8> @asr_i8(<vscale x 16 x i8> %a){
; CHECK-LABEL: @asr_i8
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 8, i32 0
; CHECK-LABEL: asr_i8:
; CHECK: // %bb.0:
; CHECK-NEXT: asr z0.b, z0.b, #7
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 7, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%lshr = ashr <vscale x 16 x i8> %a, %splat
ret <vscale x 16 x i8> %lshr
}
define <vscale x 8 x i16> @asr_i16(<vscale x 8 x i16> %a){
; CHECK-LABEL: @asr_i16
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 16, i32 0
; CHECK-LABEL: asr_i16:
; CHECK: // %bb.0:
; CHECK-NEXT: asr z0.h, z0.h, #15
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 15, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%ashr = ashr <vscale x 8 x i16> %a, %splat
ret <vscale x 8 x i16> %ashr
}
define <vscale x 4 x i32> @asr_i32(<vscale x 4 x i32> %a){
; CHECK-LABEL: @asr_i32
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 32, i32 0
; CHECK-LABEL: asr_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: asr z0.s, z0.s, #31
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 31, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%ashr = ashr <vscale x 4 x i32> %a, %splat
ret <vscale x 4 x i32> %ashr
}
define <vscale x 2 x i64> @asr_i64(<vscale x 2 x i64> %a){
; CHECK-LABEL: @asr_i64
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 64, i32 0
; CHECK-LABEL: asr_i64:
; CHECK: // %bb.0:
; CHECK-NEXT: asr z0.d, z0.d, #63
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 63, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%ashr = ashr <vscale x 2 x i64> %a, %splat
ret <vscale x 2 x i64> %ashr
@ -634,9 +691,10 @@ define <vscale x 2 x i64> @asr_i64(<vscale x 2 x i64> %a){
; LSL
define <vscale x 16 x i8> @lsl_i8(<vscale x 16 x i8> %a){
; CHECK-LABEL: @lsl_i8
; CHECK-DAG: lsl z0.b, z0.b, #7
; CHECK-NEXT: ret
; CHECK-LABEL: lsl_i8:
; CHECK: // %bb.0:
; CHECK-NEXT: lsl z0.b, z0.b, #7
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 7, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%shl = shl <vscale x 16 x i8> %a, %splat
@ -644,9 +702,10 @@ define <vscale x 16 x i8> @lsl_i8(<vscale x 16 x i8> %a){
}
define <vscale x 8 x i16> @lsl_i16(<vscale x 8 x i16> %a){
; CHECK-LABEL: @lsl_i16
; CHECK-DAG: lsl z0.h, z0.h, #15
; CHECK-NEXT: ret
; CHECK-LABEL: lsl_i16:
; CHECK: // %bb.0:
; CHECK-NEXT: lsl z0.h, z0.h, #15
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 15, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%shl = shl <vscale x 8 x i16> %a, %splat
@ -654,9 +713,10 @@ define <vscale x 8 x i16> @lsl_i16(<vscale x 8 x i16> %a){
}
define <vscale x 4 x i32> @lsl_i32(<vscale x 4 x i32> %a){
; CHECK-LABEL: @lsl_i32
; CHECK-DAG: lsl z0.s, z0.s, #31
; CHECK-NEXT: ret
; CHECK-LABEL: lsl_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: lsl z0.s, z0.s, #31
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 31, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%shl = shl <vscale x 4 x i32> %a, %splat
@ -664,9 +724,10 @@ define <vscale x 4 x i32> @lsl_i32(<vscale x 4 x i32> %a){
}
define <vscale x 2 x i64> @lsl_i64(<vscale x 2 x i64> %a){
; CHECK-LABEL: @lsl_i64
; CHECK-DAG: lsl z0.d, z0.d, #63
; CHECK-NEXT: ret
; CHECK-LABEL: lsl_i64:
; CHECK: // %bb.0:
; CHECK-NEXT: lsl z0.d, z0.d, #63
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 63, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%shl = shl <vscale x 2 x i64> %a, %splat
@ -676,40 +737,44 @@ define <vscale x 2 x i64> @lsl_i64(<vscale x 2 x i64> %a){
; LSR
define <vscale x 16 x i8> @lsr_i8(<vscale x 16 x i8> %a){
; CHECK-LABEL: @lsr_i8
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 8, i32 0
; CHECK-LABEL: lsr_i8:
; CHECK: // %bb.0:
; CHECK-NEXT: lsr z0.b, z0.b, #7
; CHECK-NEXT: ret
%elt = insertelement <vscale x 16 x i8> undef, i8 7, i32 0
%splat = shufflevector <vscale x 16 x i8> %elt, <vscale x 16 x i8> undef, <vscale x 16 x i32> zeroinitializer
%lshr = lshr <vscale x 16 x i8> %a, %splat
ret <vscale x 16 x i8> %lshr
}
define <vscale x 8 x i16> @lsr_i16(<vscale x 8 x i16> %a){
; CHECK-LABEL: @lsr_i16
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 16, i32 0
; CHECK-LABEL: lsr_i16:
; CHECK: // %bb.0:
; CHECK-NEXT: lsr z0.h, z0.h, #15
; CHECK-NEXT: ret
%elt = insertelement <vscale x 8 x i16> undef, i16 15, i32 0
%splat = shufflevector <vscale x 8 x i16> %elt, <vscale x 8 x i16> undef, <vscale x 8 x i32> zeroinitializer
%lshr = lshr <vscale x 8 x i16> %a, %splat
ret <vscale x 8 x i16> %lshr
}
define <vscale x 4 x i32> @lsr_i32(<vscale x 4 x i32> %a){
; CHECK-LABEL: @lsr_i32
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 32, i32 0
; CHECK-LABEL: lsr_i32:
; CHECK: // %bb.0:
; CHECK-NEXT: lsr z0.s, z0.s, #31
; CHECK-NEXT: ret
%elt = insertelement <vscale x 4 x i32> undef, i32 31, i32 0
%splat = shufflevector <vscale x 4 x i32> %elt, <vscale x 4 x i32> undef, <vscale x 4 x i32> zeroinitializer
%lshr = lshr <vscale x 4 x i32> %a, %splat
ret <vscale x 4 x i32> %lshr
}
define <vscale x 2 x i64> @lsr_i64(<vscale x 2 x i64> %a){
; CHECK-LABEL: @lsr_i64
; CHECK: // %bb.0:
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 64, i32 0
; CHECK-LABEL: lsr_i64:
; CHECK: // %bb.0:
; CHECK-NEXT: lsr z0.d, z0.d, #63
; CHECK-NEXT: ret
%elt = insertelement <vscale x 2 x i64> undef, i64 63, i32 0
%splat = shufflevector <vscale x 2 x i64> %elt, <vscale x 2 x i64> undef, <vscale x 2 x i32> zeroinitializer
%lshr = lshr <vscale x 2 x i64> %a, %splat
ret <vscale x 2 x i64> %lshr