xref: /freebsd/contrib/llvm-project/llvm/lib/Target/Sparc/SparcMachineFunctionInfo.h (revision 5ca8e32633c4ffbbcd6762e5888b6a4ba0708c6c)
1 //===- SparcMachineFunctionInfo.h - Sparc Machine Function Info -*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file declares  Sparc specific per-machine-function information.
10 //
11 //===----------------------------------------------------------------------===//
12 #ifndef LLVM_LIB_TARGET_SPARC_SPARCMACHINEFUNCTIONINFO_H
13 #define LLVM_LIB_TARGET_SPARC_SPARCMACHINEFUNCTIONINFO_H
14 
15 #include "llvm/CodeGen/MachineFunction.h"
16 
17 namespace llvm {
18 
19   class SparcMachineFunctionInfo : public MachineFunctionInfo {
20     virtual void anchor();
21   private:
22     Register GlobalBaseReg;
23 
24     /// VarArgsFrameOffset - Frame offset to start of varargs area.
25     int VarArgsFrameOffset;
26 
27     /// SRetReturnReg - Holds the virtual register into which the sret
28     /// argument is passed.
29     Register SRetReturnReg;
30 
31     /// IsLeafProc - True if the function is a leaf procedure.
32     bool IsLeafProc;
33   public:
34     SparcMachineFunctionInfo()
35       : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
36         IsLeafProc(false) {}
37     SparcMachineFunctionInfo(const Function &F, const TargetSubtargetInfo *STI)
38         : GlobalBaseReg(0), VarArgsFrameOffset(0), SRetReturnReg(0),
39           IsLeafProc(false) {}
40 
41     MachineFunctionInfo *
42     clone(BumpPtrAllocator &Allocator, MachineFunction &DestMF,
43           const DenseMap<MachineBasicBlock *, MachineBasicBlock *> &Src2DstMBB)
44         const override;
45 
46     Register getGlobalBaseReg() const { return GlobalBaseReg; }
47     void setGlobalBaseReg(Register Reg) { GlobalBaseReg = Reg; }
48 
49     int getVarArgsFrameOffset() const { return VarArgsFrameOffset; }
50     void setVarArgsFrameOffset(int Offset) { VarArgsFrameOffset = Offset; }
51 
52     Register getSRetReturnReg() const { return SRetReturnReg; }
53     void setSRetReturnReg(Register Reg) { SRetReturnReg = Reg; }
54 
55     void setLeafProc(bool rhs) { IsLeafProc = rhs; }
56     bool isLeafProc() const { return IsLeafProc; }
57   };
58 }
59 
60 #endif
61