blob: 0b74308eb0ee301411034a42ce15f91f01064460 [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 {
21 private:
22 unsigned GlobalBaseReg;
Dan Gohman1e93df62010-04-17 14:41:14 +000023
24 /// VarArgsFrameOffset - Frame offset to start of varargs area.
25 int VarArgsFrameOffset;
26
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000027 /// SRetReturnReg - Holds the virtual register into which the sret
28 /// argument is passed.
29 unsigned SRetReturnReg;
Chris Lattnerea7fd962009-09-15 18:03:13 +000030 public:
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000031 SparcMachineFunctionInfo()
32 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0) {}
Dan Gohman1e93df62010-04-17 14:41:14 +000033 explicit SparcMachineFunctionInfo(MachineFunction &MF)
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000034 : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0) {}
Chris Lattnerea7fd962009-09-15 18:03:13 +000035
36 unsigned getGlobalBaseReg() const { return GlobalBaseReg; }
37 void setGlobalBaseReg(unsigned Reg) { GlobalBaseReg = Reg; }
Dan Gohman1e93df62010-04-17 14:41:14 +000038
39 int getVarArgsFrameOffset() const { return VarArgsFrameOffset; }
40 void setVarArgsFrameOffset(int Offset) { VarArgsFrameOffset = Offset; }
Venkatraman Govindaraju8184e282011-01-22 13:05:16 +000041
42 unsigned getSRetReturnReg() const { return SRetReturnReg; }
43 void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; }
Chris Lattnerea7fd962009-09-15 18:03:13 +000044 };
45}
46
47#endif