mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Add an instcombine for constructs like a | -(b != c); a select is more
canonical, and generally leads to better code. Found while looking at an article about saturating arithmetic. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129545 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f6832bbda0
commit
3ec01b7dac
@ -2003,7 +2003,14 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// or(sext(A), B) -> A ? -1 : B where A is an i1
|
||||||
|
// or(A, sext(B)) -> B ? -1 : A where B is an i1
|
||||||
|
if (match(Op0, m_SExt(m_Value(A))) && A->getType()->isIntegerTy(1))
|
||||||
|
return SelectInst::Create(A, ConstantInt::getSigned(I.getType(), -1), Op1);
|
||||||
|
if (match(Op1, m_SExt(m_Value(A))) && A->getType()->isIntegerTy(1))
|
||||||
|
return SelectInst::Create(A, ConstantInt::getSigned(I.getType(), -1), Op0);
|
||||||
|
|
||||||
// Note: If we've gotten to the point of visiting the outer OR, then the
|
// Note: If we've gotten to the point of visiting the outer OR, then the
|
||||||
// inner one couldn't be simplified. If it was a constant, then it won't
|
// inner one couldn't be simplified. If it was a constant, then it won't
|
||||||
// be simplified by a later pass either, so we try swapping the inner/outer
|
// be simplified by a later pass either, so we try swapping the inner/outer
|
||||||
|
@ -390,3 +390,22 @@ define i1 @test36(i32 %x) {
|
|||||||
; CHECK-NEXT: ret i1
|
; CHECK-NEXT: ret i1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i32 @test37(i32* %xp, i32 %y) {
|
||||||
|
; CHECK: @test37
|
||||||
|
; CHECK: select i1 %tobool, i32 -1, i32 %x
|
||||||
|
%tobool = icmp ne i32 %y, 0
|
||||||
|
%sext = sext i1 %tobool to i32
|
||||||
|
%x = load i32* %xp
|
||||||
|
%or = or i32 %sext, %x
|
||||||
|
ret i32 %or
|
||||||
|
}
|
||||||
|
|
||||||
|
define i32 @test38(i32* %xp, i32 %y) {
|
||||||
|
; CHECK: @test38
|
||||||
|
; CHECK: select i1 %tobool, i32 -1, i32 %x
|
||||||
|
%tobool = icmp ne i32 %y, 0
|
||||||
|
%sext = sext i1 %tobool to i32
|
||||||
|
%x = load i32* %xp
|
||||||
|
%or = or i32 %x, %sext
|
||||||
|
ret i32 %or
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user