summaryrefslogtreecommitdiff
path: root/include/llvm/CodeGen/MachineFrameInfo.h
diff options
context:
space:
mode:
authorNate Begeman <natebegeman@mac.com>2005-11-06 09:00:38 +0000
committerNate Begeman <natebegeman@mac.com>2005-11-06 09:00:38 +0000
commitae232e7a1055033436370c0b3aecf054fa44d5e7 (patch)
treeb9035d7d7c38852ba20e32f8216bdbddf7d7b86e /include/llvm/CodeGen/MachineFrameInfo.h
parentce5e04e710c69382e33137bada9768f642ec95fd (diff)
downloadllvm-ae232e7a1055033436370c0b3aecf054fa44d5e7.tar.gz
llvm-ae232e7a1055033436370c0b3aecf054fa44d5e7.tar.bz2
llvm-ae232e7a1055033436370c0b3aecf054fa44d5e7.tar.xz
Add the necessary support to the ISel to allow targets to codegen the new
alignment information appropriately. Includes code for PowerPC to support fixed-size allocas with alignment larger than the stack. Support for arbitrarily aligned dynamic allocas coming soon. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24224 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/CodeGen/MachineFrameInfo.h')
-rw-r--r--include/llvm/CodeGen/MachineFrameInfo.h19
1 files changed, 18 insertions, 1 deletions
diff --git a/include/llvm/CodeGen/MachineFrameInfo.h b/include/llvm/CodeGen/MachineFrameInfo.h
index 8f8a852480..6720758e64 100644
--- a/include/llvm/CodeGen/MachineFrameInfo.h
+++ b/include/llvm/CodeGen/MachineFrameInfo.h
@@ -85,6 +85,13 @@ class MachineFrameInfo {
/// to be allocated on entry to the function.
///
unsigned StackSize;
+
+ /// MaxAlignment - The prolog/epilog code inserter may process objects
+ /// that require greater alignment than the default alignment the target
+ /// provides. In these cases, MaxAlignment is set to the new alignment
+ /// necessary to easily calculate fixed offsets for each stack object.
+ ///
+ unsigned MaxAlignment;
/// HasCalls - Set to true if this function has any function calls. This is
/// only valid during and after prolog/epilog code insertion.
@@ -99,7 +106,7 @@ class MachineFrameInfo {
unsigned MaxCallFrameSize;
public:
MachineFrameInfo() {
- NumFixedObjects = StackSize = 0;
+ NumFixedObjects = StackSize = MaxAlignment = 0;
HasVarSizedObjects = false;
HasCalls = false;
MaxCallFrameSize = 0;
@@ -163,6 +170,16 @@ public:
///
void setStackSize(unsigned Size) { StackSize = Size; }
+ /// getMaxAlignment - Return the alignment in bytes that this function must be
+ /// aligned to, which is greater than the default stack alignment provided by
+ /// the target.
+ ///
+ unsigned getMaxAlignment() const { return MaxAlignment; }
+
+ /// setMaxAlignment - Set the preferred alignment.
+ ///
+ void setMaxAlignment(unsigned Align) { MaxAlignment = Align; }
+
/// hasCalls - Return true if the current function has no function calls.
/// This is only valid during or after prolog/epilog code emission.
///