blob: 0749682e2f681e3eb6eec817af24fccaafc866a4 [file] [log] [blame]
Duncan Sands3ef3fcf2012-04-08 18:08:12 +00001; RUN: llc < %s -march=x86-64 -enable-unsafe-fp-math | FileCheck %s
Duncan Sands961d6662012-04-07 20:04:00 +00002
3define double @exact(double %x) {
Duncan Sands3ef3fcf2012-04-08 18:08:12 +00004; Exact division by a constant converted to multiplication.
Duncan Sands961d6662012-04-07 20:04:00 +00005; CHECK: @exact
6; CHECK: mulsd
Duncan Sands961d6662012-04-07 20:04:00 +00007 %div = fdiv double %x, 2.0
8 ret double %div
9}
10
11define double @inexact(double %x) {
Duncan Sands3ef3fcf2012-04-08 18:08:12 +000012; Inexact division by a constant converted to multiplication.
Duncan Sands961d6662012-04-07 20:04:00 +000013; CHECK: @inexact
Duncan Sands3ef3fcf2012-04-08 18:08:12 +000014; CHECK: mulsd
Duncan Sands961d6662012-04-07 20:04:00 +000015 %div = fdiv double %x, 0x41DFFFFFFFC00000
16 ret double %div
17}
18
19define double @funky(double %x) {
20; No conversion to multiplication if too funky.
21; CHECK: @funky
22; CHECK: divsd
Duncan Sands961d6662012-04-07 20:04:00 +000023 %div = fdiv double %x, 0.0
24 ret double %div
25}
Duncan Sands507bb7a2012-04-10 20:35:27 +000026
27define double @denormal1(double %x) {
28; Don't generate multiplication by a denormal.
29; CHECK: @denormal1
30; CHECK: divsd
31 %div = fdiv double %x, 0x7FD0000000000001
32 ret double %div
33}
34
35define double @denormal2(double %x) {
36; Don't generate multiplication by a denormal.
37; CHECK: @denormal
38; CHECK: divsd
39 %div = fdiv double %x, 0x7FEFFFFFFFFFFFFF
40 ret double %div
41}