Duncan Sands | 3ef3fcf | 2012-04-08 18:08:12 +0000 | [diff] [blame^] | 1 | ; RUN: llc < %s -march=x86-64 -enable-unsafe-fp-math | FileCheck %s |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 2 | |
| 3 | define double @exact(double %x) { |
Duncan Sands | 3ef3fcf | 2012-04-08 18:08:12 +0000 | [diff] [blame^] | 4 | ; Exact division by a constant converted to multiplication. |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 5 | ; CHECK: @exact |
| 6 | ; CHECK: mulsd |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 7 | %div = fdiv double %x, 2.0 |
| 8 | ret double %div |
| 9 | } |
| 10 | |
| 11 | define double @inexact(double %x) { |
Duncan Sands | 3ef3fcf | 2012-04-08 18:08:12 +0000 | [diff] [blame^] | 12 | ; Inexact division by a constant converted to multiplication. |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 13 | ; CHECK: @inexact |
Duncan Sands | 3ef3fcf | 2012-04-08 18:08:12 +0000 | [diff] [blame^] | 14 | ; CHECK: mulsd |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 15 | %div = fdiv double %x, 0x41DFFFFFFFC00000 |
| 16 | ret double %div |
| 17 | } |
| 18 | |
| 19 | define double @funky(double %x) { |
| 20 | ; No conversion to multiplication if too funky. |
| 21 | ; CHECK: @funky |
| 22 | ; CHECK: divsd |
Duncan Sands | 961d666 | 2012-04-07 20:04:00 +0000 | [diff] [blame] | 23 | %div = fdiv double %x, 0.0 |
| 24 | ret double %div |
| 25 | } |