[PATCH] D157894: InstSimplify: Handle exp10(log10(x)) -> x

Matt Arsenault via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Aug 14 08:46:40 PDT 2023


arsenm created this revision.
arsenm added reviewers: jcranmer-intel, foad, kpn, sepavloff, andrew.w.kaylor.
Herald added subscribers: StephenFan, hiraditya.
Herald added a project: All.
arsenm requested review of this revision.
Herald added a subscriber: wdng.
Herald added a project: LLVM.

Copy from exp/exp2 case.


https://reviews.llvm.org/D157894

Files:
  llvm/lib/Analysis/InstructionSimplify.cpp
  llvm/test/Transforms/InstSimplify/log-exp-intrinsic.ll


Index: llvm/test/Transforms/InstSimplify/log-exp-intrinsic.ll
===================================================================
--- llvm/test/Transforms/InstSimplify/log-exp-intrinsic.ll
+++ llvm/test/Transforms/InstSimplify/log-exp-intrinsic.ll
@@ -246,9 +246,7 @@
 
 define double @exp10_reassoc_log10_strict(double %a) {
 ; CHECK-LABEL: @exp10_reassoc_log10_strict(
-; CHECK-NEXT:    [[TMP1:%.*]] = call double @llvm.log10.f64(double [[A:%.*]])
-; CHECK-NEXT:    [[TMP2:%.*]] = call reassoc double @llvm.exp10.f64(double [[TMP1]])
-; CHECK-NEXT:    ret double [[TMP2]]
+; CHECK-NEXT:    ret double [[A:%.*]]
 ;
   %1 = call double @llvm.log10.f64(double %a)
   %2 = call reassoc double @llvm.exp10.f64(double %1)
@@ -283,11 +281,7 @@
 
 define double @exp10_log10_exp10_log10_reassoc(double %a) {
 ; CHECK-LABEL: @exp10_log10_exp10_log10_reassoc(
-; CHECK-NEXT:    [[TMP1:%.*]] = call double @llvm.log10.f64(double [[A:%.*]])
-; CHECK-NEXT:    [[TMP2:%.*]] = call reassoc double @llvm.exp10.f64(double [[TMP1]])
-; CHECK-NEXT:    [[TMP3:%.*]] = call double @llvm.log10.f64(double [[TMP2]])
-; CHECK-NEXT:    [[TMP4:%.*]] = call reassoc double @llvm.exp10.f64(double [[TMP3]])
-; CHECK-NEXT:    ret double [[TMP4]]
+; CHECK-NEXT:    ret double [[A:%.*]]
 ;
   %1 = call double @llvm.log10.f64(double %a)
   %2 = call reassoc double @llvm.exp10.f64(double %1)
Index: llvm/lib/Analysis/InstructionSimplify.cpp
===================================================================
--- llvm/lib/Analysis/InstructionSimplify.cpp
+++ llvm/lib/Analysis/InstructionSimplify.cpp
@@ -6153,6 +6153,12 @@
         match(Op0, m_Intrinsic<Intrinsic::log2>(m_Value(X))))
       return X;
     break;
+  case Intrinsic::exp10:
+    // exp10(log10(x)) -> x
+    if (Q.CxtI->hasAllowReassoc() &&
+        match(Op0, m_Intrinsic<Intrinsic::log10>(m_Value(X))))
+      return X;
+    break;
   case Intrinsic::log:
     // log(exp(x)) -> x
     if (Q.CxtI->hasAllowReassoc() &&


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D157894.549972.patch
Type: text/x-patch
Size: 1960 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20230814/277358bf/attachment.bin>


More information about the llvm-commits mailing list