mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-22 12:33:33 +02:00
5dfc642fbd
Try to avoid mutually exclusive features. Don't use a real default GPU, and use a fake "generic". The goal is to make it easier to see which set of features are incompatible between feature strings. Most of the test changes are due to random scheduling changes from not having a default fullspeed model. llvm-svn: 310258
96 lines
2.8 KiB
LLVM
96 lines
2.8 KiB
LLVM
; RUN: llc -amdgpu-scalarize-global-loads=false -march=amdgcn -mcpu=tahiti -verify-machineinstrs -enable-unsafe-fp-math < %s | FileCheck -check-prefix=GCN -check-prefix=SI %s
|
|
; RUN: llc -amdgpu-scalarize-global-loads=false -march=amdgcn -mcpu=fiji -mattr=-flat-for-global -verify-machineinstrs -enable-unsafe-fp-math < %s | FileCheck -check-prefix=GCN -check-prefix=VI %s
|
|
|
|
; GCN-LABEL: {{^}}sitofp_i16_to_f16
|
|
; GCN: buffer_load_{{sshort|ushort}} v[[A_I16:[0-9]+]]
|
|
; GCN: v_cvt_f32_i32_e32 v[[A_F32:[0-9]+]], v[[A_I16]]
|
|
; GCN: v_cvt_f16_f32_e32 v[[R_F16:[0-9]+]], v[[A_F32]]
|
|
; GCN: buffer_store_short v[[R_F16]]
|
|
; GCN: s_endpgm
|
|
define amdgpu_kernel void @sitofp_i16_to_f16(
|
|
half addrspace(1)* %r,
|
|
i16 addrspace(1)* %a) {
|
|
entry:
|
|
%a.val = load i16, i16 addrspace(1)* %a
|
|
%r.val = sitofp i16 %a.val to half
|
|
store half %r.val, half addrspace(1)* %r
|
|
ret void
|
|
}
|
|
|
|
; GCN-LABEL: {{^}}sitofp_i32_to_f16
|
|
; GCN: buffer_load_dword v[[A_I32:[0-9]+]]
|
|
; GCN: v_cvt_f32_i32_e32 v[[A_I16:[0-9]+]], v[[A_I32]]
|
|
; GCN: v_cvt_f16_f32_e32 v[[R_F16:[0-9]+]], v[[A_I16]]
|
|
; GCN: buffer_store_short v[[R_F16]]
|
|
; GCN: s_endpgm
|
|
define amdgpu_kernel void @sitofp_i32_to_f16(
|
|
half addrspace(1)* %r,
|
|
i32 addrspace(1)* %a) {
|
|
entry:
|
|
%a.val = load i32, i32 addrspace(1)* %a
|
|
%r.val = sitofp i32 %a.val to half
|
|
store half %r.val, half addrspace(1)* %r
|
|
ret void
|
|
}
|
|
|
|
; f16 = sitofp i64 is in sint_to_fp.i64.ll
|
|
|
|
; GCN-LABEL: {{^}}sitofp_v2i16_to_v2f16
|
|
; GCN: buffer_load_dword
|
|
|
|
; SI: v_cvt_f32_i32_e32
|
|
; SI: v_cvt_f32_i32_e32
|
|
; SI: v_cvt_f16_f32_e32
|
|
; SI: v_cvt_f16_f32_e32
|
|
; SI-DAG: v_lshlrev_b32_e32
|
|
; SI: v_or_b32_e32
|
|
|
|
; VI-DAG: v_cvt_f32_i32_sdwa
|
|
; VI-DAG: v_cvt_f32_i32_sdwa
|
|
; VI-DAG: v_cvt_f16_f32_e32
|
|
; VI-DAG: v_cvt_f16_f32_sdwa
|
|
; VI: v_or_b32_e32
|
|
|
|
; GCN: buffer_store_dword
|
|
; GCN: s_endpgm
|
|
|
|
define amdgpu_kernel void @sitofp_v2i16_to_v2f16(
|
|
<2 x half> addrspace(1)* %r,
|
|
<2 x i16> addrspace(1)* %a) {
|
|
entry:
|
|
%a.val = load <2 x i16>, <2 x i16> addrspace(1)* %a
|
|
%r.val = sitofp <2 x i16> %a.val to <2 x half>
|
|
store <2 x half> %r.val, <2 x half> addrspace(1)* %r
|
|
ret void
|
|
}
|
|
|
|
; GCN-LABEL: {{^}}sitofp_v2i32_to_v2f16
|
|
; GCN: buffer_load_dwordx2
|
|
|
|
; SI: v_cvt_f32_i32_e32
|
|
; SI: v_cvt_f32_i32_e32
|
|
; SI: v_cvt_f16_f32_e32
|
|
; SI: v_cvt_f16_f32_e32
|
|
; SI-DAG: v_lshlrev_b32_e32
|
|
; SI: v_or_b32_e32
|
|
|
|
; VI-DAG: v_cvt_f32_i32_e32
|
|
; VI-DAG: v_cvt_f32_i32_e32
|
|
; VI-DAG: v_cvt_f16_f32_e32
|
|
; VI-DAG: v_cvt_f16_f32_sdwa
|
|
; VI: v_or_b32_e32
|
|
|
|
; GCN: buffer_store_dword
|
|
; GCN: s_endpgm
|
|
define amdgpu_kernel void @sitofp_v2i32_to_v2f16(
|
|
<2 x half> addrspace(1)* %r,
|
|
<2 x i32> addrspace(1)* %a) {
|
|
entry:
|
|
%a.val = load <2 x i32>, <2 x i32> addrspace(1)* %a
|
|
%r.val = sitofp <2 x i32> %a.val to <2 x half>
|
|
store <2 x half> %r.val, <2 x half> addrspace(1)* %r
|
|
ret void
|
|
}
|
|
|
|
; v2f16 = sitofp v2i64 is in sint_to_fp.i64.ll
|