blob: 383fd2e9821c44d7b9395d9f2f24409cb2ea1693 [file] [log] [blame]
Anton Korobeynikovd5047cb2009-05-03 13:11:04 +00001//===- MSP430MachineFuctionInfo.h - MSP430 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 MSP430-specific per-machine-function information.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef MSP430MACHINEFUNCTIONINFO_H
15#define MSP430MACHINEFUNCTIONINFO_H
16
17#include "llvm/CodeGen/MachineFunction.h"
18
19namespace llvm {
20
21/// MSP430MachineFunctionInfo - This class is derived from MachineFunction and
22/// contains private MSP430 target-specific information for each MachineFunction.
23class MSP430MachineFunctionInfo : public MachineFunctionInfo {
24 /// CalleeSavedFrameSize - Size of the callee-saved register portion of the
25 /// stack frame in bytes.
26 unsigned CalleeSavedFrameSize;
27
Anton Korobeynikov06ccca52009-12-07 02:28:10 +000028 /// ReturnAddrIndex - FrameIndex for return slot.
29 int ReturnAddrIndex;
30
Anton Korobeynikovd5047cb2009-05-03 13:11:04 +000031public:
32 MSP430MachineFunctionInfo() : CalleeSavedFrameSize(0) {}
33
Dan Gohman2392efe2009-06-05 23:05:51 +000034 explicit MSP430MachineFunctionInfo(MachineFunction &MF)
Anton Korobeynikov06ccca52009-12-07 02:28:10 +000035 : CalleeSavedFrameSize(0), ReturnAddrIndex(0) {}
Anton Korobeynikovd5047cb2009-05-03 13:11:04 +000036
37 unsigned getCalleeSavedFrameSize() const { return CalleeSavedFrameSize; }
38 void setCalleeSavedFrameSize(unsigned bytes) { CalleeSavedFrameSize = bytes; }
Anton Korobeynikov06ccca52009-12-07 02:28:10 +000039
40 int getRAIndex() const { return ReturnAddrIndex; }
41 void setRAIndex(int Index) { ReturnAddrIndex = Index; }
Anton Korobeynikovd5047cb2009-05-03 13:11:04 +000042};
43
44} // End llvm namespace
45
46#endif