mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-04 18:09:20 +00:00
Add more debugging output to ARMConstantIslandPass.
llvm-svn: 153788
This commit is contained in:
parent
188c9214c3
commit
91f86a31e7
@ -346,11 +346,19 @@ void ARMConstantIslands::verify() {
|
|||||||
assert(BBInfo[MBBId].Offset % (1u << Align) == 0);
|
assert(BBInfo[MBBId].Offset % (1u << Align) == 0);
|
||||||
assert(!MBBId || BBInfo[MBBId - 1].postOffset() <= BBInfo[MBBId].Offset);
|
assert(!MBBId || BBInfo[MBBId - 1].postOffset() <= BBInfo[MBBId].Offset);
|
||||||
}
|
}
|
||||||
|
DEBUG(dbgs() << "Verifying " << CPUsers.size() << " CP users.\n");
|
||||||
for (unsigned i = 0, e = CPUsers.size(); i != e; ++i) {
|
for (unsigned i = 0, e = CPUsers.size(); i != e; ++i) {
|
||||||
CPUser &U = CPUsers[i];
|
CPUser &U = CPUsers[i];
|
||||||
unsigned UserOffset = getUserOffset(U);
|
unsigned UserOffset = getUserOffset(U);
|
||||||
assert(isCPEntryInRange(U.MI, UserOffset, U.CPEMI, U.getMaxDisp(),
|
if (isCPEntryInRange(U.MI, UserOffset, U.CPEMI, U.getMaxDisp(), U.NegOk,
|
||||||
U.NegOk) && "Constant pool entry out of range!");
|
/* DoDump = */ true)) {
|
||||||
|
DEBUG(dbgs() << "OK\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
DEBUG(dbgs() << "Out of range.\n");
|
||||||
|
dumpBBs();
|
||||||
|
DEBUG(MF->dump());
|
||||||
|
llvm_unreachable("Constant pool entry out of range!");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -1742,6 +1750,7 @@ bool ARMConstantIslands::optimizeThumb2Instructions() {
|
|||||||
|
|
||||||
// FIXME: Check if offset is multiple of scale if scale is not 4.
|
// FIXME: Check if offset is multiple of scale if scale is not 4.
|
||||||
if (isCPEntryInRange(U.MI, UserOffset, U.CPEMI, MaxOffs, false, true)) {
|
if (isCPEntryInRange(U.MI, UserOffset, U.CPEMI, MaxOffs, false, true)) {
|
||||||
|
DEBUG(dbgs() << "Shrink: " << *U.MI);
|
||||||
U.MI->setDesc(TII->get(NewOpc));
|
U.MI->setDesc(TII->get(NewOpc));
|
||||||
MachineBasicBlock *MBB = U.MI->getParent();
|
MachineBasicBlock *MBB = U.MI->getParent();
|
||||||
BBInfo[MBB->getNumber()].Size -= 2;
|
BBInfo[MBB->getNumber()].Size -= 2;
|
||||||
@ -1783,6 +1792,7 @@ bool ARMConstantIslands::optimizeThumb2Branches() {
|
|||||||
unsigned MaxOffs = ((1 << (Bits-1))-1) * Scale;
|
unsigned MaxOffs = ((1 << (Bits-1))-1) * Scale;
|
||||||
MachineBasicBlock *DestBB = Br.MI->getOperand(0).getMBB();
|
MachineBasicBlock *DestBB = Br.MI->getOperand(0).getMBB();
|
||||||
if (isBBInRange(Br.MI, DestBB, MaxOffs)) {
|
if (isBBInRange(Br.MI, DestBB, MaxOffs)) {
|
||||||
|
DEBUG(dbgs() << "Shrink branch: " << *Br.MI);
|
||||||
Br.MI->setDesc(TII->get(NewOpc));
|
Br.MI->setDesc(TII->get(NewOpc));
|
||||||
MachineBasicBlock *MBB = Br.MI->getParent();
|
MachineBasicBlock *MBB = Br.MI->getParent();
|
||||||
BBInfo[MBB->getNumber()].Size -= 2;
|
BBInfo[MBB->getNumber()].Size -= 2;
|
||||||
@ -1826,6 +1836,7 @@ bool ARMConstantIslands::optimizeThumb2Branches() {
|
|||||||
CmpMI->getOperand(1).getImm() == 0 &&
|
CmpMI->getOperand(1).getImm() == 0 &&
|
||||||
isARMLowRegister(Reg)) {
|
isARMLowRegister(Reg)) {
|
||||||
MachineBasicBlock *MBB = Br.MI->getParent();
|
MachineBasicBlock *MBB = Br.MI->getParent();
|
||||||
|
DEBUG(dbgs() << "Fold: " << *CmpMI << " and: " << *Br.MI);
|
||||||
MachineInstr *NewBR =
|
MachineInstr *NewBR =
|
||||||
BuildMI(*MBB, CmpMI, Br.MI->getDebugLoc(), TII->get(NewOpc))
|
BuildMI(*MBB, CmpMI, Br.MI->getDebugLoc(), TII->get(NewOpc))
|
||||||
.addReg(Reg).addMBB(DestBB,Br.MI->getOperand(0).getTargetFlags());
|
.addReg(Reg).addMBB(DestBB,Br.MI->getOperand(0).getTargetFlags());
|
||||||
@ -1942,11 +1953,14 @@ bool ARMConstantIslands::optimizeThumb2JumpTables() {
|
|||||||
if (!OptOk)
|
if (!OptOk)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
DEBUG(dbgs() << "Shrink JT: " << *MI << " addr: " << *AddrMI
|
||||||
|
<< " lea: " << *LeaMI);
|
||||||
unsigned Opc = ByteOk ? ARM::t2TBB_JT : ARM::t2TBH_JT;
|
unsigned Opc = ByteOk ? ARM::t2TBB_JT : ARM::t2TBH_JT;
|
||||||
MachineInstr *NewJTMI = BuildMI(MBB, MI->getDebugLoc(), TII->get(Opc))
|
MachineInstr *NewJTMI = BuildMI(MBB, MI->getDebugLoc(), TII->get(Opc))
|
||||||
.addReg(IdxReg, getKillRegState(IdxRegKill))
|
.addReg(IdxReg, getKillRegState(IdxRegKill))
|
||||||
.addJumpTableIndex(JTI, JTOP.getTargetFlags())
|
.addJumpTableIndex(JTI, JTOP.getTargetFlags())
|
||||||
.addImm(MI->getOperand(JTOpIdx+1).getImm());
|
.addImm(MI->getOperand(JTOpIdx+1).getImm());
|
||||||
|
DEBUG(dbgs() << "BB#" << MBB->getNumber() << ": " << *NewJTMI);
|
||||||
// FIXME: Insert an "ALIGN" instruction to ensure the next instruction
|
// FIXME: Insert an "ALIGN" instruction to ensure the next instruction
|
||||||
// is 2-byte aligned. For now, asm printer will fix it up.
|
// is 2-byte aligned. For now, asm printer will fix it up.
|
||||||
unsigned NewSize = TII->GetInstSizeInBytes(NewJTMI);
|
unsigned NewSize = TII->GetInstSizeInBytes(NewJTMI);
|
||||||
|
Loading…
Reference in New Issue
Block a user