mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
InstCombine: Fix another infinite loop caused by visitFPTrunc
We would attempt to replace an frem's operand with the same operand. This would cause InstCombine to think real work was done, causing InstCombine to enter an infinite loop. This fixes the second part of PR21576. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@222265 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ed37b1e2d0
commit
643bef9333
@ -1269,13 +1269,12 @@ Instruction *InstCombiner::visitFPTrunc(FPTruncInst &CI) {
|
|||||||
// type of OpI doesn't enter into things at all. We simply evaluate
|
// type of OpI doesn't enter into things at all. We simply evaluate
|
||||||
// in whichever source type is larger, then convert to the
|
// in whichever source type is larger, then convert to the
|
||||||
// destination type.
|
// destination type.
|
||||||
Value *NewLHS = LHSOrig, *NewRHS = RHSOrig;
|
|
||||||
if (LHSWidth < SrcWidth)
|
if (LHSWidth < SrcWidth)
|
||||||
NewLHS = Builder->CreateFPExt(NewLHS, RHSOrig->getType());
|
LHSOrig = Builder->CreateFPExt(LHSOrig, RHSOrig->getType());
|
||||||
else if (RHSWidth <= SrcWidth)
|
else if (RHSWidth <= SrcWidth)
|
||||||
NewRHS = Builder->CreateFPExt(NewRHS, LHSOrig->getType());
|
RHSOrig = Builder->CreateFPExt(RHSOrig, LHSOrig->getType());
|
||||||
if (NewLHS != LHSOrig || NewRHS != RHSOrig) {
|
if (LHSOrig != OpI->getOperand(0) || RHSOrig != OpI->getOperand(1)) {
|
||||||
Value *ExactResult = Builder->CreateFRem(NewLHS, NewRHS);
|
Value *ExactResult = Builder->CreateFRem(LHSOrig, RHSOrig);
|
||||||
if (Instruction *RI = dyn_cast<Instruction>(ExactResult))
|
if (Instruction *RI = dyn_cast<Instruction>(ExactResult))
|
||||||
RI->copyFastMathFlags(OpI);
|
RI->copyFastMathFlags(OpI);
|
||||||
return CastInst::CreateFPCast(ExactResult, CI.getType());
|
return CastInst::CreateFPCast(ExactResult, CI.getType());
|
||||||
|
@ -63,3 +63,13 @@ define <1 x float> @test6(<1 x double> %V) {
|
|||||||
; CHECK-NEXT: %[[trunc:.*]] = fptrunc <1 x double> %[[frem]] to <1 x float>
|
; CHECK-NEXT: %[[trunc:.*]] = fptrunc <1 x double> %[[frem]] to <1 x float>
|
||||||
; CHECK-NEXT: ret <1 x float> %trunc
|
; CHECK-NEXT: ret <1 x float> %trunc
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define float @test7(double %V) {
|
||||||
|
%frem = frem double %V, 1.000000e+00
|
||||||
|
%trunc = fptrunc double %frem to float
|
||||||
|
ret float %trunc
|
||||||
|
; CHECK-LABEL: @test7
|
||||||
|
; CHECK-NEXT: %[[frem:.*]] = frem double %V, 1.000000e+00
|
||||||
|
; CHECK-NEXT: %[[trunc:.*]] = fptrunc double %frem to float
|
||||||
|
; CHECK-NEXT: ret float %trunc
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user