mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-25 14:02:52 +02:00
77b263e187
SystemZ wants normal register scavenging slots, as close to the stack or frame pointer as possible. The only reason it was using custom code was because PrologEpilogInserter assumed an x86-like layout, where the frame pointer is at the opposite end of the frame from the stack pointer. This meant that when frame pointer elimination was disabled, the slots ended up being as close as possible to the incoming stack pointer, which is the opposite of what we want on SystemZ. This patch adds a new knob to say which layout is used and converts SystemZ to use target-independent scavenging slots. It's one of the pieces needed to support frame-to-frame MVCs, where two slots might be required. The ABI requires us to allocate 160 bytes for calls, so one approach would be to use that area as temporary spill space instead. It would need some surgery to make sure that the slot isn't live across a call though. I stuck to the "isFPCloseToIncomingSP - ..." style comment on the "do what the surrounding code does" principle. The FP case is already covered by several Systemz/frame-* tests, which fail without the PrologueEpilogueInserter change, so no new ones are needed. No behavioural change intended. llvm-svn: 185696
65 lines
1.9 KiB
C++
65 lines
1.9 KiB
C++
//===-- SystemZRegisterInfo.h - SystemZ register information ----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SystemZREGISTERINFO_H
|
|
#define SystemZREGISTERINFO_H
|
|
|
|
#include "SystemZ.h"
|
|
#include "llvm/Target/TargetRegisterInfo.h"
|
|
|
|
#define GET_REGINFO_HEADER
|
|
#include "SystemZGenRegisterInfo.inc"
|
|
|
|
namespace llvm {
|
|
|
|
namespace SystemZ {
|
|
// Return the subreg to use for referring to the even and odd registers
|
|
// in a GR128 pair. Is32Bit says whether we want a GR32 or GR64.
|
|
inline unsigned even128(bool Is32bit) {
|
|
return Is32bit ? subreg_32bit : subreg_high;
|
|
}
|
|
inline unsigned odd128(bool Is32bit) {
|
|
return Is32bit ? subreg_low32 : subreg_low;
|
|
}
|
|
}
|
|
|
|
class SystemZSubtarget;
|
|
class SystemZInstrInfo;
|
|
|
|
struct SystemZRegisterInfo : public SystemZGenRegisterInfo {
|
|
private:
|
|
SystemZTargetMachine &TM;
|
|
|
|
public:
|
|
SystemZRegisterInfo(SystemZTargetMachine &tm);
|
|
|
|
// Override TargetRegisterInfo.h.
|
|
virtual bool requiresRegisterScavenging(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE {
|
|
return true;
|
|
}
|
|
virtual bool requiresFrameIndexScavenging(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE {
|
|
return true;
|
|
}
|
|
virtual const uint16_t *getCalleeSavedRegs(const MachineFunction *MF = 0)
|
|
const LLVM_OVERRIDE;
|
|
virtual BitVector getReservedRegs(const MachineFunction &MF)
|
|
const LLVM_OVERRIDE;
|
|
virtual void eliminateFrameIndex(MachineBasicBlock::iterator MI,
|
|
int SPAdj, unsigned FIOperandNum,
|
|
RegScavenger *RS) const LLVM_OVERRIDE;
|
|
virtual unsigned getFrameRegister(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE;
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|