blob: 104744279d9d1e01cf887e36ae976ba955f268b8 [file] [log] [blame]
Chris Lattner7ff4a942009-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//===----------------------------------------------------------------------===//
Benjamin Kramera7c40ef2014-08-13 16:26:38 +000013#ifndef LLVM_LIB_TARGET_SPARC_SPARCMACHINEFUNCTIONINFO_H
14#define LLVM_LIB_TARGET_SPARC_SPARCMACHINEFUNCTIONINFO_H
Chris Lattner7ff4a942009-09-15 18:03:13 +000015
16#include "llvm/CodeGen/MachineFunction.h"
17
18namespace llvm {
19
20 class SparcMachineFunctionInfo : public MachineFunctionInfo {
David Blaikiea379b1812011-12-20 02:50:00 +000021 virtual void anchor();
Chris Lattner7ff4a942009-09-15 18:03:13 +000022 private:
23 unsigned GlobalBaseReg;
Dan Gohman31ae5862010-04-17 14:41:14 +000024
25 /// VarArgsFrameOffset - Frame offset to start of varargs area.
26 int VarArgsFrameOffset;
27
Venkatraman Govindarajucc91b7a2011-01-22 13:05:16 +000028 /// SRetReturnReg - Holds the virtual register into which the sret
29 /// argument is passed.
30 unsigned SRetReturnReg;
Venkatraman Govindarajuca0fe2f52013-05-29 04:46:31 +000031
32 /// IsLeafProc - True if the function is a leaf procedure.
33 bool IsLeafProc;
Chris Lattner7ff4a942009-09-15 18:03:13 +000034 public:
Venkatraman Govindarajucc91b7a2011-01-22 13:05:16 +000035 SparcMachineFunctionInfo()
Venkatraman Govindarajuca0fe2f52013-05-29 04:46:31 +000036 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
37 IsLeafProc(false) {}
Dan Gohman31ae5862010-04-17 14:41:14 +000038 explicit SparcMachineFunctionInfo(MachineFunction &MF)
Venkatraman Govindarajuca0fe2f52013-05-29 04:46:31 +000039 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
40 IsLeafProc(false) {}
Chris Lattner7ff4a942009-09-15 18:03:13 +000041
42 unsigned getGlobalBaseReg() const { return GlobalBaseReg; }
43 void setGlobalBaseReg(unsigned Reg) { GlobalBaseReg = Reg; }
Dan Gohman31ae5862010-04-17 14:41:14 +000044
45 int getVarArgsFrameOffset() const { return VarArgsFrameOffset; }
46 void setVarArgsFrameOffset(int Offset) { VarArgsFrameOffset = Offset; }
Venkatraman Govindarajucc91b7a2011-01-22 13:05:16 +000047
48 unsigned getSRetReturnReg() const { return SRetReturnReg; }
49 void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; }
Venkatraman Govindarajuca0fe2f52013-05-29 04:46:31 +000050
51 void setLeafProc(bool rhs) { IsLeafProc = rhs; }
52 bool isLeafProc() const { return IsLeafProc; }
Chris Lattner7ff4a942009-09-15 18:03:13 +000053 };
Alexander Kornienkof00654e2015-06-23 09:49:53 +000054}
Chris Lattner7ff4a942009-09-15 18:03:13 +000055
56#endif