| 12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- ; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
- declare float @llvm.nvvm.sqrt.f(float)
- ; CHECK: sqrt_div
- ; CHECK: sqrt.rn.f32
- ; CHECK: div.rn.f32
- define float @sqrt_div(float %a, float %b) {
- %t1 = tail call float @llvm.nvvm.sqrt.f(float %a)
- %t2 = fdiv float %t1, %b
- ret float %t2
- }
- ; CHECK: sqrt_div_fast
- ; CHECK: sqrt.approx.f32
- ; CHECK: div.approx.f32
- define float @sqrt_div_fast(float %a, float %b) #0 {
- %t1 = tail call float @llvm.nvvm.sqrt.f(float %a)
- %t2 = fdiv float %t1, %b
- ret float %t2
- }
- ; CHECK: fadd
- ; CHECK: add.f32
- define float @fadd(float %a, float %b) {
- %t1 = fadd float %a, %b
- ret float %t1
- }
- ; CHECK: fadd_ftz
- ; CHECK: add.ftz.f32
- define float @fadd_ftz(float %a, float %b) #1 {
- %t1 = fadd float %a, %b
- ret float %t1
- }
- attributes #0 = { "unsafe-fp-math" = "true" }
- attributes #1 = { "nvptx-f32ftz" = "true" }
|