# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 4
# RUN: llc -mtriple=amdgcn -mcpu=gfx1010 -run-pass=amdgpu-postlegalizer-combiner -verify-machineinstrs %s -o - | FileCheck -check-prefix=GCN %s
---
name: rsq_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %ext:_(s32) = G_ANYEXT [[INT]](s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = contract G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: rsq_f16_missing_contract0
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16_missing_contract0
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = G_FSQRT %x
; GCN-NEXT: %one:_(s16) = G_FCONSTANT half 0xH3C00
; GCN-NEXT: %rsq:_(s16) = contract G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = contract G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: rsq_f16_missing_contract1
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16_missing_contract1
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = contract G_FSQRT %x
; GCN-NEXT: %one:_(s16) = G_FCONSTANT half 0xH3C00
; GCN-NEXT: %rsq:_(s16) = G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %rsq:_(s16) = contract G_FNEG [[INT]]
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%neg_one:_(s16) = G_FCONSTANT half -1.0
%rsq:_(s16) = contract G_FDIV %neg_one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_f16_missing_contract0
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_f16_missing_contract0
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = G_FSQRT %x
; GCN-NEXT: %neg_one:_(s16) = G_FCONSTANT half 0xHBC00
; GCN-NEXT: %rsq:_(s16) = contract G_FDIV %neg_one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = G_FSQRT %x
%neg_one:_(s16) = G_FCONSTANT half -1.0
%rsq:_(s16) = contract G_FDIV %neg_one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_f16_missing_contract1
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_f16_missing_contract1
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = contract G_FSQRT %x
; GCN-NEXT: %neg_one:_(s16) = G_FCONSTANT half 0xHBC00
; GCN-NEXT: %rsq:_(s16) = G_FDIV %neg_one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%neg_one:_(s16) = G_FCONSTANT half -1.0
%rsq:_(s16) = G_FDIV %neg_one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: rsq_f16_multi_use
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16_multi_use
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = contract G_FSQRT %x
; GCN-NEXT: %one:_(s16) = G_FCONSTANT half 0xH3C00
; GCN-NEXT: %rsq:_(s16) = contract G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
; GCN-NEXT: S_ENDPGM 0, implicit %sqrt(s16)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = contract G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
S_ENDPGM 0, implicit %sqrt
...
---
name: rsq_f16_multi_use_missing_contract0
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16_multi_use_missing_contract0
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = G_FSQRT %x
; GCN-NEXT: %one:_(s16) = G_FCONSTANT half 0xH3C00
; GCN-NEXT: %rsq:_(s16) = contract G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
; GCN-NEXT: S_ENDPGM 0, implicit %sqrt(s16)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = contract G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
S_ENDPGM 0, implicit %sqrt
...
---
name: rsq_f16_multi_use_missing_contract1
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f16_multi_use_missing_contract1
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s16) = contract G_FSQRT %x
; GCN-NEXT: %one:_(s16) = G_FCONSTANT half 0xH3C00
; GCN-NEXT: %rsq:_(s16) = G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
; GCN-NEXT: S_ENDPGM 0, implicit %sqrt(s16)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%one:_(s16) = G_FCONSTANT half 1.0
%rsq:_(s16) = G_FDIV %one, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
S_ENDPGM 0, implicit %sqrt
...
---
name: rsq_f32
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f32
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: %x:_(s32) = COPY $vgpr0
; GCN-NEXT: %sqrt:_(s32) = contract G_FSQRT %x
; GCN-NEXT: %one:_(s32) = G_FCONSTANT float 1.000000e+00
; GCN-NEXT: %rsq:_(s32) = contract G_FDIV %one, %sqrt
; GCN-NEXT: $vgpr0 = COPY %rsq(s32)
%x:_(s32) = COPY $vgpr0
%sqrt:_(s32) = contract G_FSQRT %x
%one:_(s32) = G_FCONSTANT float 1.0
%rsq:_(s32) = contract G_FDIV %one, %sqrt
$vgpr0 = COPY %rsq
...
---
name: neg_rsq_f32
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_f32
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: %x:_(s32) = COPY $vgpr0
; GCN-NEXT: %sqrt:_(s32) = contract G_FSQRT %x
; GCN-NEXT: %neg_one:_(s32) = G_FCONSTANT float -1.000000e+00
; GCN-NEXT: %rsq:_(s32) = contract G_FDIV %neg_one, %sqrt
; GCN-NEXT: $vgpr0 = COPY %rsq(s32)
%x:_(s32) = COPY $vgpr0
%sqrt:_(s32) = contract G_FSQRT %x
%neg_one:_(s32) = G_FCONSTANT float -1.0
%rsq:_(s32) = contract G_FDIV %neg_one, %sqrt
$vgpr0 = COPY %rsq
...
---
name: afn_rsq_f32
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: afn_rsq_f32
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: %x:_(s32) = COPY $vgpr0
; GCN-NEXT: %sqrt:_(s32) = contract afn G_FSQRT %x
; GCN-NEXT: %one:_(s32) = G_FCONSTANT float 1.000000e+00
; GCN-NEXT: %rsq:_(s32) = contract afn G_FDIV %one, %sqrt
; GCN-NEXT: $vgpr0 = COPY %rsq(s32)
%x:_(s32) = COPY $vgpr0
%sqrt:_(s32) = contract afn G_FSQRT %x
%one:_(s32) = G_FCONSTANT float 1.0
%rsq:_(s32) = contract afn G_FDIV %one, %sqrt
$vgpr0 = COPY %rsq
...
---
name: afn_rsq_f32_multi_use
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: afn_rsq_f32_multi_use
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: %x:_(s32) = COPY $vgpr0
; GCN-NEXT: %sqrt:_(s32) = contract afn G_FSQRT %x
; GCN-NEXT: %one:_(s32) = G_FCONSTANT float 1.000000e+00
; GCN-NEXT: %rsq:_(s32) = contract afn G_FDIV %one, %sqrt
; GCN-NEXT: %ret:_(s32) = G_FSUB %sqrt, %rsq
; GCN-NEXT: $vgpr0 = COPY %ret(s32)
%x:_(s32) = COPY $vgpr0
%sqrt:_(s32) = contract afn G_FSQRT %x
%one:_(s32) = G_FCONSTANT float 1.0
%rsq:_(s32) = contract afn G_FDIV %one, %sqrt
%ret:_(s32) = G_FSUB %sqrt, %rsq
$vgpr0 = COPY %ret
...
---
name: afn_neg_rsq_f32
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: afn_neg_rsq_f32
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: %x:_(s32) = COPY $vgpr0
; GCN-NEXT: %sqrt:_(s32) = contract afn G_FSQRT %x
; GCN-NEXT: %neg_one:_(s32) = G_FCONSTANT float -1.000000e+00
; GCN-NEXT: %rsq:_(s32) = contract afn G_FDIV %neg_one, %sqrt
; GCN-NEXT: $vgpr0 = COPY %rsq(s32)
%x:_(s32) = COPY $vgpr0
%sqrt:_(s32) = contract afn G_FSQRT %x
%neg_one:_(s32) = G_FCONSTANT float -1.0
%rsq:_(s32) = contract afn G_FDIV %neg_one, %sqrt
$vgpr0 = COPY %rsq
...
---
name: rsq_f64
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_f64
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s64) = G_ANYEXT [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s64) = contract G_FSQRT %x
; GCN-NEXT: %one:_(s64) = G_FCONSTANT double 1.000000e+00
; GCN-NEXT: %rsq:_(s64) = contract G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_TRUNC %rsq(s64)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s64) = G_ANYEXT %0:_(s32)
%sqrt:_(s64) = contract G_FSQRT %x
%one:_(s64) = G_FCONSTANT double 1.0
%rsq:_(s64) = contract G_FDIV %one, %sqrt
%ext:_(s32) = G_TRUNC %rsq:_(s64)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_f64
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_f64
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s64) = G_ANYEXT [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s64) = contract G_FSQRT %x
; GCN-NEXT: %neg_one:_(s64) = G_FCONSTANT double -1.000000e+00
; GCN-NEXT: %rsq:_(s64) = contract G_FDIV %neg_one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_TRUNC %rsq(s64)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s64) = G_ANYEXT %0:_(s32)
%sqrt:_(s64) = contract G_FSQRT %x
%neg_one:_(s64) = G_FCONSTANT double -1.0
%rsq:_(s64) = contract G_FDIV %neg_one, %sqrt
%ext:_(s32) = G_TRUNC %rsq:_(s64)
$vgpr0 = COPY %ext
...
---
name: afn_rsq_f64
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: afn_rsq_f64
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s64) = G_ANYEXT [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s64) = contract afn G_FSQRT %x
; GCN-NEXT: %one:_(s64) = G_FCONSTANT double 1.000000e+00
; GCN-NEXT: %rsq:_(s64) = contract afn G_FDIV %one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_TRUNC %rsq(s64)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s64) = G_ANYEXT %0:_(s32)
%sqrt:_(s64) = contract afn G_FSQRT %x
%one:_(s64) = G_FCONSTANT double 1.0
%rsq:_(s64) = contract afn G_FDIV %one, %sqrt
%ext:_(s32) = G_TRUNC %rsq:_(s64)
$vgpr0 = COPY %ext
...
---
name: afn_neg_rsq_f64
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: afn_neg_rsq_f64
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s64) = G_ANYEXT [[COPY]](s32)
; GCN-NEXT: %sqrt:_(s64) = contract afn G_FSQRT %x
; GCN-NEXT: %neg_one:_(s64) = G_FCONSTANT double -1.000000e+00
; GCN-NEXT: %rsq:_(s64) = contract afn G_FDIV %neg_one, %sqrt
; GCN-NEXT: %ext:_(s32) = G_TRUNC %rsq(s64)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s64) = G_ANYEXT %0:_(s32)
%sqrt:_(s64) = contract afn G_FSQRT %x
%neg_one:_(s64) = G_FCONSTANT double -1.0
%rsq:_(s64) = contract afn G_FDIV %neg_one, %sqrt
%ext:_(s32) = G_TRUNC %rsq:_(s64)
$vgpr0 = COPY %ext
...
---
name: rsq_fract_num_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_fract_num_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %fract:_(s16) = G_FCONSTANT half 0xH3800
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %rsq:_(s16) = contract G_FMUL [[INT]], %fract
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%fract:_(s16) = G_FCONSTANT half 0.5
%rsq:_(s16) = contract G_FDIV %fract, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_fract_num_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_fract_num_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %neg_fract:_(s16) = G_FCONSTANT half 0xHB800
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %rsq:_(s16) = contract G_FMUL [[INT]], %neg_fract
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%neg_fract:_(s16) = G_FCONSTANT half -0.5
%rsq:_(s16) = contract G_FDIV %neg_fract, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: rsq_large_num_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: rsq_large_num_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %ten:_(s16) = G_FCONSTANT half 0xH4900
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %rsq:_(s16) = contract G_FMUL [[INT]], %ten
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%ten:_(s16) = G_FCONSTANT half 10.0
%rsq:_(s16) = contract G_FDIV %ten, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...
---
name: neg_rsq_large_num_f16
tracksRegLiveness: true
body: |
bb.0:
liveins: $vgpr0
; GCN-LABEL: name: neg_rsq_large_num_f16
; GCN: liveins: $vgpr0
; GCN-NEXT: {{ $}}
; GCN-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $vgpr0
; GCN-NEXT: %x:_(s16) = G_TRUNC [[COPY]](s32)
; GCN-NEXT: %neg_ten:_(s16) = G_FCONSTANT half 0xHC900
; GCN-NEXT: [[INT:%[0-9]+]]:_(s16) = contract G_INTRINSIC intrinsic(@llvm.amdgcn.rsq), %x(s16)
; GCN-NEXT: %rsq:_(s16) = contract G_FMUL [[INT]], %neg_ten
; GCN-NEXT: %ext:_(s32) = G_ANYEXT %rsq(s16)
; GCN-NEXT: $vgpr0 = COPY %ext(s32)
%0:_(s32) = COPY $vgpr0
%x:_(s16) = G_TRUNC %0:_(s32)
%sqrt:_(s16) = contract G_FSQRT %x
%neg_ten:_(s16) = G_FCONSTANT half -10.0
%rsq:_(s16) = contract G_FDIV %neg_ten, %sqrt
%ext:_(s32) = G_ANYEXT %rsq:_(s16)
$vgpr0 = COPY %ext
...