mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-04 10:30:01 +00:00
Fix Transforms/InstCombine/2007-01-13-ExtCompareMiscompile.ll, which is part
of PR1107 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33185 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ac3e76ca8f
commit
a5c5e7715c
@ -5263,9 +5263,19 @@ Instruction *InstCombiner::visitICmpInstWithCastAndCast(ICmpInst &ICI) {
|
||||
RHSCIOp = CI->getOperand(0);
|
||||
if (RHSCIOp->getType() != LHSCIOp->getType())
|
||||
return 0;
|
||||
else
|
||||
// Okay, just insert a compare of the reduced operands now!
|
||||
return new ICmpInst(ICI.getPredicate(), LHSCIOp, RHSCIOp);
|
||||
|
||||
// If the signedness of the two compares doesn't agree (i.e. one is a sext
|
||||
// and the other is a zext), then we can't handle this.
|
||||
if (CI->getOpcode() != LHSCI->getOpcode())
|
||||
return 0;
|
||||
|
||||
// Likewise, if the signedness of the [sz]exts and the compare don't match,
|
||||
// then we can't handle this.
|
||||
if (isSignedExt != isSignedCmp && !ICI.isEquality())
|
||||
return 0;
|
||||
|
||||
// Okay, just insert a compare of the reduced operands now!
|
||||
return new ICmpInst(ICI.getPredicate(), LHSCIOp, RHSCIOp);
|
||||
}
|
||||
|
||||
// If we aren't dealing with a constant on the RHS, exit early
|
||||
|
Loading…
x
Reference in New Issue
Block a user