aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2006-06-05 22:26:14 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2006-06-05 22:26:14 +0000
commit4b02367d542c7eaa429d1ff73119ae44ddb252a8 (patch)
tree6a6a74b9ed8a5e60f54f70921ce5cb8d1a34b776 /lib
parent2403b855cdd42db799052b30b286095d731f7646 (diff)
downloadexternal_llvm-4b02367d542c7eaa429d1ff73119ae44ddb252a8.zip
external_llvm-4b02367d542c7eaa429d1ff73119ae44ddb252a8.tar.gz
external_llvm-4b02367d542c7eaa429d1ff73119ae44ddb252a8.tar.bz2
add R0 to liveout
expand "ret null" (implements test/Regression/CodeGen/ARM/ret_void.ll) note that a Flag link is missing between the copy and the branch git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28691 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Target/ARM/ARMISelDAGToDAG.cpp16
1 files changed, 13 insertions, 3 deletions
diff --git a/lib/Target/ARM/ARMISelDAGToDAG.cpp b/lib/Target/ARM/ARMISelDAGToDAG.cpp
index 90ffab0..ecf54aa 100644
--- a/lib/Target/ARM/ARMISelDAGToDAG.cpp
+++ b/lib/Target/ARM/ARMISelDAGToDAG.cpp
@@ -49,18 +49,28 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) {
static SDOperand LowerRET(SDOperand Op, SelectionDAG &DAG) {
SDOperand Copy;
+ SDOperand Chain = Op.getOperand(0);
switch(Op.getNumOperands()) {
default:
assert(0 && "Do not know how to return this many arguments!");
abort();
- case 1:
- return SDOperand(); // ret void is legal
+ case 1: {
+ SDOperand LR = DAG.getRegister(ARM::R14, MVT::i32);
+ return DAG.getNode(ISD::BRIND, MVT::Other, Chain, LR);
+ }
case 3:
- Copy = DAG.getCopyToReg(Op.getOperand(0), ARM::R0, Op.getOperand(1), SDOperand());
+ Copy = DAG.getCopyToReg(Chain, ARM::R0, Op.getOperand(1), SDOperand());
+ if (DAG.getMachineFunction().liveout_empty())
+ DAG.getMachineFunction().addLiveOut(ARM::R0);
break;
}
+
SDOperand LR = DAG.getRegister(ARM::R14, MVT::i32);
+ //bug: the copy and branch should be linked with a flag so that the
+ //scheduller can't move an instruction that destroys R0 in between them
+ //return DAG.getNode(ISD::BRIND, MVT::Other, Copy, LR, Copy.getValue(1));
+
return DAG.getNode(ISD::BRIND, MVT::Other, Copy, LR);
}