mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-07 11:38:04 +00:00
541777c567
Summary: An undef extract index can be arbitrarily chosen to be an out-of-range index value, which would result in the instruction being undef. This change closes a gap identified while working on lowering vector permute intrinsics with variable index vectors to pure LLVM IR. Reviewers: arsenm, spatel, majnemer Reviewed By: arsenm, spatel Subscribers: fhahn, nhaehnle, wdng, llvm-commits Differential Revision: https://reviews.llvm.org/D40231 llvm-svn: 319910
56 lines
1.6 KiB
LLVM
56 lines
1.6 KiB
LLVM
; RUN: opt < %s -instsimplify -S | FileCheck %s
|
|
|
|
declare void @bar()
|
|
|
|
define void @test1() personality i32 (i32, i64, i8*, i8*)* @__gxx_personality_v0 {
|
|
entry:
|
|
invoke void @bar() to label %cont unwind label %lpad
|
|
cont:
|
|
ret void
|
|
lpad:
|
|
%ex = landingpad { i8*, i32 } cleanup
|
|
%exc_ptr = extractvalue { i8*, i32 } %ex, 0
|
|
%filter = extractvalue { i8*, i32 } %ex, 1
|
|
%exc_ptr2 = insertvalue { i8*, i32 } undef, i8* %exc_ptr, 0
|
|
%filter2 = insertvalue { i8*, i32 } %exc_ptr2, i32 %filter, 1
|
|
resume { i8*, i32 } %filter2
|
|
; CHECK-LABEL: @test1(
|
|
; CHECK-NOT: extractvalue
|
|
; CHECK-NOT: insertvalue
|
|
}
|
|
|
|
declare i32 @__gxx_personality_v0(i32, i64, i8*, i8*)
|
|
|
|
define { i8, i32 } @test2({ i8*, i32 } %x) {
|
|
%ex = extractvalue { i8*, i32 } %x, 1
|
|
%ins = insertvalue { i8, i32 } undef, i32 %ex, 1
|
|
ret { i8, i32 } %ins
|
|
; CHECK-LABEL: @test2(
|
|
}
|
|
|
|
define i32 @test3(i32 %a, float %b) {
|
|
%agg1 = insertvalue {i32, float} undef, i32 %a, 0
|
|
%agg2 = insertvalue {i32, float} %agg1, float %b, 1
|
|
%ev = extractvalue {i32, float} %agg2, 0
|
|
ret i32 %ev
|
|
; CHECK-LABEL: @test3(
|
|
; CHECK: ret i32 %a
|
|
}
|
|
|
|
define i8 @test4(<8 x i8> %V) {
|
|
%add = add <8 x i8> %V, bitcast (double 0x319BEB8FD172E36 to <8 x i8>)
|
|
%extract = extractelement <8 x i8> %add, i32 6
|
|
ret i8 %extract
|
|
; CHECK-LABEL: @test4(
|
|
; CHECK: %[[add:.*]] = add <8 x i8> %V, bitcast (<1 x double> <double 0x319BEB8FD172E36> to <8 x i8>)
|
|
; CHECK-NEXT: %[[extract:.*]] = extractelement <8 x i8> %[[add]], i32 6
|
|
; CHECK-NEXT: ret i8 %[[extract]]
|
|
}
|
|
|
|
define i32 @test5(<4 x i32> %V) {
|
|
%extract = extractelement <4 x i32> %V, i32 undef
|
|
ret i32 %extract
|
|
}
|
|
; CHECK-LABEL: @test5(
|
|
; CHECK: ret i32 undef
|