* Set the is64bit boolean flag in PowerPCRegisterInfo

* Doubles are 8 bytes in 64-bit PowerPC, and use the general register class
* Use double-word loads and stores for restoring from/saving to stack
* Do not allocate R2 if compiling for AIX


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15670 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Misha Brukman 2004-08-11 23:44:55 +00:00
parent ca9309f22e
commit dceb457607
3 changed files with 30 additions and 18 deletions

View File

@ -77,13 +77,13 @@ def TBU : SPR<5>;
// then nonvolatiles in reverse order since stmw/lmw save from rN to r31 // then nonvolatiles in reverse order since stmw/lmw save from rN to r31
def GPRC : def GPRC :
RegisterClass<i32, 4, RegisterClass<i32, 4,
[R2, R3, R4, R5, R6, R7, R8, R9, R10, R11, R12, [R3, R4, R5, R6, R7, R8, R9, R10, R11, R12,
R31, R30, R29, R28, R27, R26, R25, R24, R23, R22, R21, R20, R19, R18, R17, R31, R30, R29, R28, R27, R26, R25, R24, R23, R22, R21, R20, R19, R18, R17,
R16, R15, R14, R13, R0, R1, LR]> R16, R15, R14, R13, R0, R2, R1, LR]>
{ {
let Methods = [{ let Methods = [{
iterator allocation_order_end(MachineFunction &MF) const { iterator allocation_order_end(MachineFunction &MF) const {
return end()-3; return end() - (AIX ? 4 : 3);
} }
}]; }];
} }

View File

