2019-05-24 05:49:47 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
2019-04-17 12:52:47 +08:00
|
|
|
; RUN: opt -S -instsimplify < %s | FileCheck %s
|
|
|
|
|
|
|
|
define <4 x i32> @test1(<4 x i32> %A) {
|
2019-05-24 05:49:47 +08:00
|
|
|
; CHECK-LABEL: @test1(
|
|
|
|
; CHECK-NEXT: ret <4 x i32> undef
|
|
|
|
;
|
2019-04-17 12:52:47 +08:00
|
|
|
%I = insertelement <4 x i32> %A, i32 5, i64 4294967296
|
|
|
|
ret <4 x i32> %I
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @test2(<4 x i32> %A) {
|
2019-05-24 05:49:47 +08:00
|
|
|
; CHECK-LABEL: @test2(
|
|
|
|
; CHECK-NEXT: ret <4 x i32> undef
|
|
|
|
;
|
2019-04-17 12:52:47 +08:00
|
|
|
%I = insertelement <4 x i32> %A, i32 5, i64 4
|
|
|
|
ret <4 x i32> %I
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @test3(<4 x i32> %A) {
|
2019-05-24 05:49:47 +08:00
|
|
|
; CHECK-LABEL: @test3(
|
|
|
|
; CHECK-NEXT: [[I:%.*]] = insertelement <4 x i32> [[A:%.*]], i32 5, i64 1
|
|
|
|
; CHECK-NEXT: ret <4 x i32> [[I]]
|
|
|
|
;
|
2019-04-17 12:52:47 +08:00
|
|
|
%I = insertelement <4 x i32> %A, i32 5, i64 1
|
|
|
|
ret <4 x i32> %I
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @test4(<4 x i32> %A) {
|
2019-05-24 05:49:47 +08:00
|
|
|
; CHECK-LABEL: @test4(
|
|
|
|
; CHECK-NEXT: ret <4 x i32> undef
|
|
|
|
;
|
2019-04-17 12:52:47 +08:00
|
|
|
%I = insertelement <4 x i32> %A, i32 5, i128 100
|
|
|
|
ret <4 x i32> %I
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @test5(<4 x i32> %A) {
|
2019-05-24 05:49:47 +08:00
|
|
|
; CHECK-LABEL: @test5(
|
|
|
|
; CHECK-NEXT: ret <4 x i32> undef
|
|
|
|
;
|
2019-04-17 12:52:47 +08:00
|
|
|
%I = insertelement <4 x i32> %A, i32 5, i64 undef
|
|
|
|
ret <4 x i32> %I
|
|
|
|
}
|
2019-05-24 05:49:47 +08:00
|
|
|
|
|
|
|
define <4 x i32> @PR1286(<4 x i32> %A) {
|
|
|
|
; CHECK-LABEL: @PR1286(
|
|
|
|
; CHECK-NEXT: ret <4 x i32> [[A:%.*]]
|
|
|
|
;
|
|
|
|
%B = insertelement <4 x i32> %A, i32 undef, i32 1
|
|
|
|
ret <4 x i32> %B
|
|
|
|
}
|
2019-05-24 08:11:23 +08:00
|
|
|
|
|
|
|
define <8 x i8> @extract_insert_same_vec_and_index(<8 x i8> %in) {
|
|
|
|
; CHECK-LABEL: @extract_insert_same_vec_and_index(
|
2019-05-24 08:13:58 +08:00
|
|
|
; CHECK-NEXT: ret <8 x i8> [[IN:%.*]]
|
2019-05-24 08:11:23 +08:00
|
|
|
;
|
|
|
|
%val = extractelement <8 x i8> %in, i32 5
|
|
|
|
%vec = insertelement <8 x i8> %in, i8 %val, i32 5
|
|
|
|
ret <8 x i8> %vec
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @extract_insert_same_vec_and_index2(<8 x i8> %in, i32 %index) {
|
|
|
|
; CHECK-LABEL: @extract_insert_same_vec_and_index2(
|
2019-05-24 08:13:58 +08:00
|
|
|
; CHECK-NEXT: ret <8 x i8> [[IN:%.*]]
|
2019-05-24 08:11:23 +08:00
|
|
|
;
|
|
|
|
%val = extractelement <8 x i8> %in, i32 %index
|
|
|
|
%vec = insertelement <8 x i8> %in, i8 %val, i32 %index
|
|
|
|
ret <8 x i8> %vec
|
|
|
|
}
|
2019-09-04 23:12:55 +08:00
|
|
|
|
|
|
|
; The insert is in an unreachable block, so it is allowed to point to itself.
|
|
|
|
; This would crash via stack overflow.
|
|
|
|
|
|
|
|
define void @PR43218() {
|
|
|
|
; CHECK-LABEL: @PR43218(
|
|
|
|
; CHECK-NEXT: end:
|
|
|
|
; CHECK-NEXT: ret void
|
|
|
|
; CHECK: unreachable_infloop:
|
|
|
|
; CHECK-NEXT: [[EXTRACT:%.*]] = extractelement <2 x i64> [[BOGUS:%.*]], i32 0
|
|
|
|
; CHECK-NEXT: [[T0:%.*]] = inttoptr i64 [[EXTRACT]] to i16****
|
|
|
|
; CHECK-NEXT: [[BOGUS]] = insertelement <2 x i64> [[BOGUS]], i64 undef, i32 1
|
|
|
|
; CHECK-NEXT: br label [[UNREACHABLE_INFLOOP:%.*]]
|
|
|
|
;
|
|
|
|
end:
|
|
|
|
ret void
|
|
|
|
|
|
|
|
unreachable_infloop:
|
|
|
|
%extract = extractelement <2 x i64> %bogus, i32 0
|
|
|
|
%t0 = inttoptr i64 %extract to i16****
|
|
|
|
%bogus = insertelement <2 x i64> %bogus, i64 undef, i32 1
|
|
|
|
br label %unreachable_infloop
|
|
|
|
}
|