From f03f4944cf829c86bc2c080b9a564bbc59aad277 Mon Sep 17 00:00:00 2001 From: Sanjay Patel Date: Fri, 4 Jun 2021 10:15:22 -0400 Subject: [PATCH] [InstCombine] add tests for pow() reassociation; NFC Baseline tests for D102574 --- llvm/test/Transforms/InstCombine/fmul-pow.ll | 58 ++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) diff --git a/llvm/test/Transforms/InstCombine/fmul-pow.ll b/llvm/test/Transforms/InstCombine/fmul-pow.ll index 7a02062..6e23f77 100644 --- a/llvm/test/Transforms/InstCombine/fmul-pow.ll +++ b/llvm/test/Transforms/InstCombine/fmul-pow.ll @@ -2,6 +2,7 @@ ; RUN: opt -S -instcombine < %s | FileCheck %s declare double @llvm.pow.f64(double, double) +declare void @use(double) define double @pow_ab_a(double %a, double %b) { ; CHECK-LABEL: @pow_ab_a( @@ -88,3 +89,60 @@ define double @pow_ab_x_pow_ac_reassoc(double %a, double %b, double %c) { %mul = fmul reassoc double %2, %1 ret double %mul } + + +define double @pow_ab_reassoc(double %a, double %b) { +; CHECK-LABEL: @pow_ab_reassoc( +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.pow.f64(double [[A:%.*]], double [[B:%.*]]) +; CHECK-NEXT: [[MUL:%.*]] = fmul reassoc double [[TMP1]], [[TMP1]] +; CHECK-NEXT: ret double [[MUL]] +; + %1 = call double @llvm.pow.f64(double %a, double %b) + %mul = fmul reassoc double %1, %1 + ret double %mul +} + +define double @pow_ab_reassoc_extra_use(double %a, double %b) { +; CHECK-LABEL: @pow_ab_reassoc_extra_use( +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.pow.f64(double [[A:%.*]], double [[B:%.*]]) +; CHECK-NEXT: [[MUL:%.*]] = fmul reassoc double [[TMP1]], [[TMP1]] +; CHECK-NEXT: call void @use(double [[TMP1]]) +; CHECK-NEXT: ret double [[MUL]] +; + %1 = call double @llvm.pow.f64(double %a, double %b) + %mul = fmul reassoc double %1, %1 + call void @use(double %1) + ret double %mul +} + +define double @pow_ab_x_pow_ac_reassoc_extra_use(double %a, double %b, double %c) { +; CHECK-LABEL: @pow_ab_x_pow_ac_reassoc_extra_use( +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.pow.f64(double [[A:%.*]], double [[B:%.*]]) +; CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.pow.f64(double [[A]], double [[C:%.*]]) +; CHECK-NEXT: [[MUL:%.*]] = fmul reassoc double [[TMP1]], [[TMP2]] +; CHECK-NEXT: call void @use(double [[TMP1]]) +; CHECK-NEXT: ret double [[MUL]] +; + %1 = call double @llvm.pow.f64(double %a, double %b) + %2 = call double @llvm.pow.f64(double %a, double %c) + %mul = fmul reassoc double %1, %2 + call void @use(double %1) + ret double %mul +} + +define double @pow_ab_x_pow_ac_reassoc_multiple_uses(double %a, double %b, double %c) { +; CHECK-LABEL: @pow_ab_x_pow_ac_reassoc_multiple_uses( +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.pow.f64(double [[A:%.*]], double [[B:%.*]]) +; CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.pow.f64(double [[A]], double [[C:%.*]]) +; CHECK-NEXT: [[MUL:%.*]] = fmul reassoc double [[TMP1]], [[TMP2]] +; CHECK-NEXT: call void @use(double [[TMP1]]) +; CHECK-NEXT: call void @use(double [[TMP2]]) +; CHECK-NEXT: ret double [[MUL]] +; + %1 = call double @llvm.pow.f64(double %a, double %b) + %2 = call double @llvm.pow.f64(double %a, double %c) + %mul = fmul reassoc double %1, %2 + call void @use(double %1) + call void @use(double %2) + ret double %mul +} -- 2.7.4