blob: 582fa606d3b06797057d9b2d09913e0f8f7bbe62 [file] [log] [blame]
Dmitry Venikova58d8de2018-01-02 05:58:11 +00001; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: opt -S -instcombine < %s | FileCheck %s
3
4declare double @llvm.sqrt.f64(double) nounwind readnone speculatable
5declare void @use(double)
6
7; sqrt(a) * sqrt(b) no math flags
Sanjay Pateld32104e2018-02-23 21:16:12 +00008
Dmitry Venikova58d8de2018-01-02 05:58:11 +00009define double @sqrt_a_sqrt_b(double %a, double %b) {
10; CHECK-LABEL: @sqrt_a_sqrt_b(
11; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.sqrt.f64(double [[A:%.*]])
12; CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.sqrt.f64(double [[B:%.*]])
13; CHECK-NEXT: [[MUL:%.*]] = fmul double [[TMP1]], [[TMP2]]
14; CHECK-NEXT: ret double [[MUL]]
15;
16 %1 = call double @llvm.sqrt.f64(double %a)
17 %2 = call double @llvm.sqrt.f64(double %b)
18 %mul = fmul double %1, %2
19 ret double %mul
20}
21
22; sqrt(a) * sqrt(b) fast-math, multiple uses
Sanjay Pateld32104e2018-02-23 21:16:12 +000023
Dmitry Venikova58d8de2018-01-02 05:58:11 +000024define double @sqrt_a_sqrt_b_multiple_uses(double %a, double %b) {
25; CHECK-LABEL: @sqrt_a_sqrt_b_multiple_uses(
26; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.sqrt.f64(double [[A:%.*]])
27; CHECK-NEXT: [[TMP2:%.*]] = call fast double @llvm.sqrt.f64(double [[B:%.*]])
28; CHECK-NEXT: [[MUL:%.*]] = fmul fast double [[TMP1]], [[TMP2]]
29; CHECK-NEXT: call void @use(double [[TMP2]])
30; CHECK-NEXT: ret double [[MUL]]
31;
32 %1 = call fast double @llvm.sqrt.f64(double %a)
33 %2 = call fast double @llvm.sqrt.f64(double %b)
34 %mul = fmul fast double %1, %2
35 call void @use(double %2)
36 ret double %mul
37}
38
39; sqrt(a) * sqrt(b) => sqrt(a*b) with fast-math
Sanjay Pateld32104e2018-02-23 21:16:12 +000040
41define double @sqrt_a_sqrt_b_reassoc(double %a, double %b) {
42; CHECK-LABEL: @sqrt_a_sqrt_b_reassoc(
43; CHECK-NEXT: [[TMP1:%.*]] = fmul reassoc double [[A:%.*]], [[B:%.*]]
44; CHECK-NEXT: [[TMP2:%.*]] = call reassoc double @llvm.sqrt.f64(double [[TMP1]])
Dmitry Venikova58d8de2018-01-02 05:58:11 +000045; CHECK-NEXT: ret double [[TMP2]]
46;
Sanjay Pateld32104e2018-02-23 21:16:12 +000047 %1 = call double @llvm.sqrt.f64(double %a)
48 %2 = call double @llvm.sqrt.f64(double %b)
49 %mul = fmul reassoc double %1, %2
Dmitry Venikova58d8de2018-01-02 05:58:11 +000050 ret double %mul
51}
52
Sanjay Pateld32104e2018-02-23 21:16:12 +000053; sqrt(a) * sqrt(b) * sqrt(c) * sqrt(d) => sqrt(a*b*c*d) with fast-math
54; 'reassoc' on the fmuls is all that is required, but check propagation of other FMF.
55
56define double @sqrt_a_sqrt_b_sqrt_c_sqrt_d_reassoc(double %a, double %b, double %c, double %d) {
57; CHECK-LABEL: @sqrt_a_sqrt_b_sqrt_c_sqrt_d_reassoc(
58; CHECK-NEXT: [[TMP1:%.*]] = fmul reassoc arcp double [[A:%.*]], [[B:%.*]]
59; CHECK-NEXT: [[TMP2:%.*]] = fmul reassoc nnan double [[TMP1]], [[C:%.*]]
60; CHECK-NEXT: [[TMP3:%.*]] = fmul reassoc ninf double [[TMP2]], [[D:%.*]]
61; CHECK-NEXT: [[TMP4:%.*]] = call reassoc ninf double @llvm.sqrt.f64(double [[TMP3]])
Dmitry Venikova58d8de2018-01-02 05:58:11 +000062; CHECK-NEXT: ret double [[TMP4]]
63;
Sanjay Pateld32104e2018-02-23 21:16:12 +000064 %1 = call double @llvm.sqrt.f64(double %a)
65 %2 = call double @llvm.sqrt.f64(double %b)
66 %3 = call double @llvm.sqrt.f64(double %c)
67 %4 = call double @llvm.sqrt.f64(double %d)
68 %mul = fmul reassoc arcp double %1, %2
69 %mul1 = fmul reassoc nnan double %mul, %3
70 %mul2 = fmul reassoc ninf double %mul1, %4
Dmitry Venikova58d8de2018-01-02 05:58:11 +000071 ret double %mul2
72}
Sanjay Pateld32104e2018-02-23 21:16:12 +000073