Lines Matching defs:NewMI

141     MachineInstr *NewMI = cloneInstr(CI, MaxStageCount, StageNum);
142 updateInstruction(NewMI, false, MaxStageCount, StageNum, VRMap);
143 KernelBB->push_back(NewMI);
144 InstrMap[NewMI] = CI;
150 MachineInstr *NewMI = MF.CloneMachineInstr(&MI);
151 updateInstruction(NewMI, false, MaxStageCount, 0, VRMap);
152 KernelBB->push_back(NewMI);
153 InstrMap[NewMI] = &MI;
225 MachineInstr *NewMI =
227 updateInstruction(NewMI, false, i, (unsigned)StageNum, VRMap);
228 NewBB->push_back(NewMI);
229 InstrMap[NewMI] = &*BBI;
303 MachineInstr *NewMI = cloneInstr(In, UINT_MAX, 0);
304 updateInstruction(NewMI, i == 1, EpilogStage, 0, VRMap);
305 NewBB->push_back(NewMI);
306 InstrMap[NewMI] = In;
965 void ModuloScheduleExpander::updateMemOperands(MachineInstr &NewMI,
972 if (NewMI.memoperands_empty())
975 for (MachineMemOperand *MMO : NewMI.memoperands()) {
993 NewMI.setMemRefs(MF, NewMMOs);
1001 MachineInstr *NewMI = MF.CloneMachineInstr(OldMI);
1002 updateMemOperands(*NewMI, *OldMI, CurStageNum - InstStageNum);
1003 return NewMI;
1011 MachineInstr *NewMI = MF.CloneMachineInstr(OldMI);
1022 NewMI->getOperand(OffsetPos).setImm(NewOffset);
1024 updateMemOperands(*NewMI, *OldMI, CurStageNum - InstStageNum);
1025 return NewMI;
1030 void ModuloScheduleExpander::updateInstruction(MachineInstr *NewMI,
1035 for (MachineOperand &MO : NewMI->operands()) {
1696 MachineInstr *NewMI = MF.CloneMachineInstr(Phi);
1697 DestBB->insert(InsertPt, NewMI);
1700 NewMI->getOperand(0).setReg(R);
1701 NewMI->getOperand(1).setReg(OrigR);
1702 NewMI->getOperand(2).setMBB(*DestBB->pred_begin());
1704 CanonicalMIs[NewMI] = CanonicalMIs[Phi];
1705 BlockMIs[{DestBB, CanonicalMIs[Phi]}] = NewMI;
1706 PhiNodeLoopIteration[NewMI] = PhiNodeLoopIteration[Phi];
2108 MachineInstr *NewMI = MF.CloneMachineInstr(OldMI);
2111 NewMI->dropMemRefs(MF);
2113 return NewMI;
2528 MachineInstr *NewMI = cloneInstr(MI);
2529 updateInstrDef(NewMI, PrologVRMap[PrologNum], false);
2530 NewMIMap[NewMI] = {PrologNum, StageNum};
2531 Prolog->push_back(NewMI);
2562 MachineInstr *NewMI = cloneInstr(MI);
2564 LastStage0Insts[MI] = NewMI;
2565 updateInstrDef(NewMI, KernelVRMap[UnrollNum],
2568 NewMIMap[NewMI] = {UnrollNum, StageNum};
2569 NewKernel->push_back(NewMI);
2604 MachineInstr *NewMI = cloneInstr(MI);
2605 updateInstrDef(NewMI, EpilogVRMap[EpilogNum], StageNum - 1 == EpilogNum);
2606 NewMIMap[NewMI] = {EpilogNum, StageNum};
2607 Epilog->push_back(NewMI);
2664 /// Create new virtual registers for definitions of NewMI and update NewMI.
2667 void ModuloScheduleExpanderMVE::updateInstrDef(MachineInstr *NewMI,
2670 for (MachineOperand &MO : NewMI->operands()) {