[llvm] [PartiallyInlineLibCalls] Emit missed- and passed-optimization remarks when partially inlining sqrt (PR #123966)

Florian Hahn via llvm-commits llvm-commits at lists.llvm.org
Fri Feb 14 03:49:18 PST 2025


================
@@ -56,6 +56,20 @@ static bool optimizeSQRT(CallInst *Call, Function *CalledFunc,
   // dst = phi(v0, v1)
   //
 
+  ORE->emit([&]() {
+    return OptimizationRemark(DEBUG_TYPE, "SqrtPartiallyInlined",
+                              Call->getDebugLoc(), &CurrBB)
+           << "Partially inlined call to sqrt function despite having to use "
+              "errno for error handling: target has fast sqrt instruction";
+  });
+  ORE->emit([&]() {
+    return OptimizationRemarkMissed(DEBUG_TYPE, "BranchInserted",
+                                    Call->getDebugLoc(), &CurrBB)
+           << "Branch to library sqrt fn had to be inserted to satisfy the "
+              "current target's requirement for math functions to set errno on "
+              "invalid inputs";
----------------
fhahn wrote:

Not sure if the `OptimizationRemarkMissed` is the best category for this. Maybe include it in the remark above, as it isn't really a missed optimization `BranchInserted` only happens if`SqrtPartiallyInlined` also happens ?

Or maybe just use `OptimizationRemark`

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


More information about the llvm-commits mailing list