mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2025-12-15 08:03:30 -08:00
vkd3d-shader/dxil: Allocate instructions directly in sm6_parser_emit_dx_load_input().
This commit is contained in:
committed by
Henri Verbeet
parent
bd06ec9801
commit
47a1d150c3
Notes:
Henri Verbeet
2025-12-11 19:10:50 +01:00
Approved-by: Henri Verbeet (@hverbeet) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/1865
@@ -6136,11 +6136,11 @@ static void sm6_parser_emit_dx_load_input(struct sm6_parser *sm6, enum dx_intrin
|
|||||||
{
|
{
|
||||||
bool is_control_point = op == DX_LOAD_OUTPUT_CONTROL_POINT;
|
bool is_control_point = op == DX_LOAD_OUTPUT_CONTROL_POINT;
|
||||||
bool is_patch_constant = op == DX_LOAD_PATCH_CONSTANT;
|
bool is_patch_constant = op == DX_LOAD_PATCH_CONSTANT;
|
||||||
struct vkd3d_shader_instruction *ins = state->ins;
|
|
||||||
struct vsir_program *program = sm6->program;
|
struct vsir_program *program = sm6->program;
|
||||||
unsigned int count, row_index, column_index;
|
unsigned int count, row_index, column_index;
|
||||||
const struct shader_signature *signature;
|
const struct shader_signature *signature;
|
||||||
const struct vsir_dst_operand *params;
|
const struct vsir_dst_operand *params;
|
||||||
|
struct vkd3d_shader_instruction *ins;
|
||||||
struct vsir_src_operand *src_param;
|
struct vsir_src_operand *src_param;
|
||||||
const struct signature_element *e;
|
const struct signature_element *e;
|
||||||
|
|
||||||
@@ -6148,14 +6148,9 @@ static void sm6_parser_emit_dx_load_input(struct sm6_parser *sm6, enum dx_intrin
|
|||||||
column_index = sm6_value_get_constant_uint(operands[2], sm6);
|
column_index = sm6_value_get_constant_uint(operands[2], sm6);
|
||||||
|
|
||||||
if (is_control_point && operands[3]->value_type == VALUE_TYPE_UNDEFINED)
|
if (is_control_point && operands[3]->value_type == VALUE_TYPE_UNDEFINED)
|
||||||
{
|
|
||||||
/* dxcompiler will compile source which does this, so let it pass. */
|
/* dxcompiler will compile source which does this, so let it pass. */
|
||||||
WARN("Control point id is undefined.\n");
|
|
||||||
vkd3d_shader_parser_warning(&sm6->p, VKD3D_SHADER_WARNING_DXIL_UNDEFINED_OPERAND,
|
vkd3d_shader_parser_warning(&sm6->p, VKD3D_SHADER_WARNING_DXIL_UNDEFINED_OPERAND,
|
||||||
"The index for a control point load is undefined.");
|
"The index for a control point load is undefined.");
|
||||||
}
|
|
||||||
|
|
||||||
vsir_instruction_init(ins, &sm6->p.location, VSIR_OP_MOV);
|
|
||||||
|
|
||||||
if (is_patch_constant)
|
if (is_patch_constant)
|
||||||
{
|
{
|
||||||
@@ -6174,15 +6169,25 @@ static void sm6_parser_emit_dx_load_input(struct sm6_parser *sm6, enum dx_intrin
|
|||||||
}
|
}
|
||||||
if (row_index >= signature->element_count)
|
if (row_index >= signature->element_count)
|
||||||
{
|
{
|
||||||
WARN("Invalid row index %u.\n", row_index);
|
|
||||||
vkd3d_shader_parser_error(&sm6->p, VKD3D_SHADER_ERROR_DXIL_INVALID_OPERAND,
|
vkd3d_shader_parser_error(&sm6->p, VKD3D_SHADER_ERROR_DXIL_INVALID_OPERAND,
|
||||||
"Invalid input row index %u.", row_index);
|
"Invalid input row index %u.", row_index);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
e = &signature->elements[row_index];
|
e = &signature->elements[row_index];
|
||||||
|
|
||||||
if (!(src_param = instruction_src_params_alloc(ins, 1, sm6)))
|
if (!(ins = sm6_parser_add_function_instruction(sm6, state)))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
state->pushed_instruction = true;
|
||||||
|
|
||||||
|
vsir_instruction_init(ins, &sm6->p.location, VSIR_OP_MOV);
|
||||||
|
|
||||||
|
if (!(src_param = instruction_src_params_alloc(ins, 1, sm6)))
|
||||||
|
{
|
||||||
|
vkd3d_shader_instruction_make_nop(ins);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
src_param->reg = params[row_index].reg;
|
src_param->reg = params[row_index].reg;
|
||||||
src_param_init_scalar(src_param, column_index);
|
src_param_init_scalar(src_param, column_index);
|
||||||
count = 0;
|
count = 0;
|
||||||
@@ -6196,7 +6201,8 @@ static void sm6_parser_emit_dx_load_input(struct sm6_parser *sm6, enum dx_intrin
|
|||||||
register_index_address_init(&src_param->reg.idx[count], operands[3], sm6);
|
register_index_address_init(&src_param->reg.idx[count], operands[3], sm6);
|
||||||
}
|
}
|
||||||
|
|
||||||
instruction_dst_param_init_ssa_scalar(ins, 0, sm6);
|
if (!instruction_dst_param_init_ssa_scalar(ins, 0, sm6))
|
||||||
|
vkd3d_shader_instruction_make_nop(ins);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sm6_parser_emit_dx_make_double(struct sm6_parser *sm6, enum dx_intrinsic_opcode op,
|
static void sm6_parser_emit_dx_make_double(struct sm6_parser *sm6, enum dx_intrinsic_opcode op,
|
||||||
|
|||||||
Reference in New Issue
Block a user