summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2011-06-03 22:45:18 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2011-06-03 22:45:18 +0000
commite1c6d3acb4ddce22eb9240c2b09b3eb325c1ce0d (patch)
treef7d287810e94e91a7fba37fe3ea56192b0df4750 /llvm/lib
parentf56b4f6fddbb541f8cb55b56a24b3438a5f3550b (diff)
downloadbcm5719-llvm-e1c6d3acb4ddce22eb9240c2b09b3eb325c1ce0d.tar.gz
bcm5719-llvm-e1c6d3acb4ddce22eb9240c2b09b3eb325c1ce0d.zip
Blackfin always uses a reserved call frame.
Materializing the stack pointer update before a call requires a scratch register that may not be available. llvm-svn: 132601
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/Blackfin/BlackfinFrameLowering.cpp6
-rw-r--r--llvm/lib/Target/Blackfin/BlackfinFrameLowering.h1
-rw-r--r--llvm/lib/Target/Blackfin/BlackfinRegisterInfo.h2
3 files changed, 7 insertions, 2 deletions
diff --git a/llvm/lib/Target/Blackfin/BlackfinFrameLowering.cpp b/llvm/lib/Target/Blackfin/BlackfinFrameLowering.cpp
index 08bb9522b7c..0b0984d2f77 100644
--- a/llvm/lib/Target/Blackfin/BlackfinFrameLowering.cpp
+++ b/llvm/lib/Target/Blackfin/BlackfinFrameLowering.cpp
@@ -31,6 +31,12 @@ bool BlackfinFrameLowering::hasFP(const MachineFunction &MF) const {
MFI->adjustsStack() || MFI->hasVarSizedObjects();
}
+// Always reserve a call frame. We dont have enough registers to adjust SP.
+bool BlackfinFrameLowering::
+hasReservedCallFrame(const MachineFunction &MF) const {
+ return true;
+}
+
// Emit a prologue that sets up a stack frame.
// On function entry, R0-R2 and P0 may hold arguments.
// R3, P1, and P2 may be used as scratch registers
diff --git a/llvm/lib/Target/Blackfin/BlackfinFrameLowering.h b/llvm/lib/Target/Blackfin/BlackfinFrameLowering.h
index 3d2ee251d3b..726fa2c063f 100644
--- a/llvm/lib/Target/Blackfin/BlackfinFrameLowering.h
+++ b/llvm/lib/Target/Blackfin/BlackfinFrameLowering.h
@@ -36,6 +36,7 @@ public:
void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const;
bool hasFP(const MachineFunction &MF) const;
+ bool hasReservedCallFrame(const MachineFunction &MF) const;
void processFunctionBeforeCalleeSavedScan(MachineFunction &MF,
RegScavenger *RS) const;
diff --git a/llvm/lib/Target/Blackfin/BlackfinRegisterInfo.h b/llvm/lib/Target/Blackfin/BlackfinRegisterInfo.h
index dc4a69921b5..375d277216c 100644
--- a/llvm/lib/Target/Blackfin/BlackfinRegisterInfo.h
+++ b/llvm/lib/Target/Blackfin/BlackfinRegisterInfo.h
@@ -41,8 +41,6 @@ namespace llvm {
return &BF::PRegClass;
}
- // bool hasReservedCallFrame(MachineFunction &MF) const;
-
bool requiresRegisterScavenging(const MachineFunction &MF) const;
void eliminateCallFramePseudoInstr(MachineFunction &MF,
OpenPOWER on IntegriCloud