mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 20:29:48 +00:00
* 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:
parent
ca9309f22e
commit
dceb457607
@ -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);
|
||||||
}
|
}
|
||||||
}];
|
}];
|
||||||
}
|
}
|
||||||
|
@ -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:
|
||||||
|
@ -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...
|
||||||
|
Loading…
Reference in New Issue
Block a user