@ -30,9 +30,14 @@
#include <iostream> #include <iostream>
using namespace llvm; using namespace llvm;
PowerPCRegisterInfo::PowerPCRegisterInfo() namespace llvm {
: PowerPCGenRegisterInfo(PPC::ADJCALLSTACKDOWN, // Switch toggling compilation for AIX
PPC::ADJCALLSTACKUP) {} extern cl::opt<bool> AIX;
}
PowerPCRegisterInfo::PowerPCRegisterInfo(bool is64b)
: PowerPCGenRegisterInfo(PPC::ADJCALLSTACKDOWN, PPC::ADJCALLSTACKUP),
is64bit(is64b) {}
static unsigned getIdx(const TargetRegisterClass *RC) { static unsigned getIdx(const TargetRegisterClass *RC) {
if (RC == PowerPC::GPRCRegisterClass) { if (RC == PowerPC::GPRCRegisterClass) {
@ -41,12 +46,13 @@ static unsigned getIdx(const TargetRegisterClass *RC) {
case 1: return 0; case 1: return 0;
case 2: return 1; case 2: return 1;
case 4: return 2; case 4: return 2;
case 8: return 3;
} }
} else if (RC == PowerPC::FPRCRegisterClass) { } else if (RC == PowerPC::FPRCRegisterClass) {
switch (RC->getSize()) { switch (RC->getSize()) {
default: assert(0 && "Invalid data size!"); default: assert(0 && "Invalid data size!");
case 4: return 3; case 4: return 4;
case 8: return 4; case 8: return 5;
} }
} }
std::cerr << "Invalid register class to getIdx()!\n"; std::cerr << "Invalid register class to getIdx()!\n";
@ -59,7 +65,7 @@ PowerPCRegisterInfo::storeRegToStackSlot(MachineBasicBlock &MBB,
unsigned SrcReg, int FrameIdx, unsigned SrcReg, int FrameIdx,
const TargetRegisterClass *RC) const { const TargetRegisterClass *RC) const {
static const unsigned Opcode[] = { static const unsigned Opcode[] = {
PPC::STB, PPC::STH, PPC::STW, PPC::STFS, PPC::STFD PPC::STB, PPC::STH, PPC::STW, PPC::STD, PPC::STFS, PPC::STFD
}; };
unsigned OC = Opcode[getIdx(RC)]; unsigned OC = Opcode[getIdx(RC)];
if (SrcReg == PPC::LR) { if (SrcReg == PPC::LR) {
@ -78,7 +84,7 @@ PowerPCRegisterInfo::loadRegFromStackSlot(MachineBasicBlock &MBB,
unsigned DestReg, int FrameIdx, unsigned DestReg, int FrameIdx,
const TargetRegisterClass *RC) const { const TargetRegisterClass *RC) const {
static const unsigned Opcode[] = { static const unsigned Opcode[] = {
PPC::LBZ, PPC::LHZ, PPC::LWZ, PPC::LFS, PPC::LFD PPC::LBZ, PPC::LHZ, PPC::LWZ, PPC::LD, PPC::LFS, PPC::LFD
}; };
unsigned OC = Opcode[getIdx(RC)]; unsigned OC = Opcode[getIdx(RC)];
if (DestReg == PPC::LR) { if (DestReg == PPC::LR) {
@ -221,17 +227,19 @@ void PowerPCRegisterInfo::emitPrologue(MachineFunction &MF) const {
// adjust stack pointer: r1 -= numbytes // adjust stack pointer: r1 -= numbytes
if (NumBytes <= 32768) { if (NumBytes <= 32768) {
MI = BuildMI(PPC::STWU, 3).addReg(PPC::R1).addSImm(-NumBytes) unsigned StoreOpcode = is64bit ? PPC::STDU : PPC::STWU;
MI = BuildMI(StoreOpcode, 3).addReg(PPC::R1).addSImm(-NumBytes)
.addReg(PPC::R1); .addReg(PPC::R1);
MBB.insert(MBBI, MI); MBB.insert(MBBI, MI);
} else { } else {
int NegNumbytes = -NumBytes; int NegNumbytes = -NumBytes;
unsigned StoreOpcode = is64bit ? PPC::STDUX : PPC::STWUX;
MI = BuildMI(PPC::LIS, 1, PPC::R0).addSImm(NegNumbytes >> 16); MI = BuildMI(PPC::LIS, 1, PPC::R0).addSImm(NegNumbytes >> 16);
MBB.insert(MBBI, MI); MBB.insert(MBBI, MI);
MI = BuildMI(PPC::ORI, 2, PPC::R0).addReg(PPC::R0) MI = BuildMI(PPC::ORI, 2, PPC::R0).addReg(PPC::R0)
.addImm(NegNumbytes & 0xFFFF); .addImm(NegNumbytes & 0xFFFF);
MBB.insert(MBBI, MI); MBB.insert(MBBI, MI);
MI = BuildMI(PPC::STWUX, 3).addReg(PPC::R1).addReg(PPC::R1) MI = BuildMI(StoreOpcode, 3).addReg(PPC::R1).addReg(PPC::R1)
.addReg(PPC::R0); .addReg(PPC::R0);
MBB.insert(MBBI, MI); MBB.insert(MBBI, MI);
} }
@ -249,7 +257,8 @@ void PowerPCRegisterInfo::emitEpilogue(MachineFunction &MF,
unsigned NumBytes = MFI->getStackSize(); unsigned NumBytes = MFI->getStackSize();
if (NumBytes != 0) { if (NumBytes != 0) {
MI = BuildMI(PPC::LWZ, 2, PPC::R1).addSImm(0).addReg(PPC::R1); unsigned Opcode = is64bit ? PPC::LD : PPC::LWZ;
MI = BuildMI(Opcode, 2, PPC::R1).addSImm(0).addReg(PPC::R1);
MBB.insert(MBBI, MI); MBB.insert(MBBI, MI);
} }
} }
@ -259,9 +268,10 @@ void PowerPCRegisterInfo::emitEpilogue(MachineFunction &MF,
const TargetRegisterClass* const TargetRegisterClass*
PowerPCRegisterInfo::getRegClassForType(const Type* Ty) const { PowerPCRegisterInfo::getRegClassForType(const Type* Ty) const {
switch (Ty->getTypeID()) { switch (Ty->getTypeID()) {
case Type::LongTyID:
case Type::ULongTyID: assert(0 && "Long values can't fit in registers!");
default: assert(0 && "Invalid type to getClass!"); default: assert(0 && "Invalid type to getClass!");
case Type::LongTyID:
case Type::ULongTyID:
if (!is64bit) assert(0 && "Long values can't fit in registers!");
case Type::BoolTyID: case Type::BoolTyID:
case Type::SByteTyID: case Type::SByteTyID:
case Type::UByteTyID: case Type::UByteTyID:

View File

@ -21,8 +21,10 @@ namespace llvm {
class Type; class Type;
struct PowerPCRegisterInfo : public PowerPCGenRegisterInfo { class PowerPCRegisterInfo : public PowerPCGenRegisterInfo {
PowerPCRegisterInfo(); bool is64bit;
public:
PowerPCRegisterInfo(bool is64b);
const TargetRegisterClass* getRegClassForType(const Type* Ty) const; const TargetRegisterClass* getRegClassForType(const Type* Ty) const;
/// Code Generation virtual methods... /// Code Generation virtual methods...