[llvm] [AArch64] Add flag to control unrolling for small multi-exit loops (PR #131998)

Florian Hahn via llvm-commits llvm-commits at lists.llvm.org
Wed Apr 2 02:57:06 PDT 2025


================
@@ -4375,6 +4380,87 @@ getFalkorUnrollingPreferences(Loop *L, ScalarEvolution &SE,
   }
 }
 
+static bool shouldUnrollLoopWithInstruction(Instruction &I,
+                                            AArch64TTIImpl &TTI) {
+  // Don't unroll vectorised loop.
+  if (I.getType()->isVectorTy())
+    return false;
+
+  if (isa<CallBase>(I)) {
+    if (isa<CallInst>(I) || isa<InvokeInst>(I))
+      if (const Function *F = cast<CallBase>(I).getCalledFunction())
+        if (!TTI.isLoweredToCall(F))
+          return true;
+    return false;
+  }
+
+  return true;
+}
+
+static unsigned getLoopSize(Loop *L, AArch64TTIImpl &TTI,
----------------
fhahn wrote:

Would also be good to document.

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


More information about the llvm-commits mailing list