diff options
author | Akira Hatanaka <ahatanaka@mips.com> | 2011-11-07 19:06:10 +0000 |
---|---|---|
committer | Akira Hatanaka <ahatanaka@mips.com> | 2011-11-07 19:06:10 +0000 |
commit | 7bcecd486f64c8fb4fa16229ff10ad94f27aed9f (patch) | |
tree | 1086199b5046c8dcbd933c919bb80fe9bc17750a /llvm/lib/Target/Mips/MipsMachineFunction.h | |
parent | d9c2e46cfba9565e739259ac2df9b306c06e31f0 (diff) | |
download | bcm5719-llvm-7bcecd486f64c8fb4fa16229ff10ad94f27aed9f.tar.gz bcm5719-llvm-7bcecd486f64c8fb4fa16229ff10ad94f27aed9f.zip |
Define functions that get or set the size of area on callee's stack frame which
is used to save va_arg or byval arguments passed in registers.
llvm-svn: 143992
Diffstat (limited to 'llvm/lib/Target/Mips/MipsMachineFunction.h')
-rw-r--r-- | llvm/lib/Target/Mips/MipsMachineFunction.h | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/llvm/lib/Target/Mips/MipsMachineFunction.h b/llvm/lib/Target/Mips/MipsMachineFunction.h index bc30b6b2425..be27606ed8e 100644 --- a/llvm/lib/Target/Mips/MipsMachineFunction.h +++ b/llvm/lib/Target/Mips/MipsMachineFunction.h @@ -51,12 +51,16 @@ private: mutable int DynAllocFI; // Frame index of dynamically allocated stack area. unsigned MaxCallFrameSize; + // Size of area on callee's stack frame which is used to save va_arg or + // byval arguments passed in registers. + unsigned RegSaveAreaSize; + public: MipsFunctionInfo(MachineFunction& MF) : MF(MF), SRetReturnReg(0), GlobalBaseReg(0), VarArgsFrameIndex(0), InArgFIRange(std::make_pair(-1, 0)), OutArgFIRange(std::make_pair(-1, 0)), GPFI(0), DynAllocFI(0), - MaxCallFrameSize(0) + MaxCallFrameSize(0), RegSaveAreaSize(0) {} bool isInArgFI(int FI) const { @@ -100,6 +104,11 @@ public: unsigned getMaxCallFrameSize() const { return MaxCallFrameSize; } void setMaxCallFrameSize(unsigned S) { MaxCallFrameSize = S; } + + unsigned getRegSaveAreaSize() const { return RegSaveAreaSize; } + void setRegSaveAreaSize(unsigned S) { + if (RegSaveAreaSize < S) RegSaveAreaSize = S; + } }; } // end of namespace llvm |