mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-05-24 02:38:42 +00:00
InstCombine: Make sure we use the pre-zext type when creating a constant of a value that is zext'd.
Fixes PR13250. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@164377 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
30b483c940
commit
e5bd3cf000
@ -477,7 +477,8 @@ Instruction *InstCombiner::visitUDiv(BinaryOperator &I) {
|
|||||||
if (match(Op1, m_Shl(m_Power2(CI), m_Value(N))) ||
|
if (match(Op1, m_Shl(m_Power2(CI), m_Value(N))) ||
|
||||||
match(Op1, m_ZExt(m_Shl(m_Power2(CI), m_Value(N))))) {
|
match(Op1, m_ZExt(m_Shl(m_Power2(CI), m_Value(N))))) {
|
||||||
if (*CI != 1)
|
if (*CI != 1)
|
||||||
N = Builder->CreateAdd(N, ConstantInt::get(I.getType(),CI->logBase2()));
|
N = Builder->CreateAdd(N,
|
||||||
|
ConstantInt::get(N->getType(), CI->logBase2()));
|
||||||
if (ZExtInst *Z = dyn_cast<ZExtInst>(Op1))
|
if (ZExtInst *Z = dyn_cast<ZExtInst>(Op1))
|
||||||
N = Builder->CreateZExt(N, Z->getDestTy());
|
N = Builder->CreateZExt(N, Z->getDestTy());
|
||||||
if (I.isExact())
|
if (I.isExact())
|
||||||
|
@ -21,3 +21,17 @@ define i64 @t2(i64 %x, i32 %y) nounwind {
|
|||||||
%3 = udiv i64 %x, %2
|
%3 = udiv i64 %x, %2
|
||||||
ret i64 %3
|
ret i64 %3
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; PR13250
|
||||||
|
define i64 @t3(i64 %x, i32 %y) nounwind {
|
||||||
|
; CHECK: t3
|
||||||
|
; CHECK-NOT: udiv
|
||||||
|
; CHECK-NEXT: %1 = add i32 %y, 2
|
||||||
|
; CHECK-NEXT: %2 = zext i32 %1 to i64
|
||||||
|
; CHECK-NEXT: %3 = lshr i64 %x, %2
|
||||||
|
; CHECK-NEXT: ret i64 %3
|
||||||
|
%1 = shl i32 4, %y
|
||||||
|
%2 = zext i32 %1 to i64
|
||||||
|
%3 = udiv i64 %x, %2
|
||||||
|
ret i64 %3
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user