blob: 61d98c7972cafb9ee5789a66b86e274361323790 [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
Sanjay Patel63b10282018-03-18 14:32:54 +000041define double @sqrt_a_sqrt_b_reassoc_nnan(double %a, double %b) {
42; CHECK-LABEL: @sqrt_a_sqrt_b_reassoc_nnan(
43; CHECK-NEXT: [[TMP1:%.*]] = fmul reassoc nnan double [[A:%.*]], [[B:%.*]]
44; CHECK-NEXT: [[TMP2:%.*]] = call reassoc nnan double @llvm.sqrt.f64(double [[TMP1]])
45; CHECK-NEXT: ret double [[TMP2]]
46;
47 %1 = call double @llvm.sqrt.f64(double %a)
48 %2 = call double @llvm.sqrt.f64(double %b)
49 %mul = fmul reassoc nnan double %1, %2
50 ret double %mul
51}
52
53; nnan disallows the possibility that both operands are negative,
54; so we won't return a number when the answer should be NaN.
55
Sanjay Pateld32104e2018-02-23 21:16:12 +000056define double @sqrt_a_sqrt_b_reassoc(double %a, double %b) {
57; CHECK-LABEL: @sqrt_a_sqrt_b_reassoc(
Sanjay Patel63b10282018-03-18 14:32:54 +000058; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.sqrt.f64(double [[A:%.*]])
59; CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.sqrt.f64(double [[B:%.*]])
60; CHECK-NEXT: [[MUL:%.*]] = fmul reassoc double [[TMP1]], [[TMP2]]
61; CHECK-NEXT: ret double [[MUL]]
Dmitry Venikova58d8de2018-01-02 05:58:11 +000062;
Sanjay Pateld32104e2018-02-23 21:16:12 +000063 %1 = call double @llvm.sqrt.f64(double %a)
64 %2 = call double @llvm.sqrt.f64(double %b)
65 %mul = fmul reassoc double %1, %2
Dmitry Venikova58d8de2018-01-02 05:58:11 +000066 ret double %mul
67}
68
Sanjay Pateld32104e2018-02-23 21:16:12 +000069; sqrt(a) * sqrt(b) * sqrt(c) * sqrt(d) => sqrt(a*b*c*d) with fast-math
Sanjay Patel63b10282018-03-18 14:32:54 +000070; 'reassoc nnan' on the fmuls is all that is required, but check propagation of other FMF.
Sanjay Pateld32104e2018-02-23 21:16:12 +000071
72define double @sqrt_a_sqrt_b_sqrt_c_sqrt_d_reassoc(double %a, double %b, double %c, double %d) {
73; CHECK-LABEL: @sqrt_a_sqrt_b_sqrt_c_sqrt_d_reassoc(
Sanjay Patel63b10282018-03-18 14:32:54 +000074; CHECK-NEXT: [[TMP1:%.*]] = fmul reassoc nnan arcp double [[A:%.*]], [[B:%.*]]
Sanjay Pateld32104e2018-02-23 21:16:12 +000075; CHECK-NEXT: [[TMP2:%.*]] = fmul reassoc nnan double [[TMP1]], [[C:%.*]]
Sanjay Patel63b10282018-03-18 14:32:54 +000076; CHECK-NEXT: [[TMP3:%.*]] = fmul reassoc nnan ninf double [[TMP2]], [[D:%.*]]
77; CHECK-NEXT: [[TMP4:%.*]] = call reassoc nnan ninf double @llvm.sqrt.f64(double [[TMP3]])
Dmitry Venikova58d8de2018-01-02 05:58:11 +000078; CHECK-NEXT: ret double [[TMP4]]
79;
Sanjay Pateld32104e2018-02-23 21:16:12 +000080 %1 = call double @llvm.sqrt.f64(double %a)
81 %2 = call double @llvm.sqrt.f64(double %b)
82 %3 = call double @llvm.sqrt.f64(double %c)
83 %4 = call double @llvm.sqrt.f64(double %d)
Sanjay Patel63b10282018-03-18 14:32:54 +000084 %mul = fmul reassoc nnan arcp double %1, %2
Sanjay Pateld32104e2018-02-23 21:16:12 +000085 %mul1 = fmul reassoc nnan double %mul, %3
Sanjay Patel63b10282018-03-18 14:32:54 +000086 %mul2 = fmul reassoc nnan ninf double %mul1, %4
Dmitry Venikova58d8de2018-01-02 05:58:11 +000087 ret double %mul2
88}
Sanjay Pateld32104e2018-02-23 21:16:12 +000089