summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/AVR/AVRFrameLowering.h
diff options
context:
space:
mode:
authorDylan McKay <dylanmckay34@gmail.com>2016-05-06 10:12:31 +0000
committerDylan McKay <dylanmckay34@gmail.com>2016-05-06 10:12:31 +0000
commit6d8078f9937f5dce3283b218fd3c3403dc899fcf (patch)
treecf113645c0d6bc58081f366428a5c818bbee16ad /llvm/lib/Target/AVR/AVRFrameLowering.h
parentc7a82b41a706728ce7c212b5bc40c74d1cce53c7 (diff)
downloadbcm5719-llvm-6d8078f9937f5dce3283b218fd3c3403dc899fcf.tar.gz
bcm5719-llvm-6d8078f9937f5dce3283b218fd3c3403dc899fcf.zip
[AVR] Add a majority of the backend code
Summary: This adds the majority of the AVR backend. Reviewers: hfinkel, dsanders, vkalintiris, arsenm Subscribers: dylanmckay Differential Revision: http://reviews.llvm.org/D17906 llvm-svn: 268722
Diffstat (limited to 'llvm/lib/Target/AVR/AVRFrameLowering.h')
-rw-r--r--llvm/lib/Target/AVR/AVRFrameLowering.h48
1 files changed, 48 insertions, 0 deletions
diff --git a/llvm/lib/Target/AVR/AVRFrameLowering.h b/llvm/lib/Target/AVR/AVRFrameLowering.h
new file mode 100644
index 00000000000..4b91cfd4c3f
--- /dev/null
+++ b/llvm/lib/Target/AVR/AVRFrameLowering.h
@@ -0,0 +1,48 @@
+//===-- AVRFrameLowering.h - Define frame lowering for AVR ------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLVM_AVR_FRAME_LOWERING_H
+#define LLVM_AVR_FRAME_LOWERING_H
+
+#include "AVRConfig.h"
+
+#include "llvm/Target/TargetFrameLowering.h"
+
+namespace llvm {
+
+/// Utilities for creating function call frames.
+class AVRFrameLowering : public TargetFrameLowering {
+public:
+ explicit AVRFrameLowering();
+
+public:
+ void emitPrologue(MachineFunction &MF, MachineBasicBlock &MBB) const override;
+ void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override;
+ bool hasFP(const MachineFunction &MF) const override;
+ bool spillCalleeSavedRegisters(MachineBasicBlock &MBB,
+ MachineBasicBlock::iterator MI,
+ const std::vector<CalleeSavedInfo> &CSI,
+ const TargetRegisterInfo *TRI) const override;
+ bool
+ restoreCalleeSavedRegisters(MachineBasicBlock &MBB,
+ MachineBasicBlock::iterator MI,
+ const std::vector<CalleeSavedInfo> &CSI,
+ const TargetRegisterInfo *TRI) const override;
+ bool hasReservedCallFrame(const MachineFunction &MF) const override;
+ bool canSimplifyCallFramePseudos(const MachineFunction &MF) const override;
+ void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs,
+ RegScavenger *RS = nullptr) const override;
+ void
+ eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB,
+ MachineBasicBlock::iterator MI) const override;
+};
+
+} // end namespace llvm
+
+#endif // LLVM_AVR_FRAME_LOWERING_H
OpenPOWER on IntegriCloud