mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-13 08:26:02 +00:00
Revert unintentional commit.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@131597 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -722,39 +722,18 @@ bool X86FastISel::X86SelectRet(const Instruction *I) {
|
|||||||
// Only handle register returns for now.
|
// Only handle register returns for now.
|
||||||
if (!VA.isRegLoc())
|
if (!VA.isRegLoc())
|
||||||
return false;
|
return false;
|
||||||
|
// TODO: For now, don't try to handle cases where getLocInfo()
|
||||||
|
// says Full but the types don't match.
|
||||||
|
if (TLI.getValueType(RV->getType()) != VA.getValVT())
|
||||||
|
return false;
|
||||||
|
|
||||||
// The calling-convention tables for x87 returns don't tell
|
// The calling-convention tables for x87 returns don't tell
|
||||||
// the whole story.
|
// the whole story.
|
||||||
if (VA.getLocReg() == X86::ST0 || VA.getLocReg() == X86::ST1)
|
if (VA.getLocReg() == X86::ST0 || VA.getLocReg() == X86::ST1)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
unsigned SrcReg = Reg + VA.getValNo();
|
|
||||||
EVT SrcVT = TLI.getValueType(RV->getType());
|
|
||||||
EVT DstVT = VA.getValVT();
|
|
||||||
// Special handling for extended integers.
|
|
||||||
if (SrcVT != DstVT) {
|
|
||||||
return false;
|
|
||||||
if (SrcVT != MVT::i1 && SrcVT != MVT::i8 && SrcVT != MVT::i16)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!Outs[0].Flags.isZExt() && !Outs[0].Flags.isSExt())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
assert(DstVT == MVT::i32 && "X86 should always ext to i32");
|
|
||||||
|
|
||||||
if (SrcVT == MVT::i1) {
|
|
||||||
if (Outs[0].Flags.isSExt())
|
|
||||||
return false;
|
|
||||||
SrcReg = FastEmitZExtFromI1(MVT::i8, SrcReg, /*TODO: Kill=*/false);
|
|
||||||
SrcVT = MVT::i8;
|
|
||||||
}
|
|
||||||
unsigned Op = Outs[0].Flags.isZExt() ? ISD::ZERO_EXTEND :
|
|
||||||
ISD::SIGN_EXTEND;
|
|
||||||
SrcReg = FastEmit_r(SrcVT.getSimpleVT(), DstVT.getSimpleVT(), Op,
|
|
||||||
SrcReg, /*TODO: Kill=*/false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Make the copy.
|
// Make the copy.
|
||||||
|
unsigned SrcReg = Reg + VA.getValNo();
|
||||||
unsigned DstReg = VA.getLocReg();
|
unsigned DstReg = VA.getLocReg();
|
||||||
const TargetRegisterClass* SrcRC = MRI.getRegClass(SrcReg);
|
const TargetRegisterClass* SrcRC = MRI.getRegClass(SrcReg);
|
||||||
// Avoid a cross-class copy. This is very unlikely.
|
// Avoid a cross-class copy. This is very unlikely.
|
||||||
|
Reference in New Issue
Block a user