summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-08-19 20:50:53 +0000
committerChris Lattner <sabre@nondot.org>2005-08-19 20:50:53 +0000
commit78b200eb74a3e4ac907ad846febf1a793b57fbce (patch)
tree56a26135a15fdcf84863d8c9301aff68b1b8bb31 /llvm/lib/CodeGen
parentcc3035e9893355514ca9b3e8163ebb53063887b0 (diff)
downloadbcm5719-llvm-78b200eb74a3e4ac907ad846febf1a793b57fbce.tar.gz
bcm5719-llvm-78b200eb74a3e4ac907ad846febf1a793b57fbce.zip
Before implementing copyfromreg, we'll implement copytoreg correctly.
This gets us this for the previous testcase: _test: lis r2, 0 ori r3, r2, 65535 blr Note that we actually write to r3 (the return reg) correctly now :) llvm-svn: 22933
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp
index 87943f9253d..d77578e2866 100644
--- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp
@@ -36,14 +36,16 @@ namespace {
MachineBasicBlock *BB;
const TargetMachine &TM;
const TargetInstrInfo &TII;
+ const MRegisterInfo &MRI;
SSARegMap *RegMap;
std::map<SDNode *, unsigned> EmittedOps;
public:
SimpleSched(SelectionDAG &D, MachineBasicBlock *bb)
: DAG(D), BB(bb), TM(D.getTarget()), TII(*TM.getInstrInfo()),
- RegMap(BB->getParent()->getSSARegMap()) {
+ MRI(*TM.getRegisterInfo()), RegMap(BB->getParent()->getSSARegMap()) {
assert(&TII && "Target doesn't provide instr info?");
+ assert(&MRI && "Target doesn't provide register info?");
}
void Run() {
@@ -131,7 +133,9 @@ unsigned SimpleSched::Emit(SDOperand Op) {
case ISD::EntryToken: break;
case ISD::CopyToReg: {
unsigned Val = Emit(Op.getOperand(2));
- // FIXME: DO THE COPY NOW.
+ MRI.copyRegToReg(*BB, BB->end(),
+ cast<RegisterSDNode>(Op.getOperand(1))->getReg(), Val,
+ RegMap->getRegClass(Val));
break;
}
}
OpenPOWER on IntegriCloud