mirror of
https://github.com/opnsense/src.git
synced 2026-02-23 18:00:31 -05:00
all of the features in the current working draft of the upcoming C++ standard, provisionally named C++1y. The code generator's performance is greatly increased, and the loop auto-vectorizer is now enabled at -Os and -O2 in addition to -O3. The PowerPC backend has made several major improvements to code generation quality and compile time, and the X86, SPARC, ARM32, Aarch64 and SystemZ backends have all seen major feature work. Release notes for llvm and clang can be found here: <http://llvm.org/releases/3.4/docs/ReleaseNotes.html> <http://llvm.org/releases/3.4/tools/clang/docs/ReleaseNotes.html> MFC after: 1 month
78 lines
3 KiB
C++
78 lines
3 KiB
C++
//===-- SystemZFrameLowering.h - Frame lowering for SystemZ -----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SYSTEMZFRAMELOWERING_H
|
|
#define SYSTEMZFRAMELOWERING_H
|
|
|
|
#include "SystemZSubtarget.h"
|
|
#include "llvm/ADT/IndexedMap.h"
|
|
#include "llvm/Target/TargetFrameLowering.h"
|
|
|
|
namespace llvm {
|
|
class SystemZTargetMachine;
|
|
class SystemZSubtarget;
|
|
|
|
class SystemZFrameLowering : public TargetFrameLowering {
|
|
IndexedMap<unsigned> RegSpillOffsets;
|
|
|
|
protected:
|
|
const SystemZTargetMachine &TM;
|
|
const SystemZSubtarget &STI;
|
|
|
|
public:
|
|
SystemZFrameLowering(const SystemZTargetMachine &tm,
|
|
const SystemZSubtarget &sti);
|
|
|
|
// Override TargetFrameLowering.
|
|
virtual bool isFPCloseToIncomingSP() const LLVM_OVERRIDE { return false; }
|
|
virtual const SpillSlot *getCalleeSavedSpillSlots(unsigned &NumEntries) const
|
|
LLVM_OVERRIDE;
|
|
virtual void
|
|
processFunctionBeforeCalleeSavedScan(MachineFunction &MF,
|
|
RegScavenger *RS) const LLVM_OVERRIDE;
|
|
virtual bool
|
|
spillCalleeSavedRegisters(MachineBasicBlock &MBB,
|
|
MachineBasicBlock::iterator MBBI,
|
|
const std::vector<CalleeSavedInfo> &CSI,
|
|
const TargetRegisterInfo *TRI) const
|
|
LLVM_OVERRIDE;
|
|
virtual bool
|
|
restoreCalleeSavedRegisters(MachineBasicBlock &MBB,
|
|
MachineBasicBlock::iterator MBBII,
|
|
const std::vector<CalleeSavedInfo> &CSI,
|
|
const TargetRegisterInfo *TRI) const
|
|
LLVM_OVERRIDE;
|
|
virtual void processFunctionBeforeFrameFinalized(MachineFunction &MF,
|
|
RegScavenger *RS) const;
|
|
virtual void emitPrologue(MachineFunction &MF) const LLVM_OVERRIDE;
|
|
virtual void emitEpilogue(MachineFunction &MF,
|
|
MachineBasicBlock &MBB) const LLVM_OVERRIDE;
|
|
virtual bool hasFP(const MachineFunction &MF) const LLVM_OVERRIDE;
|
|
virtual int getFrameIndexOffset(const MachineFunction &MF,
|
|
int FI) const LLVM_OVERRIDE;
|
|
virtual bool hasReservedCallFrame(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE;
|
|
virtual void
|
|
eliminateCallFramePseudoInstr(MachineFunction &MF,
|
|
MachineBasicBlock &MBB,
|
|
MachineBasicBlock::iterator MI) const
|
|
LLVM_OVERRIDE;
|
|
|
|
// Return the number of bytes in the callee-allocated part of the frame.
|
|
uint64_t getAllocatedStackSize(const MachineFunction &MF) const;
|
|
|
|
// Return the byte offset from the incoming stack pointer of Reg's
|
|
// ABI-defined save slot. Return 0 if no slot is defined for Reg.
|
|
unsigned getRegSpillOffset(unsigned Reg) const {
|
|
return RegSpillOffsets[Reg];
|
|
}
|
|
};
|
|
} // end namespace llvm
|
|
|
|
#endif
|