blob: 3783c16d9922ee31aa87dd6376381a94c0ffd84a [file] [log] [blame]
Chris Lattnerea7fd962009-09-15 18:03:13 +00001//===- SparcMachineFunctionInfo.h - Sparc Machine Function Info -*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file declares Sparc specific per-machine-function information.
11//
12//===----------------------------------------------------------------------===//
13#ifndef SPARCMACHINEFUNCTIONINFO_H
14#define SPARCMACHINEFUNCTIONINFO_H
15
16#include "llvm/CodeGen/MachineFunction.h"
17
18namespace llvm {
19
20 class SparcMachineFunctionInfo : public MachineFunctionInfo {
David Blaikie2d24e2a2011-12-20 02:50:00 +000021 virtual void anchor();
Chris Lattnerea7fd962009-09-15 18:03:13 +000022 private:
23 unsigned GlobalBaseReg;
Dan Gohman1e93df62010-04-17 14:41:14 +000024
25 /// VarArgsFrameOffset - Frame offset to start of varargs area.
26 int VarArgsFrameOffset;
27
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000028 /// SRetReturnReg - Holds the virtual register into which the sret
29 /// argument is passed.
30 unsigned SRetReturnReg;
Venkatraman Govindaraju53008692013-05-29 04:46:31 +000031
32 /// IsLeafProc - True if the function is a leaf procedure.
33 bool IsLeafProc;
Chris Lattnerea7fd962009-09-15 18:03:13 +000034 public:
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000035 SparcMachineFunctionInfo()
Venkatraman Govindaraju53008692013-05-29 04:46:31 +000036 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
37 IsLeafProc(false) {}
Dan Gohman1e93df62010-04-17 14:41:14 +000038 explicit SparcMachineFunctionInfo(MachineFunction &MF)
Venkatraman Govindaraju53008692013-05-29 04:46:31 +000039 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
40 IsLeafProc(false) {}
Chris Lattnerea7fd962009-09-15 18:03:13 +000041
42 unsigned getGlobalBaseReg() const { return GlobalBaseReg; }
43 void setGlobalBaseReg(unsigned Reg) { GlobalBaseReg = Reg; }
Dan Gohman1e93df62010-04-17 14:41:14 +000044
45 int getVarArgsFrameOffset() const { return VarArgsFrameOffset; }
46 void setVarArgsFrameOffset(int Offset) { VarArgsFrameOffset = Offset; }
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000047
48 unsigned getSRetReturnReg() const { return SRetReturnReg; }
49 void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; }
Venkatraman Govindaraju53008692013-05-29 04:46:31 +000050
51 void setLeafProc(bool rhs) { IsLeafProc = rhs; }
52 bool isLeafProc() const { return IsLeafProc; }
Chris Lattnerea7fd962009-09-15 18:03:13 +000053 };
54}
55
56#endif