From ead690a17a99ba54ba87181738eac3a5c5ecd6be Mon Sep 17 00:00:00 2001 From: Giovanni Mascellani Date: Fri, 30 May 2025 13:58:48 +0200 Subject: [PATCH] vkd3d-shader/ir: Validate DADD instructions. --- libs/vkd3d-shader/ir.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/libs/vkd3d-shader/ir.c b/libs/vkd3d-shader/ir.c index dc48a895d..8674146a7 100644 --- a/libs/vkd3d-shader/ir.c +++ b/libs/vkd3d-shader/ir.c @@ -10388,6 +10388,17 @@ static void vsir_validate_elementwise_operation(struct validation_context *ctx, } } +static void vsir_validate_double_elementwise_operation(struct validation_context *ctx, + const struct vkd3d_shader_instruction *instruction) +{ + static const bool types[VKD3D_DATA_COUNT] = + { + [VKD3D_DATA_DOUBLE] = true, + }; + + vsir_validate_elementwise_operation(ctx, instruction, types); +} + static void vsir_validate_float_elementwise_operation(struct validation_context *ctx, const struct vkd3d_shader_instruction *instruction) { @@ -11104,6 +11115,7 @@ static const struct vsir_validator_instruction_desc vsir_validator_instructions[ [VKD3DSIH_ASIN] = {1, 1, vsir_validate_float_elementwise_operation}, [VKD3DSIH_ATAN] = {1, 1, vsir_validate_float_elementwise_operation}, [VKD3DSIH_BRANCH] = {0, ~0u, vsir_validate_branch}, + [VKD3DSIH_DADD] = {1, 2, vsir_validate_double_elementwise_operation}, [VKD3DSIH_HS_CONTROL_POINT_PHASE] = {0, 0, vsir_validate_hull_shader_phase}, [VKD3DSIH_HS_DECLS] = {0, 0, vsir_validate_hull_shader_phase}, [VKD3DSIH_HS_FORK_PHASE] = {0, 0, vsir_validate_hull_shader_phase},