[llvm] [RISCV][VLOPT] Look through PHI instructions (PR #132236)

Michael Maitland via llvm-commits llvm-commits at lists.llvm.org
Thu Mar 20 10:54:58 PDT 2025


================
@@ -1340,6 +1341,17 @@ RISCVVLOptimizer::checkUsers(const MachineInstr &MI) const {
       continue;
     }
 
+    if (UserMI.isPHI() && PHISeen.insert(&UserMI).second) {
+      LLVM_DEBUG(dbgs() << "    Peeking through uses of PHI\n");
+      for (auto &PhiUse : MRI->use_operands(UserMI.getOperand(0).getReg())) {
+        // If UserMI has a PHI cycle, don't analyze it.
+        if (PhiUse.getParent() == &UserMI)
----------------
michaelmaitland wrote:

I think I handle that case too in the if statement with the `insert` check. I added a test for it.

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


More information about the llvm-commits mailing list