mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-02 16:36:40 +00:00
InstCombine: Only foldSelectICmpAndOr for integer types
Currently foldSelectICmpAndOr asserts if the "or" involves a vector containing several of the same power of two. We can easily avoid this by only performing the fold on integer types, like foldSelectICmpAnd does. Fixes <rdar://problem/15012516> llvm-svn: 191552
This commit is contained in:
parent
a3513fb267
commit
d2e08f6deb
@ -367,7 +367,7 @@ static Value *foldSelectICmpAndOr(const SelectInst &SI, Value *TrueVal,
|
||||
Value *FalseVal,
|
||||
InstCombiner::BuilderTy *Builder) {
|
||||
const ICmpInst *IC = dyn_cast<ICmpInst>(SI.getCondition());
|
||||
if (!IC || !IC->isEquality())
|
||||
if (!IC || !IC->isEquality() || !SI.getType()->isIntegerTy())
|
||||
return 0;
|
||||
|
||||
Value *CmpLHS = IC->getOperand(0);
|
||||
|
@ -986,6 +986,16 @@ define i32 @select_icmp_ne_0_and_8_or_1073741824(i8 %x, i32 %y) {
|
||||
ret i32 %select
|
||||
}
|
||||
|
||||
; We can't combine here, because the cmp is scalar and the or vector.
|
||||
; Just make sure we don't assert.
|
||||
define <2 x i32> @select_icmp_eq_and_1_0_or_vector_of_2s(i32 %x, <2 x i32> %y) {
|
||||
%and = and i32 %x, 1
|
||||
%cmp = icmp eq i32 %and, 0
|
||||
%or = or <2 x i32> %y, <i32 2, i32 2>
|
||||
%select = select i1 %cmp, <2 x i32> %y, <2 x i32> %or
|
||||
ret <2 x i32> %select
|
||||
}
|
||||
|
||||
define i32 @test65(i64 %x) {
|
||||
%1 = and i64 %x, 16
|
||||
%2 = icmp ne i64 %1, 0
|
||||
|
Loading…
Reference in New Issue
Block a user