mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2024-11-21 16:46:41 -08:00
vkd3d-shader/spirv: Implement the WAVE_ACTIVE_BIT_* instructions.
This commit is contained in:
parent
af208135f3
commit
fef5760af0
Notes:
Alexandre Julliard
2024-05-06 22:37:06 +02:00
Approved-by: Giovanni Mascellani (@giomasce) Approved-by: Henri Verbeet (@hverbeet) Approved-by: Alexandre Julliard (@julliard) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/827
@ -9816,6 +9816,45 @@ static void spirv_compiler_emit_wave_active_ballot(struct spirv_compiler *compil
|
|||||||
spirv_compiler_emit_store_dst(compiler, dst, val_id);
|
spirv_compiler_emit_store_dst(compiler, dst, val_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static SpvOp map_wave_alu_op(enum vkd3d_shader_opcode handler_idx, bool is_float)
|
||||||
|
{
|
||||||
|
switch (handler_idx)
|
||||||
|
{
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_AND:
|
||||||
|
return SpvOpGroupNonUniformBitwiseAnd;
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_OR:
|
||||||
|
return SpvOpGroupNonUniformBitwiseOr;
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_XOR:
|
||||||
|
return SpvOpGroupNonUniformBitwiseXor;
|
||||||
|
default:
|
||||||
|
vkd3d_unreachable();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void spirv_compiler_emit_wave_alu_op(struct spirv_compiler *compiler,
|
||||||
|
const struct vkd3d_shader_instruction *instruction)
|
||||||
|
{
|
||||||
|
struct vkd3d_spirv_builder *builder = &compiler->spirv_builder;
|
||||||
|
const struct vkd3d_shader_dst_param *dst = instruction->dst;
|
||||||
|
const struct vkd3d_shader_src_param *src = instruction->src;
|
||||||
|
uint32_t type_id, val_id;
|
||||||
|
SpvOp op;
|
||||||
|
|
||||||
|
op = map_wave_alu_op(instruction->handler_idx, data_type_is_floating_point(src->reg.data_type));
|
||||||
|
|
||||||
|
type_id = vkd3d_spirv_get_type_id_for_data_type(builder, dst->reg.data_type,
|
||||||
|
vsir_write_mask_component_count(dst->write_mask));
|
||||||
|
val_id = spirv_compiler_emit_load_src(compiler, &src[0], dst->write_mask);
|
||||||
|
|
||||||
|
vkd3d_spirv_enable_capability(builder, SpvCapabilityGroupNonUniformArithmetic);
|
||||||
|
val_id = vkd3d_spirv_build_op_tr3(builder, &builder->function_stream, op, type_id,
|
||||||
|
vkd3d_spirv_get_op_scope_subgroup(builder),
|
||||||
|
SpvGroupOperationReduce,
|
||||||
|
val_id);
|
||||||
|
|
||||||
|
spirv_compiler_emit_store_dst(compiler, dst, val_id);
|
||||||
|
}
|
||||||
|
|
||||||
/* This function is called after declarations are processed. */
|
/* This function is called after declarations are processed. */
|
||||||
static void spirv_compiler_emit_main_prolog(struct spirv_compiler *compiler)
|
static void spirv_compiler_emit_main_prolog(struct spirv_compiler *compiler)
|
||||||
{
|
{
|
||||||
@ -10168,6 +10207,11 @@ static int spirv_compiler_handle_instruction(struct spirv_compiler *compiler,
|
|||||||
case VKD3DSIH_WAVE_ACTIVE_BALLOT:
|
case VKD3DSIH_WAVE_ACTIVE_BALLOT:
|
||||||
spirv_compiler_emit_wave_active_ballot(compiler, instruction);
|
spirv_compiler_emit_wave_active_ballot(compiler, instruction);
|
||||||
break;
|
break;
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_AND:
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_OR:
|
||||||
|
case VKD3DSIH_WAVE_ACTIVE_BIT_XOR:
|
||||||
|
spirv_compiler_emit_wave_alu_op(compiler, instruction);
|
||||||
|
break;
|
||||||
case VKD3DSIH_DCL:
|
case VKD3DSIH_DCL:
|
||||||
case VKD3DSIH_DCL_HS_MAX_TESSFACTOR:
|
case VKD3DSIH_DCL_HS_MAX_TESSFACTOR:
|
||||||
case VKD3DSIH_DCL_INPUT_CONTROL_POINT_COUNT:
|
case VKD3DSIH_DCL_INPUT_CONTROL_POINT_COUNT:
|
||||||
|
@ -232,7 +232,7 @@ void main(uint id : SV_GroupIndex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
[test]
|
[test]
|
||||||
todo dispatch 4 1 1
|
dispatch 4 1 1
|
||||||
probe uav 1 (0) rui (8)
|
probe uav 1 (0) rui (8)
|
||||||
probe uav 1 (1) rui (8)
|
probe uav 1 (1) rui (8)
|
||||||
probe uav 1 (2) rui (8)
|
probe uav 1 (2) rui (8)
|
||||||
@ -250,7 +250,7 @@ void main(uint id : SV_GroupIndex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
[test]
|
[test]
|
||||||
todo dispatch 4 1 1
|
dispatch 4 1 1
|
||||||
probe uav 1 (0) rui (15)
|
probe uav 1 (0) rui (15)
|
||||||
probe uav 1 (1) rui (15)
|
probe uav 1 (1) rui (15)
|
||||||
probe uav 1 (2) rui (15)
|
probe uav 1 (2) rui (15)
|
||||||
@ -268,7 +268,7 @@ void main(uint id : SV_GroupIndex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
[test]
|
[test]
|
||||||
todo dispatch 4 1 1
|
dispatch 4 1 1
|
||||||
probe uav 1 (0) rui (5)
|
probe uav 1 (0) rui (5)
|
||||||
probe uav 1 (1) rui (5)
|
probe uav 1 (1) rui (5)
|
||||||
probe uav 1 (2) rui (5)
|
probe uav 1 (2) rui (5)
|
||||||
|
Loading…
Reference in New Issue
Block a user