mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
1. Fix a leftover bug in generating memory instructions.
2. Fix type used for TmpInstruction holding the return address. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2075 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a44c6c00a2
commit
a10d1a7aaa
@ -918,19 +918,20 @@ SetOperandsForMemInstr(vector<MachineInstr*>& mvec,
|
|||||||
// The major work here is to extract these for all 3 instruction types
|
// The major work here is to extract these for all 3 instruction types
|
||||||
// and then call the common function SetMemOperands_Internal().
|
// and then call the common function SetMemOperands_Internal().
|
||||||
//
|
//
|
||||||
vector<Value*> idxVec;
|
|
||||||
Value* ptrVal = memInst->getPointerOperand();
|
Value* ptrVal = memInst->getPointerOperand();
|
||||||
|
|
||||||
// Test if a GetElemPtr instruction is being folded into this mem instrn.
|
// Start with the index vector of this instruction, if any.
|
||||||
// If so, it will be in the left child for Load and GetElemPtr,
|
vector<Value*> idxVec;
|
||||||
// and in the right child for Store instructions.
|
idxVec.insert(idxVec.end(), memInst->idx_begin(), memInst->idx_end());
|
||||||
//
|
|
||||||
|
// If there is a GetElemPtr instruction to fold in to this instr,
|
||||||
|
// it must be in the left child for Load and GetElemPtr, and in the
|
||||||
|
// right child for Store instructions.
|
||||||
InstrTreeNode* ptrChild = (vmInstrNode->getOpLabel() == Instruction::Store
|
InstrTreeNode* ptrChild = (vmInstrNode->getOpLabel() == Instruction::Store
|
||||||
? vmInstrNode->rightChild()
|
? vmInstrNode->rightChild()
|
||||||
: vmInstrNode->leftChild());
|
: vmInstrNode->leftChild());
|
||||||
|
|
||||||
// Fold chains of GetElemPtr instructions for structure references.
|
// Fold chains of GetElemPtr instructions for structure references.
|
||||||
//
|
|
||||||
if (isa<StructType>(cast<PointerType>(ptrVal->getType())->getElementType())
|
if (isa<StructType>(cast<PointerType>(ptrVal->getType())->getElementType())
|
||||||
&& (ptrChild->getOpLabel() == Instruction::GetElementPtr ||
|
&& (ptrChild->getOpLabel() == Instruction::GetElementPtr ||
|
||||||
ptrChild->getOpLabel() == GetElemPtrIdx))
|
ptrChild->getOpLabel() == GetElemPtrIdx))
|
||||||
@ -940,10 +941,6 @@ SetOperandsForMemInstr(vector<MachineInstr*>& mvec,
|
|||||||
ptrVal = newPtr;
|
ptrVal = newPtr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Append the index vector of this instruction (may be none) to the indexes
|
|
||||||
// folded in previous getElementPtr's (may be none)
|
|
||||||
idxVec.insert(idxVec.end(), memInst->idx_begin(), memInst->idx_end());
|
|
||||||
|
|
||||||
SetMemOperands_Internal(mvec, mvecI, vmInstrNode, ptrVal, idxVec, target);
|
SetMemOperands_Internal(mvec, mvecI, vmInstrNode, ptrVal, idxVec, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1044,16 +1041,30 @@ SetMemOperands_Internal(vector<MachineInstr*>& mvec,
|
|||||||
smallConstOffset = 0;
|
smallConstOffset = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Operand 0 is value for STORE, ptr for LOAD or GET_ELEMENT_PTR
|
// For STORE:
|
||||||
// It is the left child in the instruction tree in all cases.
|
// Operand 0 is value, operand 1 is ptr, operand 2 is offset
|
||||||
Value* leftVal = vmInstrNode->leftChild()->getValue();
|
// For LOAD or GET_ELEMENT_PTR,
|
||||||
(*mvecI)->SetMachineOperandVal(0, MachineOperand::MO_VirtualRegister,
|
// Operand 0 is ptr, operand 1 is offset, operand 2 is result.
|
||||||
leftVal);
|
|
||||||
|
|
||||||
// Operand 1 is ptr for STORE, offset for LOAD or GET_ELEMENT_PTR
|
|
||||||
// Operand 2 is offset for STORE, result reg for LOAD or GET_ELEMENT_PTR
|
|
||||||
//
|
//
|
||||||
unsigned offsetOpNum = (memInst->getOpcode() == Instruction::Store)? 2 : 1;
|
unsigned offsetOpNum, ptrOpNum;
|
||||||
|
if (memInst->getOpcode() == Instruction::Store)
|
||||||
|
{
|
||||||
|
(*mvecI)->SetMachineOperandVal(0, MachineOperand::MO_VirtualRegister,
|
||||||
|
vmInstrNode->leftChild()->getValue());
|
||||||
|
ptrOpNum = 1;
|
||||||
|
offsetOpNum = 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ptrOpNum = 0;
|
||||||
|
offsetOpNum = 1;
|
||||||
|
(*mvecI)->SetMachineOperandVal(2, MachineOperand::MO_VirtualRegister,
|
||||||
|
memInst);
|
||||||
|
}
|
||||||
|
|
||||||
|
(*mvecI)->SetMachineOperandVal(ptrOpNum, MachineOperand::MO_VirtualRegister,
|
||||||
|
ptrVal);
|
||||||
|
|
||||||
if (offsetOpType == MachineOperand::MO_VirtualRegister)
|
if (offsetOpType == MachineOperand::MO_VirtualRegister)
|
||||||
{
|
{
|
||||||
assert(valueForRegOffset != NULL);
|
assert(valueForRegOffset != NULL);
|
||||||
@ -1063,13 +1074,6 @@ SetMemOperands_Internal(vector<MachineInstr*>& mvec,
|
|||||||
else
|
else
|
||||||
(*mvecI)->SetMachineOperandConst(offsetOpNum, offsetOpType,
|
(*mvecI)->SetMachineOperandConst(offsetOpNum, offsetOpType,
|
||||||
smallConstOffset);
|
smallConstOffset);
|
||||||
|
|
||||||
if (memInst->getOpcode() == Instruction::Store)
|
|
||||||
(*mvecI)->SetMachineOperandVal(1, MachineOperand::MO_VirtualRegister,
|
|
||||||
ptrVal);
|
|
||||||
else
|
|
||||||
(*mvecI)->SetMachineOperandVal(2, MachineOperand::MO_VirtualRegister,
|
|
||||||
vmInstrNode->getValue());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2089,17 +2093,11 @@ GetInstructionsByRule(InstructionNode* subtreeRoot,
|
|||||||
CallInst *callInstr = cast<CallInst>(subtreeRoot->getInstruction());
|
CallInst *callInstr = cast<CallInst>(subtreeRoot->getInstruction());
|
||||||
Value *callee = callInstr->getCalledValue();
|
Value *callee = callInstr->getCalledValue();
|
||||||
|
|
||||||
Instruction* retAddrReg = new TmpInstruction(callInstr);
|
// Create hidden virtual register for return address, with type void*.
|
||||||
|
Instruction* retAddrReg =
|
||||||
// Note temporary values in the machineInstrVec for the VM instr.
|
new TmpInstruction(PointerType::get(Type::VoidTy), callInstr);
|
||||||
//
|
|
||||||
// WARNING: Operands 0..N-1 must go in slots 0..N-1 of implicitUses.
|
|
||||||
// The result value must go in slot N. This is assumed
|
|
||||||
// in register allocation.
|
|
||||||
//
|
|
||||||
MachineCodeForInstruction::get(callInstr).addTemp(retAddrReg);
|
MachineCodeForInstruction::get(callInstr).addTemp(retAddrReg);
|
||||||
|
|
||||||
|
|
||||||
// Generate the machine instruction and its operands.
|
// Generate the machine instruction and its operands.
|
||||||
// Use CALL for direct function calls; this optimistically assumes
|
// Use CALL for direct function calls; this optimistically assumes
|
||||||
// the PC-relative address fits in the CALL address field (22 bits).
|
// the PC-relative address fits in the CALL address field (22 bits).
|
||||||
@ -2124,6 +2122,10 @@ GetInstructionsByRule(InstructionNode* subtreeRoot,
|
|||||||
|
|
||||||
mvec.push_back(M);
|
mvec.push_back(M);
|
||||||
|
|
||||||
|
// WARNING: Operands 0..N-1 must go in slots 0..N-1 of implicitUses.
|
||||||
|
// The result value must go in slot N. This is assumed
|
||||||
|
// in register allocation.
|
||||||
|
//
|
||||||
// Add the call operands and return value as implicit refs
|
// Add the call operands and return value as implicit refs
|
||||||
for (unsigned i=0, N=callInstr->getNumOperands(); i < N; ++i)
|
for (unsigned i=0, N=callInstr->getNumOperands(); i < N; ++i)
|
||||||
if (callInstr->getOperand(i) != callee)
|
if (callInstr->getOperand(i) != callee)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user