mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Add support for fast isel of inttoptr and ptrtoint in the cases where truncation is not needed.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55399 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d0533c9998
commit
9d5b416240
@ -388,6 +388,25 @@ FastISel::SelectInstructions(BasicBlock::iterator Begin,
|
||||
if (!SelectConstantCast(I, ISD::SINT_TO_FP, ValueMap)) return I;
|
||||
break;
|
||||
|
||||
case Instruction::IntToPtr: // Deliberate fall-through.
|
||||
case Instruction::PtrToInt: {
|
||||
MVT SrcVT = TLI.getValueType(I->getOperand(0)->getType());
|
||||
MVT DstVT = TLI.getValueType(I->getType());
|
||||
if (SrcVT.getSimpleVT() == DstVT.getSimpleVT()) {
|
||||
ValueMap[I] = ValueMap[I->getOperand(0)];
|
||||
break;
|
||||
} else if (DstVT.bitsGT(SrcVT)) {
|
||||
if (!isa<ConstantInt>(I->getOperand(0))) {
|
||||
if (!SelectCast(I, ISD::ZERO_EXTEND, ValueMap)) return I;
|
||||
} else
|
||||
if (!SelectConstantCast(I, ISD::ZERO_EXTEND, ValueMap)) return I;
|
||||
break;
|
||||
} else {
|
||||
// TODO: Handle SrcVT > DstVT, where truncation is needed.
|
||||
return I;
|
||||
}
|
||||
}
|
||||
|
||||
default:
|
||||
// Unhandled instruction. Halt "fast" selection and bail.
|
||||
return I;
|
||||
|
Loading…
x
Reference in New Issue
Block a user