blob: 1e089e1168f6625765b595b0995dcd01dfcbbde2 (
plain)
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
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt -S -passes=instcombine < %s | FileCheck %s
define i1 @extract_const_idx(<vscale x 4 x i1> %a) {
; CHECK-LABEL: define i1 @extract_const_idx(
; CHECK-SAME: <vscale x 4 x i1> [[A:%.*]]) {
; CHECK-NEXT: [[ELT:%.*]] = extractelement <vscale x 4 x i1> [[A]], i64 1
; CHECK-NEXT: ret i1 [[ELT]]
;
%subvec = call <vscale x 2 x i1> @llvm.vector.extract.nxv2i1.nxv4i1.i64(<vscale x 4 x i1> %a, i64 0)
%elt = extractelement <vscale x 2 x i1> %subvec, i32 1
ret i1 %elt
}
define float @extract_variable_idx(<vscale x 4 x float> %a, i32 %idx) {
; CHECK-LABEL: define float @extract_variable_idx(
; CHECK-SAME: <vscale x 4 x float> [[A:%.*]], i32 [[IDX:%.*]]) {
; CHECK-NEXT: [[ELT:%.*]] = extractelement <vscale x 4 x float> [[A]], i32 [[IDX]]
; CHECK-NEXT: ret float [[ELT]]
;
%subvec = call <vscale x 2 x float> @llvm.vector.extract.nxv2f32.nxv4f32.i64(<vscale x 4 x float> %a, i64 0)
%elt = extractelement <vscale x 2 x float> %subvec, i32 %idx
ret float %elt
}
define float @negative_test(<vscale x 4 x float> %a) {
; CHECK-LABEL: define float @negative_test(
; CHECK-SAME: <vscale x 4 x float> [[A:%.*]]) {
; CHECK-NEXT: [[SUBVEC:%.*]] = call <vscale x 2 x float> @llvm.vector.extract.nxv2f32.nxv4f32(<vscale x 4 x float> [[A]], i64 2)
; CHECK-NEXT: [[ELT:%.*]] = extractelement <vscale x 2 x float> [[SUBVEC]], i64 1
; CHECK-NEXT: ret float [[ELT]]
;
%subvec = call <vscale x 2 x float> @llvm.vector.extract.nxv2f32.nxv4f32.i64(<vscale x 4 x float> %a, i64 2)
%elt = extractelement <vscale x 2 x float> %subvec, i32 1
ret float %elt
}
|