blob: 90c27a4459a11ed2554dece962675dd503c207dc [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;
Chris Lattnerea7fd962009-09-15 18:03:13 +000031 public:
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000032 SparcMachineFunctionInfo()
33 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0) {}
Dan Gohman1e93df62010-04-17 14:41:14 +000034 explicit SparcMachineFunctionInfo(MachineFunction &MF)
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000035 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0) {}
Chris Lattnerea7fd962009-09-15 18:03:13 +000036
37 unsigned getGlobalBaseReg() const { return GlobalBaseReg; }
38 void setGlobalBaseReg(unsigned Reg) { GlobalBaseReg = Reg; }
Dan Gohman1e93df62010-04-17 14:41:14 +000039
40 int getVarArgsFrameOffset() const { return VarArgsFrameOffset; }
41 void setVarArgsFrameOffset(int Offset) { VarArgsFrameOffset = Offset; }
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000042
43 unsigned getSRetReturnReg() const { return SRetReturnReg; }
44 void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; }
Chris Lattnerea7fd962009-09-15 18:03:13 +000045 };
46}
47
48#endif