mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
R600/SI: Add VCC as an implict def of SI_KILL
When SI_KILL has a register operand, its lowered form writes to vcc. llvm-svn: 236307
This commit is contained in:
parent
6da1425028
commit
b37aaa4862
@ -1896,8 +1896,8 @@ def SGPR_USE : InstSI <(outs),(ins), "", []>;
|
||||
// SI pseudo instructions. These are used by the CFG structurizer pass
|
||||
// and should be lowered to ISA instructions prior to codegen.
|
||||
|
||||
let mayLoad = 1, mayStore = 1, hasSideEffects = 1,
|
||||
Uses = [EXEC], Defs = [EXEC] in {
|
||||
let mayLoad = 1, mayStore = 1, hasSideEffects = 1 in {
|
||||
let Uses = [EXEC], Defs = [EXEC] in {
|
||||
|
||||
let isBranch = 1, isTerminator = 1 in {
|
||||
|
||||
@ -1954,15 +1954,18 @@ def SI_END_CF : InstSI <
|
||||
[(int_SI_end_cf i64:$saved)]
|
||||
>;
|
||||
|
||||
} // End Uses = [EXEC], Defs = [EXEC]
|
||||
|
||||
let Uses = [EXEC], Defs = [EXEC,VCC] in {
|
||||
def SI_KILL : InstSI <
|
||||
(outs),
|
||||
(ins VSrc_32:$src),
|
||||
"si_kill $src",
|
||||
[(int_AMDGPU_kill f32:$src)]
|
||||
>;
|
||||
} // End Uses = [EXEC], Defs = [EXEC,VCC]
|
||||
|
||||
} // end mayLoad = 1, mayStore = 1, hasSideEffects = 1
|
||||
// Uses = [EXEC], Defs = [EXEC]
|
||||
|
||||
let Uses = [EXEC], Defs = [EXEC,VCC,M0] in {
|
||||
|
||||
|
@ -16,8 +16,24 @@ main_body:
|
||||
ret void
|
||||
}
|
||||
|
||||
; SI-LABEL: {{^}}kill_vcc_implicit_def:
|
||||
; SI-NOT: v_cmp_gt_f32_e32 vcc,
|
||||
; SI: v_cmp_gt_f32_e64 [[CMP:s\[[0-9]+:[0-9]+\]]], 0, v{{[0-9]+}}
|
||||
; SI: v_cmpx_le_f32_e32 vcc, 0, v{{[0-9]+}}
|
||||
; SI: v_cndmask_b32_e64 v{{[0-9]+}}, 0, 1.0, [[CMP]]
|
||||
define void @kill_vcc_implicit_def([6 x <16 x i8>] addrspace(2)* byval, [17 x <16 x i8>] addrspace(2)* byval, [17 x <4 x i32>] addrspace(2)* byval, [34 x <8 x i32>] addrspace(2)* byval, float inreg, i32 inreg, <2 x i32>, <2 x i32>, <2 x i32>, <3 x i32>, <2 x i32>, <2 x i32>, <2 x i32>, float, float, float, float, float, float, i32, float, float) #1 {
|
||||
entry:
|
||||
%tmp0 = fcmp olt float %13, 0.0
|
||||
call void @llvm.AMDGPU.kill(float %14)
|
||||
%tmp1 = select i1 %tmp0, float 1.0, float 0.0
|
||||
call void @llvm.SI.export(i32 15, i32 1, i32 1, i32 1, i32 1, float %tmp1, float %tmp1, float %tmp1, float %tmp1)
|
||||
ret void
|
||||
}
|
||||
|
||||
declare void @llvm.AMDGPU.kill(float)
|
||||
declare void @llvm.SI.export(i32, i32, i32, i32, i32, float, float, float, float)
|
||||
|
||||
attributes #0 = { "ShaderType"="2" }
|
||||
attributes #1 = { "ShaderType"="0" }
|
||||
|
||||
!0 = !{!"const", null, i32 1}
|
||||
|
Loading…
Reference in New Issue
Block a user