blob: 0031a61059ab27a300bf48ffdc1d0c34fb852819 [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
8define double @sqrt_a_sqrt_b(double %a, double %b) {
9; CHECK-LABEL: @sqrt_a_sqrt_b(
10; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.sqrt.f64(double [[A:%.*]])
11; CHECK-NEXT: [[TMP2:%.*]] = call double @llvm.sqrt.f64(double [[B:%.*]])
12; CHECK-NEXT: [[MUL:%.*]] = fmul double [[TMP1]], [[TMP2]]
13; CHECK-NEXT: ret double [[MUL]]
14;
15 %1 = call double @llvm.sqrt.f64(double %a)
16 %2 = call double @llvm.sqrt.f64(double %b)
17 %mul = fmul double %1, %2
18 ret double %mul
19}
20
21; sqrt(a) * sqrt(b) fast-math, multiple uses
22define double @sqrt_a_sqrt_b_multiple_uses(double %a, double %b) {
23; CHECK-LABEL: @sqrt_a_sqrt_b_multiple_uses(
24; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.sqrt.f64(double [[A:%.*]])
25; CHECK-NEXT: [[TMP2:%.*]] = call fast double @llvm.sqrt.f64(double [[B:%.*]])
26; CHECK-NEXT: [[MUL:%.*]] = fmul fast double [[TMP1]], [[TMP2]]
27; CHECK-NEXT: call void @use(double [[TMP2]])
28; CHECK-NEXT: ret double [[MUL]]
29;
30 %1 = call fast double @llvm.sqrt.f64(double %a)
31 %2 = call fast double @llvm.sqrt.f64(double %b)
32 %mul = fmul fast double %1, %2
33 call void @use(double %2)
34 ret double %mul
35}
36
37; sqrt(a) * sqrt(b) => sqrt(a*b) with fast-math
38define double @sqrt_a_sqrt_b_fast(double %a, double %b) {
39; CHECK-LABEL: @sqrt_a_sqrt_b_fast(
40; CHECK-NEXT: [[TMP1:%.*]] = fmul fast double [[A:%.*]], [[B:%.*]]
41; CHECK-NEXT: [[TMP2:%.*]] = call fast double @llvm.sqrt.f64(double [[TMP1]])
42; CHECK-NEXT: ret double [[TMP2]]
43;
44 %1 = call fast double @llvm.sqrt.f64(double %a)
45 %2 = call fast double @llvm.sqrt.f64(double %b)
46 %mul = fmul fast double %1, %2
47 ret double %mul
48}
49
50; sqrt(a) * sqrt(b) * sqrt(c) * sqrt(d) => sqrt(a*b*c+d) with fast-math
51define double @sqrt_a_sqrt_b_sqrt_c_sqrt_d_fast(double %a, double %b, double %c, double %d) {
52; CHECK-LABEL: @sqrt_a_sqrt_b_sqrt_c_sqrt_d_fast(
53; CHECK-NEXT: [[TMP1:%.*]] = fmul fast double [[A:%.*]], [[B:%.*]]
54; CHECK-NEXT: [[TMP2:%.*]] = fmul fast double [[TMP1]], [[C:%.*]]
55; CHECK-NEXT: [[TMP3:%.*]] = fmul fast double [[TMP2]], [[D:%.*]]
56; CHECK-NEXT: [[TMP4:%.*]] = call fast double @llvm.sqrt.f64(double [[TMP3]])
57; CHECK-NEXT: ret double [[TMP4]]
58;
59 %1 = call fast double @llvm.sqrt.f64(double %a)
60 %2 = call fast double @llvm.sqrt.f64(double %b)
61 %mul = fmul fast double %1, %2
62 %3 = call fast double @llvm.sqrt.f64(double %c)
63 %mul1 = fmul fast double %mul, %3
64 %4 = call fast double @llvm.sqrt.f64(double %d)
65 %mul2 = fmul fast double %mul1, %4
66 ret double %mul2
67}