[llvm] [CodeGen] commuteInstruction should update implicit-def (PR #131361)

Matt Arsenault via llvm-commits llvm-commits at lists.llvm.org
Mon Mar 17 00:01:25 PDT 2025


================
@@ -214,6 +215,24 @@ MachineInstr *TargetInstrInfo::commuteInstructionImpl(MachineInstr &MI,
     SubReg0 = SubReg1;
   }
 
+  // For a case like this:
+  //   %0.sub = INST %0.sub(tied), %1.sub, implicit-def %0
+  // we need to update the implicit-def after commuting to result in:
+  //   %1.sub = INST %1.sub(tied), %0.sub, implicit-def %1
+  SmallVector<unsigned> UpdateImplicitDefIdx;
+  if (HasDef && MI.hasImplicitDef() && MI.getOperand(0).getReg() != Reg0) {
----------------
arsenm wrote:

Can you use MachineInstr::substituteRegister? 

https://github.com/llvm/llvm-project/pull/131361


More information about the llvm-commits mailing list