mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
oops. revert for a moment to clean up tests first.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110259 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
936ed5424c
commit
87c0175cce
@ -851,18 +851,13 @@ ARMBaseRegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,
|
|||||||
// slot of the previous FP. Also, if we have variable sized objects in the
|
// slot of the previous FP. Also, if we have variable sized objects in the
|
||||||
// function, stack slot references will often be negative, and some of
|
// function, stack slot references will often be negative, and some of
|
||||||
// our instructions are positive-offset only, so conservatively consider
|
// our instructions are positive-offset only, so conservatively consider
|
||||||
// that case to want a spill slot (or register) as well. Similarly, if
|
// that case to want a spill slot (or register) as well.
|
||||||
// the function adjusts the stack pointer during execution and the
|
|
||||||
// adjustments aren't already part of our stack size estimate, our offset
|
|
||||||
// calculations may be off, so be conservative.
|
|
||||||
// FIXME: We could add logic to be more precise about negative offsets
|
// FIXME: We could add logic to be more precise about negative offsets
|
||||||
// and which instructions will need a scratch register for them. Is it
|
// and which instructions will need a scratch register for them. Is it
|
||||||
// worth the effort and added fragility?
|
// worth the effort and added fragility?
|
||||||
bool BigStack =
|
bool BigStack =
|
||||||
(RS && (estimateStackSize(MF) + (hasFP(MF) ? 4:0) >=
|
(RS && (estimateStackSize(MF) + (hasFP(MF) ? 4:0) >=
|
||||||
estimateRSStackSizeLimit(MF))
|
estimateRSStackSizeLimit(MF))) || MFI->hasVarSizedObjects();
|
||||||
|| MFI->hasVarSizedObjects()
|
|
||||||
|| (MFI->adjustsStack() && !canSimplifyCallFramePseudos(MF)));
|
|
||||||
|
|
||||||
bool ExtraCSSpill = false;
|
bool ExtraCSSpill = false;
|
||||||
if (BigStack || !CanEliminateFrame || cannotEliminateFrame(MF)) {
|
if (BigStack || !CanEliminateFrame || cannotEliminateFrame(MF)) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user