diff options
Diffstat (limited to 'llvm/lib/Target/Hexagon/HexagonFrameLowering.h')
-rw-r--r-- | llvm/lib/Target/Hexagon/HexagonFrameLowering.h | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/llvm/lib/Target/Hexagon/HexagonFrameLowering.h b/llvm/lib/Target/Hexagon/HexagonFrameLowering.h index 79e2cf12774..529a61d4a5b 100644 --- a/llvm/lib/Target/Hexagon/HexagonFrameLowering.h +++ b/llvm/lib/Target/Hexagon/HexagonFrameLowering.h @@ -12,7 +12,11 @@ #include "Hexagon.h" #include "HexagonBlockRanges.h" +#include "llvm/ADT/STLExtras.h" +#include "llvm/CodeGen/MachineBasicBlock.h" +#include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/Target/TargetFrameLowering.h" +#include <vector> namespace llvm { @@ -31,11 +35,13 @@ public: override; void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override {} + bool spillCalleeSavedRegisters(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, const std::vector<CalleeSavedInfo> &CSI, const TargetRegisterInfo *TRI) const override { return true; } + bool restoreCalleeSavedRegisters(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, const std::vector<CalleeSavedInfo> &CSI, const TargetRegisterInfo *TRI) const override { @@ -53,6 +59,7 @@ public: bool targetHandlesStackFrameRounding() const override { return true; } + int getFrameIndexReference(const MachineFunction &MF, int FI, unsigned &FrameReg) const override; bool hasFP(const MachineFunction &MF) const override; @@ -147,6 +154,6 @@ private: bool mayOverflowFrameOffset(MachineFunction &MF) const; }; -} // End llvm namespace +} // end namespace llvm -#endif +#endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONFRAMELOWERING_H |