mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-21 02:24:22 +00:00
CodeGen: Use mop_iterator instead of MIOperands/ConstMIOperands
MIOperands/ConstMIOperands are classes iterating over the MachineOperand of a MachineInstr, however MachineInstr::mop_iterator does the same thing. I assume these two iterators exist to have a uniform interface to iterate over the operands of a machine instruction bundle and a single machine instruction. However in practice I find it more confusing to have 2 different iterator classes, so this patch transforms (nearly all) the code to use mop_iterators. The only exception being MIOperands::anlayzePhysReg() and MIOperands::analyzeVirtReg() still needing an equivalent, I leave that as an exercise for the next patch. Differential Revision: http://reviews.llvm.org/D9932 This version is slightly modified from the proposed revision in that it introduces MachineInstr::getOperandNo to avoid the extra counting variable in the few loops that previously used MIOperands::getOperandNo. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238539 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -68,8 +68,8 @@ bool ProcessImplicitDefs::canTurnIntoImplicitDef(MachineInstr *MI) {
|
||||
!MI->isRegSequence() &&
|
||||
!MI->isPHI())
|
||||
return false;
|
||||
for (MIOperands MO(MI); MO.isValid(); ++MO)
|
||||
if (MO->isReg() && MO->isUse() && MO->readsReg())
|
||||
for (const MachineOperand &MO : MI->operands())
|
||||
if (MO.isReg() && MO.isUse() && MO.readsReg())
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
@ -100,17 +100,17 @@ void ProcessImplicitDefs::processImplicitDef(MachineInstr *MI) {
|
||||
MachineBasicBlock::instr_iterator UserE = MI->getParent()->instr_end();
|
||||
bool Found = false;
|
||||
for (++UserMI; UserMI != UserE; ++UserMI) {
|
||||
for (MIOperands MO(UserMI); MO.isValid(); ++MO) {
|
||||
if (!MO->isReg())
|
||||
for (MachineOperand &MO : UserMI->operands()) {
|
||||
if (!MO.isReg())
|
||||
continue;
|
||||
unsigned UserReg = MO->getReg();
|
||||
unsigned UserReg = MO.getReg();
|
||||
if (!TargetRegisterInfo::isPhysicalRegister(UserReg) ||
|
||||
!TRI->regsOverlap(Reg, UserReg))
|
||||
continue;
|
||||
// UserMI uses or redefines Reg. Set <undef> flags on all uses.
|
||||
Found = true;
|
||||
if (MO->isUse())
|
||||
MO->setIsUndef();
|
||||
if (MO.isUse())
|
||||
MO.setIsUndef();
|
||||
}
|
||||
if (Found)
|
||||
break;
|
||||
|
Reference in New Issue
Block a user