aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/Target/TargetFrameInfo.h
blob: 4f19cc95c3cbf421f3bacc658679a6083c36b91e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// $Id$ -*-c++-*-
//***************************************************************************
// File:
//	MachineFrameInfo.h
// 
// Purpose:
//	Interface to layout of stack frame on target machine.
// 
// History:
//	11/6/01	 -  Vikram Adve  -  Created
//**************************************************************************/

#ifndef LLVM_CODEGEN_FRAMEINFO_H
#define LLVM_CODEGEN_FRAMEINFO_H

#include "llvm/Support/NonCopyable.h"
#include <vector>


//************************* Forward Declarations **************************/

class MachineCodeForMethod;


//*************************** External Classes ****************************/


class MachineFrameInfo : public NonCopyableV {
public:
  const TargetMachine& target;
  
public:
  /*ctor*/ MachineFrameInfo(const TargetMachine& tgt) : target(tgt) {}
  
  //
  // These methods provide constant parameters of the frame layout.
  // 
  virtual int  getStackFrameSizeAlignment       () const = 0;
  virtual int  getMinStackFrameSize             () const = 0;
  virtual int  getNumFixedOutgoingArgs          () const = 0;
  virtual int  getSizeOfEachArgOnStack          () const = 0;
  virtual bool argsOnStackHaveFixedSize         () const = 0;
  
  //
  // These methods compute offsets using the frame contents for a
  // particular method.  The frame contents are obtained from the
  // MachineCodeInfoForMethod object for the given method.
  // 
  virtual int getFirstIncomingArgOffset         (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;
  virtual int getFirstOutgoingArgOffset         (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;
  virtual int getFirstOptionalOutgoingArgOffset (MachineCodeForMethod&,
                                                 bool& pos) const=0;
  virtual int getFirstAutomaticVarOffset        (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;
  virtual int getRegSpillAreaOffset             (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;
  virtual int getTmpAreaOffset                  (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;
  virtual int getDynamicAreaOffset              (MachineCodeForMethod& mcInfo,
                                                 bool& pos) const=0;

  //
  // These methods specify the base register used for each stack area
  // (generally FP or SP)
  // 
  virtual int getIncomingArgBaseRegNum()               const=0;
  virtual int getOutgoingArgBaseRegNum()               const=0;
  virtual int getOptionalOutgoingArgBaseRegNum()       const=0;
  virtual int getAutomaticVarBaseRegNum()              const=0;
  virtual int getRegSpillAreaBaseRegNum()              const=0;
  virtual int getDynamicAreaBaseRegNum()               const=0;
};

#endif