mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-24 07:35:04 +00:00
Change "Name" to "AsmName" in the target register info. Gee, a refactoring tool
would have been a Godsend here! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47625 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4d535cadf1
commit
74ab84c31e
include/llvm/Target
lib
CodeGen
LiveInterval.cppLiveIntervalAnalysis.cppMachineBasicBlock.cppMachineFunction.cppMachineLICM.cppRegAllocBigBlock.cppRegAllocLinearScan.cppRegAllocLocal.cpp
SelectionDAG
SimpleRegisterCoalescing.cppVirtRegMap.cppTarget
utils/TableGen
@ -48,7 +48,7 @@ class Type;
|
||||
/// register, e.g. RAX, EAX, are super-registers of AX.
|
||||
///
|
||||
struct TargetRegisterDesc {
|
||||
const char *Name; // Assembly language name for the register
|
||||
const char *AsmName; // Assembly language name for the register
|
||||
const char *PrintableName;// Printable name for the reg (for debugging)
|
||||
const unsigned *AliasSet; // Register Alias Set, described above
|
||||
const unsigned *SubRegs; // Sub-register set, described above
|
||||
@ -376,10 +376,10 @@ public:
|
||||
return get(RegNo).SuperRegs;
|
||||
}
|
||||
|
||||
/// getName - Return the symbolic target specific name for the specified
|
||||
/// physical register.
|
||||
const char *getName(unsigned RegNo) const {
|
||||
return get(RegNo).Name;
|
||||
/// getAsmName - Return the symbolic target specific name for the
|
||||
/// specified physical register.
|
||||
const char *getAsmName(unsigned RegNo) const {
|
||||
return get(RegNo).AsmName;
|
||||
}
|
||||
|
||||
/// getPrintableName - Return the human-readable symbolic target specific name
|
||||
|
@ -665,7 +665,7 @@ void LiveRange::dump() const {
|
||||
void LiveInterval::print(std::ostream &OS,
|
||||
const TargetRegisterInfo *TRI) const {
|
||||
if (TRI && TargetRegisterInfo::isPhysicalRegister(reg))
|
||||
OS << TRI->getName(reg);
|
||||
OS << TRI->getPrintableName(reg);
|
||||
else
|
||||
OS << "%reg" << reg;
|
||||
|
||||
|
@ -189,7 +189,7 @@ bool LiveIntervals::conflictsWithPhysRegDef(const LiveInterval &li,
|
||||
|
||||
void LiveIntervals::printRegName(unsigned reg) const {
|
||||
if (TargetRegisterInfo::isPhysicalRegister(reg))
|
||||
cerr << tri_->getName(reg);
|
||||
cerr << tri_->getPrintableName(reg);
|
||||
else
|
||||
cerr << "%reg" << reg;
|
||||
}
|
||||
|
@ -146,7 +146,7 @@ static inline void OutputReg(std::ostream &os, unsigned RegNo,
|
||||
const TargetRegisterInfo *TRI = 0) {
|
||||
if (!RegNo || TargetRegisterInfo::isPhysicalRegister(RegNo)) {
|
||||
if (TRI)
|
||||
os << " %" << TRI->get(RegNo).Name;
|
||||
os << " %" << TRI->get(RegNo).PrintableName;
|
||||
else
|
||||
os << " %mreg(" << RegNo << ")";
|
||||
} else
|
||||
|
@ -214,7 +214,7 @@ void MachineFunction::print(std::ostream &OS) const {
|
||||
for (MachineRegisterInfo::livein_iterator
|
||||
I = RegInfo->livein_begin(), E = RegInfo->livein_end(); I != E; ++I) {
|
||||
if (TRI)
|
||||
OS << " " << TRI->getName(I->first);
|
||||
OS << " " << TRI->getPrintableName(I->first);
|
||||
else
|
||||
OS << " Reg #" << I->first;
|
||||
|
||||
@ -228,7 +228,7 @@ void MachineFunction::print(std::ostream &OS) const {
|
||||
for (MachineRegisterInfo::liveout_iterator
|
||||
I = RegInfo->liveout_begin(), E = RegInfo->liveout_end(); I != E; ++I)
|
||||
if (TRI)
|
||||
OS << " " << TRI->getName(*I);
|
||||
OS << " " << TRI->getPrintableName(*I);
|
||||
else
|
||||
OS << " Reg #" << *I;
|
||||
OS << "\n";
|
||||
|
@ -251,7 +251,7 @@ bool MachineLICM::IsLoopInvariantInst(MachineInstr &I) {
|
||||
const TargetRegisterInfo *TRI = TM->getRegisterInfo();
|
||||
for (const unsigned *ImpUses = I.getDesc().getImplicitUses();
|
||||
*ImpUses; ++ImpUses)
|
||||
DOUT << " -> " << TRI->getName(*ImpUses) << "\n";
|
||||
DOUT << " -> " << TRI->getPrintableName(*ImpUses) << "\n";
|
||||
}
|
||||
|
||||
if (I.getDesc().getImplicitDefs()) {
|
||||
@ -260,7 +260,7 @@ bool MachineLICM::IsLoopInvariantInst(MachineInstr &I) {
|
||||
const TargetRegisterInfo *TRI = TM->getRegisterInfo();
|
||||
for (const unsigned *ImpDefs = I.getDesc().getImplicitDefs();
|
||||
*ImpDefs; ++ImpDefs)
|
||||
DOUT << " -> " << TRI->getName(*ImpDefs) << "\n";
|
||||
DOUT << " -> " << TRI->getPrintableName(*ImpDefs) << "\n";
|
||||
}
|
||||
|
||||
//if (TII->hasUnmodelledSideEffects(&I))
|
||||
|
@ -311,7 +311,7 @@ void RABigBlock::spillVirtReg(MachineBasicBlock &MBB,
|
||||
assert(VirtReg && "Spilling a physical register is illegal!"
|
||||
" Must not have appropriate kill for the register or use exists beyond"
|
||||
" the intended one.");
|
||||
DOUT << " Spilling register " << RegInfo->getName(PhysReg)
|
||||
DOUT << " Spilling register " << RegInfo->getPrintableName(PhysReg)
|
||||
<< " containing %reg" << VirtReg;
|
||||
|
||||
const TargetInstrInfo* TII = MBB.getParent()->getTarget().getInstrInfo();
|
||||
@ -535,7 +535,7 @@ MachineInstr *RABigBlock::reloadVirtReg(MachineBasicBlock &MBB, MachineInstr *MI
|
||||
markVirtRegModified(VirtReg, false);
|
||||
|
||||
DOUT << " Reloading %reg" << VirtReg << " into "
|
||||
<< RegInfo->getName(PhysReg) << "\n";
|
||||
<< RegInfo->getPrintableName(PhysReg) << "\n";
|
||||
|
||||
// Add move instruction(s)
|
||||
TII->loadRegFromStackSlot(MBB, MI, PhysReg, FrameIndex, RC);
|
||||
@ -646,7 +646,7 @@ void RABigBlock::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
DOUT << " Regs have values: ";
|
||||
for (unsigned i = 0; i != RegInfo->getNumRegs(); ++i)
|
||||
if (PhysRegsUsed[i] != -1 && PhysRegsUsed[i] != -2)
|
||||
DOUT << "[" << RegInfo->getName(i)
|
||||
DOUT << "[" << RegInfo->getPrintableName(i)
|
||||
<< ",%reg" << PhysRegsUsed[i] << "] ";
|
||||
DOUT << "\n");
|
||||
|
||||
@ -700,14 +700,14 @@ void RABigBlock::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
}
|
||||
|
||||
if (PhysReg) {
|
||||
DOUT << " Last use of " << RegInfo->getName(PhysReg)
|
||||
DOUT << " Last use of " << RegInfo->getPrintableName(PhysReg)
|
||||
<< "[%reg" << VirtReg <<"], removing it from live set\n";
|
||||
removePhysReg(PhysReg);
|
||||
for (const unsigned *AliasSet = RegInfo->getSubRegisters(PhysReg);
|
||||
*AliasSet; ++AliasSet) {
|
||||
if (PhysRegsUsed[*AliasSet] != -2) {
|
||||
DOUT << " Last use of "
|
||||
<< RegInfo->getName(*AliasSet)
|
||||
<< RegInfo->getPrintableName(*AliasSet)
|
||||
<< "[%reg" << VirtReg <<"], removing it from live set\n";
|
||||
removePhysReg(*AliasSet);
|
||||
}
|
||||
@ -806,14 +806,14 @@ void RABigBlock::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
}
|
||||
|
||||
if (PhysReg) {
|
||||
DOUT << " Register " << RegInfo->getName(PhysReg)
|
||||
DOUT << " Register " << RegInfo->getPrintableName(PhysReg)
|
||||
<< " [%reg" << VirtReg
|
||||
<< "] is never used, removing it frame live list\n";
|
||||
removePhysReg(PhysReg);
|
||||
for (const unsigned *AliasSet = RegInfo->getAliasSet(PhysReg);
|
||||
*AliasSet; ++AliasSet) {
|
||||
if (PhysRegsUsed[*AliasSet] != -2) {
|
||||
DOUT << " Register " << RegInfo->getName(*AliasSet)
|
||||
DOUT << " Register " << RegInfo->getPrintableName(*AliasSet)
|
||||
<< " [%reg" << *AliasSet
|
||||
<< "] is never used, removing it frame live list\n";
|
||||
removePhysReg(*AliasSet);
|
||||
|
@ -164,7 +164,7 @@ namespace {
|
||||
if (TargetRegisterInfo::isVirtualRegister(reg)) {
|
||||
reg = vrm_->getPhys(reg);
|
||||
}
|
||||
DOUT << tri_->getName(reg) << '\n';
|
||||
DOUT << tri_->getPrintableName(reg) << '\n';
|
||||
}
|
||||
}
|
||||
};
|
||||
@ -239,7 +239,8 @@ unsigned RALinScan::attemptTrivialCoalescing(LiveInterval &cur, unsigned Reg) {
|
||||
|
||||
// Try to coalesce.
|
||||
if (!li_->conflictsWithPhysRegDef(cur, *vrm_, SrcReg)) {
|
||||
DOUT << "Coalescing: " << cur << " -> " << tri_->getName(SrcReg) << '\n';
|
||||
DOUT << "Coalescing: " << cur << " -> " << tri_->getPrintableName(SrcReg)
|
||||
<< '\n';
|
||||
vrm_->clearVirt(cur.reg);
|
||||
vrm_->assignVirt2Phys(cur.reg, SrcReg);
|
||||
++NumCoalesce;
|
||||
@ -627,7 +628,7 @@ void RALinScan::assignRegOrStackSlotAtInterval(LiveInterval* cur)
|
||||
// the free physical register and add this interval to the active
|
||||
// list.
|
||||
if (physReg) {
|
||||
DOUT << tri_->getName(physReg) << '\n';
|
||||
DOUT << tri_->getPrintableName(physReg) << '\n';
|
||||
vrm_->assignVirt2Phys(cur->reg, physReg);
|
||||
prt_->addRegUse(physReg);
|
||||
active_.push_back(std::make_pair(cur, cur->begin()));
|
||||
@ -689,7 +690,7 @@ void RALinScan::assignRegOrStackSlotAtInterval(LiveInterval* cur)
|
||||
}
|
||||
|
||||
DOUT << "\t\tregister with min weight: "
|
||||
<< tri_->getName(minReg) << " (" << minWeight << ")\n";
|
||||
<< tri_->getPrintableName(minReg) << " (" << minWeight << ")\n";
|
||||
|
||||
// if the current has the minimum weight, we need to spill it and
|
||||
// add any added intervals back to unhandled, and restart
|
||||
@ -868,11 +869,11 @@ unsigned RALinScan::getFreePhysReg(LiveInterval *cur) {
|
||||
if (cur->preference) {
|
||||
if (prt_->isRegAvail(cur->preference)) {
|
||||
DOUT << "\t\tassigned the preferred register: "
|
||||
<< tri_->getName(cur->preference) << "\n";
|
||||
<< tri_->getPrintableName(cur->preference) << "\n";
|
||||
return cur->preference;
|
||||
} else
|
||||
DOUT << "\t\tunable to assign the preferred register: "
|
||||
<< tri_->getName(cur->preference) << "\n";
|
||||
<< tri_->getPrintableName(cur->preference) << "\n";
|
||||
}
|
||||
|
||||
// Scan for the first available register.
|
||||
|
@ -286,7 +286,7 @@ void RALocal::spillVirtReg(MachineBasicBlock &MBB,
|
||||
assert(VirtReg && "Spilling a physical register is illegal!"
|
||||
" Must not have appropriate kill for the register or use exists beyond"
|
||||
" the intended one.");
|
||||
DOUT << " Spilling register " << TRI->getName(PhysReg)
|
||||
DOUT << " Spilling register " << TRI->getPrintableName(PhysReg)
|
||||
<< " containing %reg" << VirtReg;
|
||||
|
||||
const TargetInstrInfo* TII = MBB.getParent()->getTarget().getInstrInfo();
|
||||
@ -502,7 +502,7 @@ MachineInstr *RALocal::reloadVirtReg(MachineBasicBlock &MBB, MachineInstr *MI,
|
||||
markVirtRegModified(VirtReg, false); // Note that this reg was just reloaded
|
||||
|
||||
DOUT << " Reloading %reg" << VirtReg << " into "
|
||||
<< TRI->getName(PhysReg) << "\n";
|
||||
<< TRI->getPrintableName(PhysReg) << "\n";
|
||||
|
||||
// Add move instruction(s)
|
||||
const TargetInstrInfo* TII = MBB.getParent()->getTarget().getInstrInfo();
|
||||
@ -575,7 +575,7 @@ void RALocal::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
DOUT << " Regs have values: ";
|
||||
for (unsigned i = 0; i != TRI->getNumRegs(); ++i)
|
||||
if (PhysRegsUsed[i] != -1 && PhysRegsUsed[i] != -2)
|
||||
DOUT << "[" << TRI->getName(i)
|
||||
DOUT << "[" << TRI->getPrintableName(i)
|
||||
<< ",%reg" << PhysRegsUsed[i] << "] ";
|
||||
DOUT << "\n");
|
||||
|
||||
@ -637,14 +637,14 @@ void RALocal::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
}
|
||||
|
||||
if (PhysReg) {
|
||||
DOUT << " Last use of " << TRI->getName(PhysReg)
|
||||
DOUT << " Last use of " << TRI->getPrintableName(PhysReg)
|
||||
<< "[%reg" << VirtReg <<"], removing it from live set\n";
|
||||
removePhysReg(PhysReg);
|
||||
for (const unsigned *AliasSet = TRI->getSubRegisters(PhysReg);
|
||||
*AliasSet; ++AliasSet) {
|
||||
if (PhysRegsUsed[*AliasSet] != -2) {
|
||||
DOUT << " Last use of "
|
||||
<< TRI->getName(*AliasSet)
|
||||
<< TRI->getPrintableName(*AliasSet)
|
||||
<< "[%reg" << VirtReg <<"], removing it from live set\n";
|
||||
removePhysReg(*AliasSet);
|
||||
}
|
||||
@ -728,7 +728,7 @@ void RALocal::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
MF->getRegInfo().setPhysRegUsed(DestPhysReg);
|
||||
markVirtRegModified(DestVirtReg);
|
||||
getVirtRegLastUse(DestVirtReg) = std::make_pair((MachineInstr*)0, 0);
|
||||
DOUT << " Assigning " << TRI->getName(DestPhysReg)
|
||||
DOUT << " Assigning " << TRI->getPrintableName(DestPhysReg)
|
||||
<< " to %reg" << DestVirtReg << "\n";
|
||||
MI->getOperand(i).setReg(DestPhysReg); // Assign the output register
|
||||
}
|
||||
@ -751,14 +751,14 @@ void RALocal::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
}
|
||||
|
||||
if (PhysReg) {
|
||||
DOUT << " Register " << TRI->getName(PhysReg)
|
||||
DOUT << " Register " << TRI->getPrintableName(PhysReg)
|
||||
<< " [%reg" << VirtReg
|
||||
<< "] is never used, removing it frame live list\n";
|
||||
removePhysReg(PhysReg);
|
||||
for (const unsigned *AliasSet = TRI->getAliasSet(PhysReg);
|
||||
*AliasSet; ++AliasSet) {
|
||||
if (PhysRegsUsed[*AliasSet] != -2) {
|
||||
DOUT << " Register " << TRI->getName(*AliasSet)
|
||||
DOUT << " Register " << TRI->getPrintableName(*AliasSet)
|
||||
<< " [%reg" << *AliasSet
|
||||
<< "] is never used, removing it frame live list\n";
|
||||
removePhysReg(*AliasSet);
|
||||
|
@ -4181,7 +4181,8 @@ void SDNode::dump(const SelectionDAG *G) const {
|
||||
} else if (const RegisterSDNode *R = dyn_cast<RegisterSDNode>(this)) {
|
||||
if (G && R->getReg() &&
|
||||
TargetRegisterInfo::isPhysicalRegister(R->getReg())) {
|
||||
cerr << " " <<G->getTarget().getRegisterInfo()->getName(R->getReg());
|
||||
cerr << " "
|
||||
<< G->getTarget().getRegisterInfo()->getPrintableName(R->getReg());
|
||||
} else {
|
||||
cerr << " #" << R->getReg();
|
||||
}
|
||||
|
@ -133,7 +133,8 @@ std::string DOTGraphTraits<SelectionDAG*>::getNodeLabel(const SDNode *Node,
|
||||
} else if (const RegisterSDNode *R = dyn_cast<RegisterSDNode>(Node)) {
|
||||
if (G && R->getReg() != 0 &&
|
||||
TargetRegisterInfo::isPhysicalRegister(R->getReg())) {
|
||||
Op = Op + " " + G->getTarget().getRegisterInfo()->getName(R->getReg());
|
||||
Op = Op + " " +
|
||||
G->getTarget().getRegisterInfo()->getPrintableName(R->getReg());
|
||||
} else {
|
||||
Op += " #" + utostr(R->getReg());
|
||||
}
|
||||
|
@ -1648,7 +1648,7 @@ getRegForInlineAsmConstraint(const std::string &Constraint,
|
||||
|
||||
for (TargetRegisterClass::iterator I = RC->begin(), E = RC->end();
|
||||
I != E; ++I) {
|
||||
if (StringsEqualNoCase(RegName, RI->get(*I).Name))
|
||||
if (StringsEqualNoCase(RegName, RI->get(*I).AsmName))
|
||||
return std::make_pair(*I, RC);
|
||||
}
|
||||
}
|
||||
|
@ -1537,7 +1537,7 @@ void SimpleRegisterCoalescing::unsetRegisterKills(unsigned Start, unsigned End,
|
||||
|
||||
void SimpleRegisterCoalescing::printRegName(unsigned reg) const {
|
||||
if (TargetRegisterInfo::isPhysicalRegister(reg))
|
||||
cerr << tri_->getName(reg);
|
||||
cerr << tri_->getPrintableName(reg);
|
||||
else
|
||||
cerr << "%reg" << reg;
|
||||
}
|
||||
|
@ -141,8 +141,8 @@ void VirtRegMap::print(std::ostream &OS) const {
|
||||
for (unsigned i = TargetRegisterInfo::FirstVirtualRegister,
|
||||
e = MF.getRegInfo().getLastVirtReg(); i <= e; ++i) {
|
||||
if (Virt2PhysMap[i] != (unsigned)VirtRegMap::NO_PHYS_REG)
|
||||
OS << "[reg" << i << " -> " << TRI->getName(Virt2PhysMap[i]) << "]\n";
|
||||
|
||||
OS << "[reg" << i << " -> " << TRI->getPrintableName(Virt2PhysMap[i])
|
||||
<< "]\n";
|
||||
}
|
||||
|
||||
for (unsigned i = TargetRegisterInfo::FirstVirtualRegister,
|
||||
@ -351,7 +351,7 @@ public:
|
||||
DOUT << "Remembering RM#" << SlotOrReMat-VirtRegMap::MAX_STACK_SLOT-1;
|
||||
else
|
||||
DOUT << "Remembering SS#" << SlotOrReMat;
|
||||
DOUT << " in physreg " << TRI->getName(Reg) << "\n";
|
||||
DOUT << " in physreg " << TRI->getPrintableName(Reg) << "\n";
|
||||
}
|
||||
|
||||
/// canClobberPhysReg - Return true if the spiller is allowed to change the
|
||||
@ -392,7 +392,7 @@ void AvailableSpills::disallowClobberPhysRegOnly(unsigned PhysReg) {
|
||||
assert((SpillSlotsOrReMatsAvailable[SlotOrReMat] >> 1) == PhysReg &&
|
||||
"Bidirectional map mismatch!");
|
||||
SpillSlotsOrReMatsAvailable[SlotOrReMat] &= ~1;
|
||||
DOUT << "PhysReg " << TRI->getName(PhysReg)
|
||||
DOUT << "PhysReg " << TRI->getPrintableName(PhysReg)
|
||||
<< " copied, it is available for use but can no longer be modified\n";
|
||||
}
|
||||
}
|
||||
@ -417,7 +417,7 @@ void AvailableSpills::ClobberPhysRegOnly(unsigned PhysReg) {
|
||||
assert((SpillSlotsOrReMatsAvailable[SlotOrReMat] >> 1) == PhysReg &&
|
||||
"Bidirectional map mismatch!");
|
||||
SpillSlotsOrReMatsAvailable.erase(SlotOrReMat);
|
||||
DOUT << "PhysReg " << TRI->getName(PhysReg)
|
||||
DOUT << "PhysReg " << TRI->getPrintableName(PhysReg)
|
||||
<< " clobbered, invalidating ";
|
||||
if (SlotOrReMat > VirtRegMap::MAX_STACK_SLOT)
|
||||
DOUT << "RM#" << SlotOrReMat-VirtRegMap::MAX_STACK_SLOT-1 << "\n";
|
||||
@ -1135,9 +1135,9 @@ void LocalSpiller::RewriteMBB(MachineBasicBlock &MBB, VirtRegMap &VRM) {
|
||||
else
|
||||
DOUT << "Reusing SS#" << ReuseSlot;
|
||||
DOUT << " from physreg "
|
||||
<< TRI->getName(PhysReg) << " for vreg"
|
||||
<< TRI->getPrintableName(PhysReg) << " for vreg"
|
||||
<< VirtReg <<" instead of reloading into physreg "
|
||||
<< TRI->getName(VRM.getPhys(VirtReg)) << "\n";
|
||||
<< TRI->getPrintableName(VRM.getPhys(VirtReg)) << "\n";
|
||||
unsigned RReg = SubIdx ? TRI->getSubReg(PhysReg, SubIdx) : PhysReg;
|
||||
MI.getOperand(i).setReg(RReg);
|
||||
|
||||
@ -1208,8 +1208,8 @@ void LocalSpiller::RewriteMBB(MachineBasicBlock &MBB, VirtRegMap &VRM) {
|
||||
DOUT << "Reusing RM#" << ReuseSlot-VirtRegMap::MAX_STACK_SLOT-1;
|
||||
else
|
||||
DOUT << "Reusing SS#" << ReuseSlot;
|
||||
DOUT << " from physreg " << TRI->getName(PhysReg) << " for vreg"
|
||||
<< VirtReg
|
||||
DOUT << " from physreg " << TRI->getPrintableName(PhysReg)
|
||||
<< " for vreg" << VirtReg
|
||||
<< " instead of reloading into same physreg.\n";
|
||||
unsigned RReg = SubIdx ? TRI->getSubReg(PhysReg, SubIdx) : PhysReg;
|
||||
MI.getOperand(i).setReg(RReg);
|
||||
|
@ -273,7 +273,7 @@ void ARMAsmPrinter::printOperand(const MachineInstr *MI, int opNum,
|
||||
switch (MO.getType()) {
|
||||
case MachineOperand::MO_Register:
|
||||
if (TargetRegisterInfo::isPhysicalRegister(MO.getReg()))
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
else
|
||||
assert(0 && "not implemented");
|
||||
break;
|
||||
@ -393,7 +393,7 @@ void ARMAsmPrinter::printSORegOperand(const MachineInstr *MI, int Op) {
|
||||
const MachineOperand &MO3 = MI->getOperand(Op+2);
|
||||
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO1.getReg()));
|
||||
O << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
|
||||
// Print the shift opc.
|
||||
O << ", "
|
||||
@ -402,7 +402,7 @@ void ARMAsmPrinter::printSORegOperand(const MachineInstr *MI, int Op) {
|
||||
|
||||
if (MO2.getReg()) {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO2.getReg()));
|
||||
O << TM.getRegisterInfo()->get(MO2.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO2.getReg()).AsmName;
|
||||
assert(ARM_AM::getSORegOffset(MO3.getImm()) == 0);
|
||||
} else {
|
||||
O << "#" << ARM_AM::getSORegOffset(MO3.getImm());
|
||||
@ -419,7 +419,7 @@ void ARMAsmPrinter::printAddrMode2Operand(const MachineInstr *MI, int Op) {
|
||||
return;
|
||||
}
|
||||
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
|
||||
if (!MO2.getReg()) {
|
||||
if (ARM_AM::getAM2Offset(MO3.getImm())) // Don't print +0.
|
||||
@ -432,7 +432,7 @@ void ARMAsmPrinter::printAddrMode2Operand(const MachineInstr *MI, int Op) {
|
||||
|
||||
O << ", "
|
||||
<< (char)ARM_AM::getAM2Op(MO3.getImm())
|
||||
<< TM.getRegisterInfo()->get(MO2.getReg()).Name;
|
||||
<< TM.getRegisterInfo()->get(MO2.getReg()).AsmName;
|
||||
|
||||
if (unsigned ShImm = ARM_AM::getAM2Offset(MO3.getImm()))
|
||||
O << ", "
|
||||
@ -455,7 +455,7 @@ void ARMAsmPrinter::printAddrMode2OffsetOperand(const MachineInstr *MI, int Op){
|
||||
}
|
||||
|
||||
O << (char)ARM_AM::getAM2Op(MO2.getImm())
|
||||
<< TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
<< TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
|
||||
if (unsigned ShImm = ARM_AM::getAM2Offset(MO2.getImm()))
|
||||
O << ", "
|
||||
@ -469,12 +469,12 @@ void ARMAsmPrinter::printAddrMode3Operand(const MachineInstr *MI, int Op) {
|
||||
const MachineOperand &MO3 = MI->getOperand(Op+2);
|
||||
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO1.getReg()));
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
|
||||
if (MO2.getReg()) {
|
||||
O << ", "
|
||||
<< (char)ARM_AM::getAM3Op(MO3.getImm())
|
||||
<< TM.getRegisterInfo()->get(MO2.getReg()).Name
|
||||
<< TM.getRegisterInfo()->get(MO2.getReg()).AsmName
|
||||
<< "]";
|
||||
return;
|
||||
}
|
||||
@ -492,7 +492,7 @@ void ARMAsmPrinter::printAddrMode3OffsetOperand(const MachineInstr *MI, int Op){
|
||||
|
||||
if (MO1.getReg()) {
|
||||
O << (char)ARM_AM::getAM3Op(MO2.getImm())
|
||||
<< TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
<< TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
return;
|
||||
}
|
||||
|
||||
@ -545,13 +545,13 @@ void ARMAsmPrinter::printAddrMode5Operand(const MachineInstr *MI, int Op,
|
||||
return;
|
||||
} else if (Modifier && strcmp(Modifier, "base") == 0) {
|
||||
// Used for FSTM{D|S} and LSTM{D|S} operations.
|
||||
O << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
if (ARM_AM::getAM5WBFlag(MO2.getImm()))
|
||||
O << "!";
|
||||
return;
|
||||
}
|
||||
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
|
||||
if (unsigned ImmOffs = ARM_AM::getAM5Offset(MO2.getImm())) {
|
||||
O << ", #"
|
||||
@ -570,15 +570,15 @@ void ARMAsmPrinter::printAddrModePCOperand(const MachineInstr *MI, int Op,
|
||||
|
||||
const MachineOperand &MO1 = MI->getOperand(Op);
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO1.getReg()));
|
||||
O << "[pc, +" << TM.getRegisterInfo()->get(MO1.getReg()).Name << "]";
|
||||
O << "[pc, +" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName << "]";
|
||||
}
|
||||
|
||||
void
|
||||
ARMAsmPrinter::printThumbAddrModeRROperand(const MachineInstr *MI, int Op) {
|
||||
const MachineOperand &MO1 = MI->getOperand(Op);
|
||||
const MachineOperand &MO2 = MI->getOperand(Op+1);
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << ", " << TM.getRegisterInfo()->get(MO2.getReg()).Name << "]";
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
O << ", " << TM.getRegisterInfo()->get(MO2.getReg()).AsmName << "]";
|
||||
}
|
||||
|
||||
void
|
||||
@ -593,9 +593,9 @@ ARMAsmPrinter::printThumbAddrModeRI5Operand(const MachineInstr *MI, int Op,
|
||||
return;
|
||||
}
|
||||
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
if (MO3.getReg())
|
||||
O << ", " << TM.getRegisterInfo()->get(MO3.getReg()).Name;
|
||||
O << ", " << TM.getRegisterInfo()->get(MO3.getReg()).AsmName;
|
||||
else if (unsigned ImmOffs = MO2.getImm()) {
|
||||
O << ", #" << ImmOffs;
|
||||
if (Scale > 1)
|
||||
@ -620,7 +620,7 @@ ARMAsmPrinter::printThumbAddrModeS4Operand(const MachineInstr *MI, int Op) {
|
||||
void ARMAsmPrinter::printThumbAddrModeSPOperand(const MachineInstr *MI,int Op) {
|
||||
const MachineOperand &MO1 = MI->getOperand(Op);
|
||||
const MachineOperand &MO2 = MI->getOperand(Op+1);
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).Name;
|
||||
O << "[" << TM.getRegisterInfo()->get(MO1.getReg()).AsmName;
|
||||
if (unsigned ImmOffs = MO2.getImm())
|
||||
O << ", #" << ImmOffs << " * 4";
|
||||
O << "]";
|
||||
|
@ -77,7 +77,7 @@ void AlphaAsmPrinter::printOperand(const MachineInstr *MI, int opNum)
|
||||
if (MO.getType() == MachineOperand::MO_Register) {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO.getReg()) &&
|
||||
"Not physreg??");
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
} else if (MO.isImmediate()) {
|
||||
O << MO.getImm();
|
||||
assert(MO.getImm() < (1 << 30));
|
||||
@ -92,7 +92,7 @@ void AlphaAsmPrinter::printOp(const MachineOperand &MO, bool IsCallOp) {
|
||||
|
||||
switch (MO.getType()) {
|
||||
case MachineOperand::MO_Register:
|
||||
O << RI.get(MO.getReg()).Name;
|
||||
O << RI.get(MO.getReg()).AsmName;
|
||||
return;
|
||||
|
||||
case MachineOperand::MO_Immediate:
|
||||
|
@ -334,6 +334,6 @@ int AlphaRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
||||
|
||||
std::string AlphaRegisterInfo::getPrettyName(unsigned reg)
|
||||
{
|
||||
std::string s(RegisterDescriptors[reg].Name);
|
||||
std::string s(RegisterDescriptors[reg].PrintableName);
|
||||
return s;
|
||||
}
|
||||
|
@ -75,14 +75,14 @@ namespace {
|
||||
unsigned RegNo = MO.getReg();
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(RegNo) &&
|
||||
"Not physreg??");
|
||||
O << TM.getRegisterInfo()->get(RegNo).Name;
|
||||
O << TM.getRegisterInfo()->get(RegNo).AsmName;
|
||||
}
|
||||
|
||||
void printOperand(const MachineInstr *MI, unsigned OpNo) {
|
||||
const MachineOperand &MO = MI->getOperand(OpNo);
|
||||
if (MO.isRegister()) {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO.getReg())&&"Not physreg??");
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
} else if (MO.isImmediate()) {
|
||||
O << MO.getImm();
|
||||
} else {
|
||||
@ -149,7 +149,7 @@ namespace {
|
||||
// the value contained in the register. For this reason, the darwin
|
||||
// assembler requires that we print r0 as 0 (no r) when used as the base.
|
||||
const MachineOperand &MO = MI->getOperand(OpNo);
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
O << ", ";
|
||||
printOperand(MI, OpNo+1);
|
||||
}
|
||||
|
@ -56,7 +56,7 @@ namespace {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO.getReg()) &&
|
||||
"Not physref??");
|
||||
//XXX Bug Workaround: See note in Printer::doInitialization about %.
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
} else {
|
||||
printOp(MO);
|
||||
}
|
||||
@ -168,7 +168,7 @@ void IA64AsmPrinter::printOp(const MachineOperand &MO,
|
||||
const TargetRegisterInfo &RI = *TM.getRegisterInfo();
|
||||
switch (MO.getType()) {
|
||||
case MachineOperand::MO_Register:
|
||||
O << RI.get(MO.getReg()).Name;
|
||||
O << RI.get(MO.getReg()).AsmName;
|
||||
return;
|
||||
|
||||
case MachineOperand::MO_Immediate:
|
||||
|
@ -169,9 +169,9 @@ emitFrameDirective(MachineFunction &MF)
|
||||
unsigned stackSize = MF.getFrameInfo()->getStackSize();
|
||||
|
||||
|
||||
O << "\t.frame\t" << "$" << LowercaseString(RI.get(stackReg).Name)
|
||||
O << "\t.frame\t" << "$" << LowercaseString(RI.get(stackReg).AsmName)
|
||||
<< "," << stackSize << ","
|
||||
<< "$" << LowercaseString(RI.get(returnReg).Name)
|
||||
<< "$" << LowercaseString(RI.get(returnReg).AsmName)
|
||||
<< "\n";
|
||||
}
|
||||
|
||||
@ -365,7 +365,7 @@ printOperand(const MachineInstr *MI, int opNum)
|
||||
{
|
||||
case MachineOperand::MO_Register:
|
||||
if (TargetRegisterInfo::isPhysicalRegister(MO.getReg()))
|
||||
O << "$" << LowercaseString (RI.get(MO.getReg()).Name);
|
||||
O << "$" << LowercaseString (RI.get(MO.getReg()).AsmName);
|
||||
else
|
||||
O << "$" << MO.getReg();
|
||||
break;
|
||||
|
@ -113,7 +113,7 @@ namespace {
|
||||
return;
|
||||
}
|
||||
|
||||
const char *RegName = TM.getRegisterInfo()->get(RegNo).Name;
|
||||
const char *RegName = TM.getRegisterInfo()->get(RegNo).AsmName;
|
||||
// Linux assembler (Others?) does not take register mnemonics.
|
||||
// FIXME - What about special registers used in mfspr/mtspr?
|
||||
if (!Subtarget.isDarwin()) RegName = stripRegisterPrefix(RegName);
|
||||
|
@ -22,7 +22,7 @@ class GPR<bits<5> num, string n> : PPCReg<n> {
|
||||
}
|
||||
|
||||
// GP8 - One of the 32 64-bit general-purpose registers
|
||||
class GP8<GPR SubReg, string n> : PPCReg<SubReg.Name> {
|
||||
class GP8<GPR SubReg, string n> : PPCReg<SubReg.AsmName> {
|
||||
field bits<5> Num = SubReg.Num;
|
||||
let SubRegs = [SubReg];
|
||||
let PrintableName = n;
|
||||
|
@ -146,7 +146,7 @@ void SparcAsmPrinter::printOperand(const MachineInstr *MI, int opNum) {
|
||||
switch (MO.getType()) {
|
||||
case MachineOperand::MO_Register:
|
||||
if (TargetRegisterInfo::isPhysicalRegister(MO.getReg()))
|
||||
O << "%" << LowercaseString (RI.get(MO.getReg()).Name);
|
||||
O << "%" << LowercaseString (RI.get(MO.getReg()).AsmName);
|
||||
else
|
||||
O << "%reg" << MO.getReg();
|
||||
break;
|
||||
|
@ -25,7 +25,7 @@ class RegisterClass; // Forward def
|
||||
// in the target machine. String n will become the "name" of the register.
|
||||
class Register<string n> {
|
||||
string Namespace = "";
|
||||
string Name = n;
|
||||
string AsmName = n;
|
||||
string PrintableName = n;
|
||||
|
||||
// SpillSize - If this value is set to a non-zero value, it is the size in
|
||||
|
@ -229,7 +229,7 @@ void X86ATTAsmPrinter::printOperand(const MachineInstr *MI, unsigned OpNo,
|
||||
((strcmp(Modifier+6,"16") == 0) ? MVT::i16 : MVT::i8));
|
||||
Reg = getX86SubSuperRegister(Reg, VT);
|
||||
}
|
||||
for (const char *Name = RI.get(Reg).Name; *Name; ++Name)
|
||||
for (const char *Name = RI.get(Reg).AsmName; *Name; ++Name)
|
||||
O << (char)tolower(*Name);
|
||||
return;
|
||||
}
|
||||
@ -575,7 +575,7 @@ bool X86ATTAsmPrinter::printAsmMRegister(const MachineOperand &MO,
|
||||
}
|
||||
|
||||
O << '%';
|
||||
for (const char *Name = RI.get(Reg).Name; *Name; ++Name)
|
||||
for (const char *Name = RI.get(Reg).AsmName; *Name; ++Name)
|
||||
O << (char)tolower(*Name);
|
||||
return false;
|
||||
}
|
||||
|
@ -125,7 +125,7 @@ void X86IntelAsmPrinter::printOp(const MachineOperand &MO,
|
||||
((strcmp(Modifier,"subreg16") == 0) ? MVT::i16 :MVT::i8));
|
||||
Reg = getX86SubSuperRegister(Reg, VT);
|
||||
}
|
||||
O << RI.get(Reg).Name;
|
||||
O << RI.get(Reg).AsmName;
|
||||
} else
|
||||
O << "reg" << MO.getReg();
|
||||
return;
|
||||
@ -271,7 +271,7 @@ bool X86IntelAsmPrinter::printAsmMRegister(const MachineOperand &MO,
|
||||
break;
|
||||
}
|
||||
|
||||
O << '%' << RI.get(Reg).Name;
|
||||
O << '%' << RI.get(Reg).AsmName;
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -43,7 +43,7 @@ struct VISIBILITY_HIDDEN X86IntelAsmPrinter : public X86SharedAsmPrinter {
|
||||
if (MO.isRegister()) {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(MO.getReg()) &&
|
||||
"Not physreg??");
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).Name;
|
||||
O << TM.getRegisterInfo()->get(MO.getReg()).AsmName;
|
||||
} else {
|
||||
printOp(MO, Modifier);
|
||||
}
|
||||
|
@ -520,8 +520,8 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||
for (unsigned i = 0, e = Registers.size(); i != e; ++i) {
|
||||
const CodeGenRegister &Reg = Registers[i];
|
||||
OS << " { \"";
|
||||
if (!Reg.TheDef->getValueAsString("Name").empty())
|
||||
OS << Reg.TheDef->getValueAsString("Name");
|
||||
if (!Reg.TheDef->getValueAsString("AsmName").empty())
|
||||
OS << Reg.TheDef->getValueAsString("AsmName");
|
||||
else
|
||||
OS << Reg.getName();
|
||||
OS << "\",\t\"";
|
||||
|
Loading…
x
Reference in New Issue
Block a user