diff options
| author | Vikram S. Adve <vadve@cs.uiuc.edu> | 2002-04-25 04:35:27 +0000 |
|---|---|---|
| committer | Vikram S. Adve <vadve@cs.uiuc.edu> | 2002-04-25 04:35:27 +0000 |
| commit | b63c4886c492b928f5f4029b5bb596e590733e4c (patch) | |
| tree | 0d11f8720d596ad6aeccf9c52fe1c05281a48a36 /llvm/lib/Target | |
| parent | 7a4b381f807ec04425fca272c4464eb251c3db69 (diff) | |
| download | bcm5719-llvm-b63c4886c492b928f5f4029b5bb596e590733e4c.tar.gz bcm5719-llvm-b63c4886c492b928f5f4029b5bb596e590733e4c.zip | |
Implementation of class MachineFrameInfo.
llvm-svn: 2313
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/MachineFrameInfo.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/llvm/lib/Target/MachineFrameInfo.cpp b/llvm/lib/Target/MachineFrameInfo.cpp new file mode 100644 index 00000000000..be7feee5eec --- /dev/null +++ b/llvm/lib/Target/MachineFrameInfo.cpp @@ -0,0 +1,50 @@ +// $Id$ -*-c++-*- +//*************************************************************************** +// File: +// MachineFrameInfo.cpp +// +// Purpose: +// Interface to layout of stack frame on target machine. +// Most functions of class MachineFrameInfo have to be machine-specific +// so there is little code here. +// +// History: +// 4/17/02 - Vikram Adve - Created +//**************************************************************************/ + + +#include "llvm/Target/MachineFrameInfo.h" +#include "llvm/CodeGen/MachineCodeForMethod.h" + + +int +MachineFrameInfo::getIncomingArgOffset(MachineCodeForMethod& mcInfo, + unsigned argNum) const +{ + assert(argsOnStackHaveFixedSize()); + + unsigned relativeOffset = argNum * getSizeOfEachArgOnStack(); + bool growUp; // do args grow up or down + int firstArg = getFirstIncomingArgOffset(mcInfo, growUp); + int offset = growUp? firstArg + relativeOffset + : firstArg - relativeOffset; + return offset; +} + + +int +MachineFrameInfo::getOutgoingArgOffset(MachineCodeForMethod& mcInfo, + unsigned argNum) const +{ + assert(argsOnStackHaveFixedSize()); + assert(((int) argNum - this->getNumFixedOutgoingArgs()) + <= (int) mcInfo.getMaxOptionalNumArgs()); + + unsigned relativeOffset = argNum * getSizeOfEachArgOnStack(); + bool growUp; // do args grow up or down + int firstArg = getFirstOutgoingArgOffset(mcInfo, growUp); + int offset = growUp? firstArg + relativeOffset + : firstArg - relativeOffset; + + return offset; +} |

