| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: opt -S -mtriple=amdgcn-- -mcpu=gfx700 -passes=amdgpu-codegenprepare %s | FileCheck -check-prefixes=CHECK,GFX7 %s |
| ; RUN: opt -S -mtriple=amdgcn-- -mcpu=gfx803 -passes=amdgpu-codegenprepare %s | FileCheck -check-prefixes=CHECK,GFX8 %s |
| |
| ; Ignore correct case |
| define half @log_f16(half %x) { |
| ; CHECK-LABEL: define half @log_f16( |
| ; CHECK-SAME: half [[X:%.*]]) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: [[RESULT:%.*]] = call half @llvm.log.f16(half [[X]]) |
| ; CHECK-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log.f16(half %x) |
| ret half %result |
| } |
| |
| ; afn case should be handled by codegen |
| define half @log_afn_f16(half %x) { |
| ; CHECK-LABEL: define half @log_afn_f16( |
| ; CHECK-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[RESULT:%.*]] = call afn half @llvm.log.f16(half [[X]]) |
| ; CHECK-NEXT: ret half [[RESULT]] |
| ; |
| %result = call afn half @llvm.log.f16(half %x) |
| ret half %result |
| } |
| |
| ; exact ulp threshold |
| define half @log_f16_ulp180(half %x) { |
| ; GFX7-LABEL: define half @log_f16_ulp180( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call half @llvm.log.f16(half [[X]]), !fpmath [[META0:![0-9]+]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log_f16_ulp180( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[TMP1:%.*]] = call half @llvm.log2.f16(half [[X]]) |
| ; GFX8-NEXT: [[RESULT:%.*]] = fmul half [[TMP1]], 0xH398C |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log.f16(half %x), !fpmath !{float 0x3FFCCCCCC0000000} |
| ret half %result |
| } |
| |
| ; off by one, ignore |
| define half @log_f16_ulp180_nextdown(half %x) { |
| ; GFX7-LABEL: define half @log_f16_ulp180_nextdown( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call half @llvm.log.f16(half [[X]]), !fpmath [[META1:![0-9]+]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log_f16_ulp180_nextdown( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[RESULT:%.*]] = call half @llvm.log.f16(half [[X]]), !fpmath [[META0:![0-9]+]] |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log.f16(half %x), !fpmath !{float 0x3FFCCCCCA0000000} |
| ret half %result |
| } |
| |
| ; OpenCL limit |
| define half @log_f16_ulp2(half %x) { |
| ; GFX7-LABEL: define half @log_f16_ulp2( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call half @llvm.log.f16(half [[X]]), !fpmath [[META2:![0-9]+]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log_f16_ulp2( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[TMP1:%.*]] = call half @llvm.log2.f16(half [[X]]) |
| ; GFX8-NEXT: [[RESULT:%.*]] = fmul half [[TMP1]], 0xH398C |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log.f16(half %x), !fpmath !0 |
| ret half %result |
| } |
| |
| ; OpenCL limit |
| define half @log10_f16_ulp2(half %x) { |
| ; GFX7-LABEL: define half @log10_f16_ulp2( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call half @llvm.log10.f16(half [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log10_f16_ulp2( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[TMP1:%.*]] = call half @llvm.log2.f16(half [[X]]) |
| ; GFX8-NEXT: [[RESULT:%.*]] = fmul half [[TMP1]], 0xH34D1 |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log10.f16(half %x), !fpmath !0 |
| ret half %result |
| } |
| |
| ; Ignore log2 |
| define half @log2_f16_ulp2(half %x) { |
| ; GFX7-LABEL: define half @log2_f16_ulp2( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call half @llvm.log2.f16(half [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log2_f16_ulp2( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[RESULT:%.*]] = call half @llvm.log2.f16(half [[X]]), !fpmath [[META1:![0-9]+]] |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call half @llvm.log2.f16(half %x), !fpmath !0 |
| ret half %result |
| } |
| |
| ; afn case should be handled by codegen |
| define half @log_afn_f16_ulp2(half %x) { |
| ; GFX7-LABEL: define half @log_afn_f16_ulp2( |
| ; GFX7-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call afn half @llvm.log.f16(half [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret half [[RESULT]] |
| ; |
| ; GFX8-LABEL: define half @log_afn_f16_ulp2( |
| ; GFX8-SAME: half [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[RESULT:%.*]] = call afn half @llvm.log.f16(half [[X]]), !fpmath [[META1]] |
| ; GFX8-NEXT: ret half [[RESULT]] |
| ; |
| %result = call afn half @llvm.log.f16(half %x), !fpmath !0 |
| ret half %result |
| } |
| |
| ; Handle vector with scalarization |
| define <2 x half> @log_v2f16_ulp2(<2 x half> %x) { |
| ; GFX7-LABEL: define <2 x half> @log_v2f16_ulp2( |
| ; GFX7-SAME: <2 x half> [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call <2 x half> @llvm.log.v2f16(<2 x half> [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret <2 x half> [[RESULT]] |
| ; |
| ; GFX8-LABEL: define <2 x half> @log_v2f16_ulp2( |
| ; GFX8-SAME: <2 x half> [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[TMP1:%.*]] = call <2 x half> @llvm.log2.v2f16(<2 x half> [[X]]) |
| ; GFX8-NEXT: [[RESULT:%.*]] = fmul <2 x half> [[TMP1]], splat (half 0xH398C) |
| ; GFX8-NEXT: ret <2 x half> [[RESULT]] |
| ; |
| %result = call <2 x half> @llvm.log.v2f16(<2 x half> %x), !fpmath !0 |
| ret <2 x half> %result |
| } |
| |
| ; Handle vector with scalarization |
| define <3 x half> @log_v3f16_ulp2(<3 x half> %x) { |
| ; GFX7-LABEL: define <3 x half> @log_v3f16_ulp2( |
| ; GFX7-SAME: <3 x half> [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call <3 x half> @llvm.log.v3f16(<3 x half> [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret <3 x half> [[RESULT]] |
| ; |
| ; GFX8-LABEL: define <3 x half> @log_v3f16_ulp2( |
| ; GFX8-SAME: <3 x half> [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[TMP1:%.*]] = call <3 x half> @llvm.log2.v3f16(<3 x half> [[X]]) |
| ; GFX8-NEXT: [[RESULT:%.*]] = fmul <3 x half> [[TMP1]], splat (half 0xH398C) |
| ; GFX8-NEXT: ret <3 x half> [[RESULT]] |
| ; |
| %result = call <3 x half> @llvm.log.v3f16(<3 x half> %x), !fpmath !0 |
| ret <3 x half> %result |
| } |
| |
| ; bfloat not handled |
| define bfloat @log_bf16_ulp2(bfloat %x) { |
| ; GFX7-LABEL: define bfloat @log_bf16_ulp2( |
| ; GFX7-SAME: bfloat [[X:%.*]]) #[[ATTR0]] { |
| ; GFX7-NEXT: [[RESULT:%.*]] = call bfloat @llvm.log.bf16(bfloat [[X]]), !fpmath [[META2]] |
| ; GFX7-NEXT: ret bfloat [[RESULT]] |
| ; |
| ; GFX8-LABEL: define bfloat @log_bf16_ulp2( |
| ; GFX8-SAME: bfloat [[X:%.*]]) #[[ATTR0]] { |
| ; GFX8-NEXT: [[RESULT:%.*]] = call bfloat @llvm.log.bf16(bfloat [[X]]), !fpmath [[META1]] |
| ; GFX8-NEXT: ret bfloat [[RESULT]] |
| ; |
| %result = call bfloat @llvm.log.bf16(bfloat %x), !fpmath !0 |
| ret bfloat %result |
| } |
| |
| !0 = !{float 2.0} |
| |
| |
| ;. |
| ; GFX7: [[META0]] = !{float 0x3FFCCCCCC0000000} |
| ; GFX7: [[META1]] = !{float 0x3FFCCCCCA0000000} |
| ; GFX7: [[META2]] = !{float 2.000000e+00} |
| ;. |
| ; GFX8: [[META0]] = !{float 0x3FFCCCCCA0000000} |
| ; GFX8: [[META1]] = !{float 2.000000e+00} |
| ;. |