diff options
| author | 2020-08-03 15:06:44 +0000 | |
|---|---|---|
| committer | 2020-08-03 15:06:44 +0000 | |
| commit | b64793999546ed8adebaeebd9d8345d18db8927d (patch) | |
| tree | 4357c27b561d73b0e089727c6ed659f2ceff5f47 /gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h | |
| parent | Add support for UTF-8 DISPLAY-HINTs with octet length. For now only (diff) | |
| download | wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.tar.xz wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.zip | |
Remove LLVM 8.0.1 files.
Diffstat (limited to 'gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h')
| -rw-r--r-- | gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h | 96 |
1 files changed, 0 insertions, 96 deletions
diff --git a/gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h b/gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h deleted file mode 100644 index 6c05ab3f10d..00000000000 --- a/gnu/llvm/lib/Target/XCore/XCoreMachineFunctionInfo.h +++ /dev/null @@ -1,96 +0,0 @@ -//===- XCoreMachineFunctionInfo.h - XCore machine function info -*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file declares XCore-specific per-machine-function information. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_LIB_TARGET_XCORE_XCOREMACHINEFUNCTIONINFO_H -#define LLVM_LIB_TARGET_XCORE_XCOREMACHINEFUNCTIONINFO_H - -#include "llvm/CodeGen/MachineBasicBlock.h" -#include "llvm/CodeGen/MachineFrameInfo.h" -#include "llvm/CodeGen/MachineFunction.h" -#include <cassert> -#include <utility> -#include <vector> - -namespace llvm { - -/// XCoreFunctionInfo - This class is derived from MachineFunction private -/// XCore target-specific information for each MachineFunction. -class XCoreFunctionInfo : public MachineFunctionInfo { - bool LRSpillSlotSet = false; - int LRSpillSlot; - bool FPSpillSlotSet = false; - int FPSpillSlot; - bool EHSpillSlotSet = false; - int EHSpillSlot[2]; - unsigned ReturnStackOffset; - bool ReturnStackOffsetSet = false; - int VarArgsFrameIndex = 0; - mutable int CachedEStackSize = -1; - std::vector<std::pair<MachineBasicBlock::iterator, CalleeSavedInfo>> - SpillLabels; - - virtual void anchor(); - -public: - XCoreFunctionInfo() = default; - - explicit XCoreFunctionInfo(MachineFunction &MF) {} - - ~XCoreFunctionInfo() override = default; - - void setVarArgsFrameIndex(int off) { VarArgsFrameIndex = off; } - int getVarArgsFrameIndex() const { return VarArgsFrameIndex; } - - int createLRSpillSlot(MachineFunction &MF); - bool hasLRSpillSlot() { return LRSpillSlotSet; } - int getLRSpillSlot() const { - assert(LRSpillSlotSet && "LR Spill slot not set"); - return LRSpillSlot; - } - - int createFPSpillSlot(MachineFunction &MF); - bool hasFPSpillSlot() { return FPSpillSlotSet; } - int getFPSpillSlot() const { - assert(FPSpillSlotSet && "FP Spill slot not set"); - return FPSpillSlot; - } - - const int* createEHSpillSlot(MachineFunction &MF); - bool hasEHSpillSlot() { return EHSpillSlotSet; } - const int* getEHSpillSlot() const { - assert(EHSpillSlotSet && "EH Spill slot not set"); - return EHSpillSlot; - } - - void setReturnStackOffset(unsigned value) { - assert(!ReturnStackOffsetSet && "Return stack offset set twice"); - ReturnStackOffset = value; - ReturnStackOffsetSet = true; - } - - unsigned getReturnStackOffset() const { - assert(ReturnStackOffsetSet && "Return stack offset not set"); - return ReturnStackOffset; - } - - bool isLargeFrame(const MachineFunction &MF) const; - - std::vector<std::pair<MachineBasicBlock::iterator, CalleeSavedInfo>> & - getSpillLabels() { - return SpillLabels; - } -}; - -} // end namespace llvm - -#endif // LLVM_LIB_TARGET_XCORE_XCOREMACHINEFUNCTIONINFO_H |
