diff options
author | Weiming Zhao <weimingz@codeaurora.org> | 2013-02-13 23:24:40 +0000 |
---|---|---|
committer | Weiming Zhao <weimingz@codeaurora.org> | 2013-02-13 23:24:40 +0000 |
commit | 090edf7e67226b32a478ea67e11d324f95090252 (patch) | |
tree | 5a11ed078b449eb1ffa68395f4a6198545164f2a /llvm/lib/Target/ARM/ARMAsmPrinter.cpp | |
parent | e40346050a128d60acec7d2265d867f11f750182 (diff) | |
download | bcm5719-llvm-090edf7e67226b32a478ea67e11d324f95090252.tar.gz bcm5719-llvm-090edf7e67226b32a478ea67e11d324f95090252.zip |
temporarily revert the patch due to some conflicts
llvm-svn: 175107
Diffstat (limited to 'llvm/lib/Target/ARM/ARMAsmPrinter.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMAsmPrinter.cpp | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/llvm/lib/Target/ARM/ARMAsmPrinter.cpp b/llvm/lib/Target/ARM/ARMAsmPrinter.cpp index 58c779830e1..986dfb715ce 100644 --- a/llvm/lib/Target/ARM/ARMAsmPrinter.cpp +++ b/llvm/lib/Target/ARM/ARMAsmPrinter.cpp @@ -342,11 +342,6 @@ void ARMAsmPrinter::printOperand(const MachineInstr *MI, int OpNum, unsigned Reg = MO.getReg(); assert(TargetRegisterInfo::isPhysicalRegister(Reg)); assert(!MO.getSubReg() && "Subregs should be eliminated!"); - if(ARM::GPRPairRegClass.contains(Reg)) { - const MachineFunction &MF = *MI->getParent()->getParent(); - const TargetRegisterInfo *TRI = MF.getTarget().getRegisterInfo(); - Reg = TRI->getSubReg(Reg, ARM::gsub_0); - } O << ARMInstPrinter::getRegisterName(Reg); break; } @@ -535,12 +530,14 @@ bool ARMAsmPrinter::PrintAsmOperand(const MachineInstr *MI, unsigned OpNum, const MachineOperand &MO = MI->getOperand(OpNum); if (!MO.isReg()) return true; + const TargetRegisterClass &RC = ARM::GPRRegClass; const MachineFunction &MF = *MI->getParent()->getParent(); const TargetRegisterInfo *TRI = MF.getTarget().getRegisterInfo(); - unsigned Reg = MO.getReg(); - if(!ARM::GPRPairRegClass.contains(Reg)) - return false; - Reg = TRI->getSubReg(Reg, ARM::gsub_1); + + unsigned RegIdx = TRI->getEncodingValue(MO.getReg()); + RegIdx |= 1; //The odd register is also the higher-numbered one of a pair. + + unsigned Reg = RC.getRegister(RegIdx); O << ARMInstPrinter::getRegisterName(Reg); return false; } |