diff --git a/llvm/lib/Target/PowerPC/PPCTLSDynamicCall.cpp b/llvm/lib/Target/PowerPC/PPCTLSDynamicCall.cpp --- a/llvm/lib/Target/PowerPC/PPCTLSDynamicCall.cpp +++ b/llvm/lib/Target/PowerPC/PPCTLSDynamicCall.cpp @@ -43,7 +43,6 @@ } const PPCInstrInfo *TII; - LiveIntervals *LIS; protected: bool processBlock(MachineBasicBlock &MBB) { @@ -83,11 +82,8 @@ Register InReg = PPC::NoRegister; Register GPR3 = Is64Bit ? PPC::X3 : PPC::R3; Register GPR4 = Is64Bit ? PPC::X4 : PPC::R4; - SmallVector OrigRegs = {OutReg, GPR3}; - if (!IsPCREL) { + if (!IsPCREL) InReg = MI.getOperand(1).getReg(); - OrigRegs.push_back(InReg); - } DebugLoc DL = MI.getDebugLoc(); unsigned Opc1, Opc2; @@ -139,11 +135,6 @@ BuildMI(MBB, I, DL, TII->get(PPC::ADJCALLSTACKDOWN)).addImm(0) .addImm(0); - // The ADDItls* instruction is the first instruction in the - // repair range. - MachineBasicBlock::iterator First = I; - --First; - if (IsAIX) { // The variable offset and region handle are copied in r4 and r3. The // copies are followed by GETtlsADDR32AIX/GETtlsADDR64AIX. @@ -177,16 +168,10 @@ BuildMI(MBB, I, DL, TII->get(TargetOpcode::COPY), OutReg) .addReg(GPR3); - // The COPY is the last instruction in the repair range. - MachineBasicBlock::iterator Last = I; - --Last; - // Move past the original instruction and remove it. ++I; MI.removeFromParent(); - // Repair the live intervals. - LIS->repairIntervalsInRange(&MBB, First, Last, OrigRegs); Changed = true; } @@ -204,7 +189,6 @@ bool runOnMachineFunction(MachineFunction &MF) override { TII = MF.getSubtarget().getInstrInfo(); - LIS = &getAnalysis(); bool Changed = false; @@ -217,7 +201,6 @@ void getAnalysisUsage(AnalysisUsage &AU) const override { AU.addRequired(); - AU.addPreserved(); AU.addRequired(); AU.addPreserved(); MachineFunctionPass::getAnalysisUsage(AU);