diff options
author | Jim Grosbach <grosbach@apple.com> | 2010-08-14 00:15:52 +0000 |
---|---|---|
committer | Jim Grosbach <grosbach@apple.com> | 2010-08-14 00:15:52 +0000 |
commit | 3d72367d30c9ce6f387764a028763f7a366cc443 (patch) | |
tree | 5290b81ee70c16285532ecc8ce5e4b5bac3ee87f /lib/CodeGen/LLVMTargetMachine.cpp | |
parent | 61556e3a946f3814e2166a78667453e9fff17c77 (diff) |
Add a local stack object block allocation pass. This is still an
experimental pass that allocates locals relative to one another before
register allocation and then assigns them to actual stack slots as a block
later in PEI. This will eventually allow targets with limited index offset
range to allocate additional base registers (not just FP and SP) to
more efficiently reference locals, as well as handle situations where
locals cannot be referenced via SP or FP at all (dynamic stack realignment
together with variable sized objects, for example). It's currently
incomplete and almost certainly buggy. Work in progress.
Disabled by default and gated via the -enable-local-stack-alloc command
line option.
rdar://8277890
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111059 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/LLVMTargetMachine.cpp')
-rw-r--r-- | lib/CodeGen/LLVMTargetMachine.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/lib/CodeGen/LLVMTargetMachine.cpp b/lib/CodeGen/LLVMTargetMachine.cpp index 20df99e039..b856d9093e 100644 --- a/lib/CodeGen/LLVMTargetMachine.cpp +++ b/lib/CodeGen/LLVMTargetMachine.cpp @@ -74,6 +74,16 @@ static cl::opt<bool> EnableMCLogging("enable-mc-api-logging", cl::Hidden, static cl::opt<bool> VerifyMachineCode("verify-machineinstrs", cl::Hidden, cl::desc("Verify generated machine code"), cl::init(getenv("LLVM_VERIFY_MACHINEINSTRS")!=NULL)); +// Enabled or disable local stack object block allocation. This is an +// experimental pass that allocates locals relative to one another before +// register allocation and then assigns them to actual stack slots as a block +// later in PEI. This will eventually allow targets with limited index offset +// range to allocate additional base registers (not just FP and SP) to +// more efficiently reference locals, as well as handle situations where +// locals cannot be referenced via SP or FP at all (dynamic stack realignment +// together with variable sized objects, for example). +cl::opt<bool> EnableLocalStackAlloc("enable-local-stack-alloc", cl::init(false), + cl::Hidden, cl::desc("Enable pre-regalloc stack frame index allocation")); static cl::opt<cl::boolOrDefault> AsmVerbose("asm-verbose", cl::desc("Add comments to directives."), @@ -344,6 +354,12 @@ bool LLVMTargetMachine::addCommonCodeGenPasses(PassManagerBase &PM, if (OptLevel != CodeGenOpt::None) PM.add(createOptimizePHIsPass()); + // Assign local variables to stack slots relative to one another and simplify + // frame index references where possible. Final stack slot locations will be + // assigned in PEI. + if (EnableLocalStackAlloc) + PM.add(createLocalStackSlotAllocationPass()); + if (OptLevel != CodeGenOpt::None) { // With optimization, dead code should already be eliminated. However // there is one known exception: lowered code for arguments that are only |