blob: 6571d5d3e603e0a6ce876c630590cd60f9f46d1a [file] [log] [blame]
Dylan McKay751a4492015-12-21 23:13:15 +00001//===-- AVRMachineFuctionInfo.h - AVR 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 AVR-specific per-machine-function information.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_AVR_MACHINE_FUNCTION_INFO_H
15#define LLVM_AVR_MACHINE_FUNCTION_INFO_H
16
17#include "AVRConfig.h"
18
19#include "llvm/CodeGen/MachineFunction.h"
20
21namespace llvm {
22
23/**
24 * Contains AVR-specific information for each MachineFunction.
25 */
26class AVRMachineFunctionInfo : public MachineFunctionInfo {
27 /// Indicates if a register has been spilled by the register
28 /// allocator.
29 bool HasSpills;
30
31 /// Indicates if there are any fixed size allocas present.
32 /// Note that if there are only variable sized allocas this is set to false.
33 bool HasAllocas;
34
35 /// Indicates if arguments passed using the stack are being
36 /// used inside the function.
37 bool HasStackArgs;
38
39 /// Size of the callee-saved register portion of the
40 /// stack frame in bytes.
41 unsigned CalleeSavedFrameSize;
42
43 /// FrameIndex for start of varargs area.
44 int VarArgsFrameIndex;
45
46public:
47 AVRMachineFunctionInfo()
48 : HasSpills(false), HasAllocas(false), HasStackArgs(false),
49 CalleeSavedFrameSize(0), VarArgsFrameIndex(0) {}
50
51 explicit AVRMachineFunctionInfo(MachineFunction &MF)
52 : HasSpills(false), HasAllocas(false), HasStackArgs(false),
53 CalleeSavedFrameSize(0), VarArgsFrameIndex(0) {}
54
55 bool getHasSpills() const { return HasSpills; }
56 void setHasSpills(bool B) { HasSpills = B; }
57
58 bool getHasAllocas() const { return HasAllocas; }
59 void setHasAllocas(bool B) { HasAllocas = B; }
60
61 bool getHasStackArgs() const { return HasStackArgs; }
62 void setHasStackArgs(bool B) { HasStackArgs = B; }
63
64 unsigned getCalleeSavedFrameSize() const { return CalleeSavedFrameSize; }
65 void setCalleeSavedFrameSize(unsigned Bytes) { CalleeSavedFrameSize = Bytes; }
66
67 int getVarArgsFrameIndex() const { return VarArgsFrameIndex; }
68 void setVarArgsFrameIndex(int Idx) { VarArgsFrameIndex = Idx; }
69};
70
71} // end llvm namespace
72
73#endif // LLVM_AVR_MACHINE_FUNCTION_INFO_H