# 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 ...