1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s | FileCheck %s
target triple = "aarch64-unknown-linux-gnu"
define i32 @i8_i32(<vscale x 16 x i8> %a) #0 {
; CHECK-LABEL: i8_i32:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: smov w0, v0.b[15]
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 16 x i8> %a, i32 15
%conv = sext i8 %elt to i32
ret i32 %conv
}
define i64 @i8_i64(<vscale x 16 x i8> %a) #0 {
; CHECK-LABEL: i8_i64:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: smov x0, v0.b[15]
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 16 x i8> %a, i32 15
%conv = sext i8 %elt to i64
ret i64 %conv
}
define i32 @i16_i32(<vscale x 8 x i16> %a) #0 {
; CHECK-LABEL: i16_i32:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: smov w0, v0.h[7]
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 8 x i16> %a, i32 7
%conv = sext i16 %elt to i32
ret i32 %conv
}
define i64 @i16_i64(<vscale x 8 x i16> %a) #0 {
; CHECK-LABEL: i16_i64:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: smov x0, v0.h[7]
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 8 x i16> %a, i32 7
%conv = sext i16 %elt to i64
ret i64 %conv
}
define i64 @i32_i64(<vscale x 4 x i32> %a) #0 {
; CHECK-LABEL: i32_i64:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: smov x0, v0.s[3]
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 4 x i32> %a, i32 3
%conv = sext i32 %elt to i64
ret i64 %conv
}
; NOTE: Testing out-of-range indices
define i32 @i8_i32_oor(<vscale x 16 x i8> %a) #0 {
; CHECK-LABEL: i8_i32_oor:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov z0.b, z0.b[16]
; CHECK-NEXT: fmov w8, s0
; CHECK-NEXT: sxtb w0, w8
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 16 x i8> %a, i32 16
%conv = sext i8 %elt to i32
ret i32 %conv
}
define i64 @i8_i64_oor(<vscale x 16 x i8> %a) #0 {
; CHECK-LABEL: i8_i64_oor:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov z0.b, z0.b[16]
; CHECK-NEXT: fmov w8, s0
; CHECK-NEXT: sxtb x0, w8
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 16 x i8> %a, i32 16
%conv = sext i8 %elt to i64
ret i64 %conv
}
define i32 @i16_i32_oor(<vscale x 8 x i16> %a) #0 {
; CHECK-LABEL: i16_i32_oor:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov z0.h, z0.h[8]
; CHECK-NEXT: fmov w8, s0
; CHECK-NEXT: sxth w0, w8
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 8 x i16> %a, i32 8
%conv = sext i16 %elt to i32
ret i32 %conv
}
define i64 @i16_i64_oor(<vscale x 8 x i16> %a) #0 {
; CHECK-LABEL: i16_i64_oor:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov z0.h, z0.h[8]
; CHECK-NEXT: fmov w8, s0
; CHECK-NEXT: sxth x0, w8
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 8 x i16> %a, i32 8
%conv = sext i16 %elt to i64
ret i64 %conv
}
define i64 @i32_i64_oor(<vscale x 4 x i32> %a) #0 {
; CHECK-LABEL: i32_i64_oor:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov z0.s, z0.s[4]
; CHECK-NEXT: fmov w8, s0
; CHECK-NEXT: sxtw x0, w8
; CHECK-NEXT: ret
entry:
%elt = extractelement <vscale x 4 x i32> %a, i32 4
%conv = sext i32 %elt to i64
ret i64 %conv
}
attributes #0 = { "target-features"="+sve" }
|