vkd3d-shader/ir: Refactor register-type-specific code in parameter validation.

To better accommodate code for other register types.
This commit is contained in:
Giovanni Mascellani 2024-01-19 00:02:13 +01:00 committed by Alexandre Julliard
parent fb6409bda1
commit 21633fcc52
Notes: Alexandre Julliard 2024-01-23 23:03:03 +01: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/559

View File

@ -2602,7 +2602,10 @@ static void vsir_validate_dst_param(struct validation_context *ctx,
dst->shift);
}
if (dst->reg.type == VKD3DSPR_SSA && dst->reg.idx[0].offset < ctx->program->ssa_count)
switch (dst->reg.type)
{
case VKD3DSPR_SSA:
if (dst->reg.idx[0].offset < ctx->parser->program.ssa_count)
{
struct validation_context_ssa_data *data = &ctx->ssas[dst->reg.idx[0].offset];
@ -2618,6 +2621,11 @@ static void vsir_validate_dst_param(struct validation_context *ctx,
data->first_assigned);
}
}
break;
default:
break;
}
}
static void vsir_validate_src_param(struct validation_context *ctx,
@ -2637,7 +2645,10 @@ static void vsir_validate_src_param(struct validation_context *ctx,
validator_error(ctx, VKD3D_SHADER_ERROR_VSIR_INVALID_MODIFIERS, "Source has invalid modifiers %#x.",
src->modifiers);
if (src->reg.type == VKD3DSPR_SSA && src->reg.idx[0].offset < ctx->program->ssa_count)
switch (src->reg.type)
{
case VKD3DSPR_SSA:
if (src->reg.idx[0].offset < ctx->parser->program.ssa_count)
{
struct validation_context_ssa_data *data = &ctx->ssas[src->reg.idx[0].offset];
unsigned int i;
@ -2645,6 +2656,11 @@ static void vsir_validate_src_param(struct validation_context *ctx,
for (i = 0; i < VKD3D_VEC4_SIZE; ++i)
data->read_mask |= (1u << vsir_swizzle_get_component(src->swizzle, i));
}
break;
default:
break;
}
}
static void vsir_validate_dst_count(struct validation_context *ctx,