vkd3d-shader/fx: Do not print padding bytes of fx_2_0 strings.

This commit is contained in:
Nikolay Sivov
2025-06-07 10:42:49 +02:00
committed by Henri Verbeet
parent 8aacee8eae
commit b22ebe73bc
Notes: Henri Verbeet 2025-06-10 18:05:49 +02:00
Approved-by: Henri Verbeet (@hverbeet)
Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/1541

View File

@@ -289,15 +289,6 @@ static void set_status(struct fx_write_context *fx, int status)
fx->status = status; fx->status = status;
} }
static void fx_print_string(struct vkd3d_string_buffer *buffer, const char *prefix,
const char *s, size_t len)
{
if (len)
--len; /* Trim terminating null. */
vkd3d_string_buffer_printf(buffer, "%s", prefix);
vkd3d_string_buffer_print_string_escaped(buffer, s, len);
}
static uint32_t write_string(const char *string, struct fx_write_context *fx) static uint32_t write_string(const char *string, struct fx_write_context *fx)
{ {
return fx->ops->write_string(string, fx); return fx->ops->write_string(string, fx);
@@ -3648,20 +3639,43 @@ static void parse_fx_print_indent(struct fx_parser *parser)
vkd3d_string_buffer_printf(&parser->buffer, "%*s", 4 * parser->indent, ""); vkd3d_string_buffer_printf(&parser->buffer, "%*s", 4 * parser->indent, "");
} }
static const char *fx_2_get_string(struct fx_parser *parser, uint32_t offset, uint32_t *size) static void fx_2_print_string_literal(struct fx_parser *parser, const char *prefix,
const char *s, uint32_t max_len, const char *suffix)
{ {
const char *ptr; uint32_t len;
fx_parser_read_unstructured(parser, size, offset, sizeof(*size)); if (s)
ptr = fx_parser_get_unstructured_ptr(parser, offset + 4, *size); len = strnlen(s, max_len);
if (!s || len == max_len)
if (!ptr)
{ {
parser->failed = true; fx_parser_error(parser, VKD3D_SHADER_ERROR_FX_INVALID_DATA, "Failed to parse a string entry.");
return "<invalid>"; return;
} }
return ptr; vkd3d_string_buffer_printf(&parser->buffer, "%s", prefix);
vkd3d_string_buffer_print_string_escaped(&parser->buffer, s, len);
vkd3d_string_buffer_printf(&parser->buffer, "%s", suffix);
}
static void fx_2_parse_string_literal(struct fx_parser *parser, uint32_t offset,
bool unstructured, const char *prefix, const char *suffix)
{
uint32_t max_len;
const char *s;
if (unstructured)
{
fx_parser_read_unstructured(parser, &max_len, offset, sizeof(max_len));
s = fx_parser_get_unstructured_ptr(parser, offset + 4, max_len);
}
else
{
max_len = fx_parser_read_u32(parser);
s = fx_parser_get_ptr(parser, max_len);
fx_parser_skip(parser, align(max_len, 4));
}
fx_2_print_string_literal(parser, prefix, s, max_len, suffix);
} }
static unsigned int fx_get_fx_2_type_size(struct fx_parser *parser, uint32_t *offset) static unsigned int fx_get_fx_2_type_size(struct fx_parser *parser, uint32_t *offset)
@@ -3818,15 +3832,12 @@ static void fx_parse_fx_2_parameter(struct fx_parser *parser, uint32_t offset)
uint32_t semantic; uint32_t semantic;
uint32_t element_count; uint32_t element_count;
} var; } var;
const char *name;
uint32_t size;
fx_parser_read_unstructured(parser, &var, offset, sizeof(var)); fx_parser_read_unstructured(parser, &var, offset, sizeof(var));
fx_parse_fx_2_type(parser, offset); fx_parse_fx_2_type(parser, offset);
name = fx_2_get_string(parser, var.name, &size); fx_2_parse_string_literal(parser, var.name, true, " ", "");
fx_print_string(&parser->buffer, " ", name, size);
if (var.element_count) if (var.element_count)
vkd3d_string_buffer_printf(&parser->buffer, "[%u]", var.element_count); vkd3d_string_buffer_printf(&parser->buffer, "[%u]", var.element_count);
} }
@@ -4028,18 +4039,14 @@ static void fx_parse_fx_2_technique(struct fx_parser *parser)
uint32_t annotation_count; uint32_t annotation_count;
uint32_t assignment_count; uint32_t assignment_count;
} pass; } pass;
const char *name;
uint32_t size;
if (parser->failed) if (parser->failed)
return; return;
fx_parser_read_u32s(parser, &technique, sizeof(technique)); fx_parser_read_u32s(parser, &technique, sizeof(technique));
name = fx_2_get_string(parser, technique.name, &size);
parse_fx_print_indent(parser); parse_fx_print_indent(parser);
fx_print_string(&parser->buffer, "technique ", name, size); fx_2_parse_string_literal(parser, technique.name, true, "technique ", "");
fx_parse_fx_2_annotations(parser, technique.annotation_count); fx_parse_fx_2_annotations(parser, technique.annotation_count);
vkd3d_string_buffer_printf(&parser->buffer, "\n"); vkd3d_string_buffer_printf(&parser->buffer, "\n");
@@ -4050,10 +4057,9 @@ static void fx_parse_fx_2_technique(struct fx_parser *parser)
for (uint32_t i = 0; i < technique.pass_count; ++i) for (uint32_t i = 0; i < technique.pass_count; ++i)
{ {
fx_parser_read_u32s(parser, &pass, sizeof(pass)); fx_parser_read_u32s(parser, &pass, sizeof(pass));
name = fx_2_get_string(parser, pass.name, &size);
parse_fx_print_indent(parser); parse_fx_print_indent(parser);
fx_print_string(&parser->buffer, "pass ", name, size); fx_2_parse_string_literal(parser, pass.name, true, "pass ", "");
fx_parse_fx_2_annotations(parser, pass.annotation_count); fx_parse_fx_2_annotations(parser, pass.annotation_count);
vkd3d_string_buffer_printf(&parser->buffer, "\n"); vkd3d_string_buffer_printf(&parser->buffer, "\n");
@@ -4189,8 +4195,7 @@ static void fx_parse_fx_2_data_blob(struct fx_parser *parser)
{ {
parse_fx_start_indent(parser); parse_fx_start_indent(parser);
parse_fx_print_indent(parser); parse_fx_print_indent(parser);
fx_print_string(&parser->buffer, "\"", (const char *)data, size); fx_2_print_string_literal(parser, "\"", (const char *)data, size, "\"");
vkd3d_string_buffer_printf(&parser->buffer, "\"");
parse_fx_end_indent(parser); parse_fx_end_indent(parser);
} }
else if (type == D3DXPT_PIXELSHADER || type == D3DXPT_VERTEXSHADER) else if (type == D3DXPT_PIXELSHADER || type == D3DXPT_VERTEXSHADER)
@@ -4230,20 +4235,16 @@ static void fx_dump_blob(struct fx_parser *parser, const void *blob, uint32_t si
} }
} }
static void fx_parse_fx_2_array_selector(struct fx_parser *parser, uint32_t size) static void fx_parse_fx_2_array_selector(struct fx_parser *parser)
{ {
const uint8_t *end = parser->ptr + size; uint32_t size, blob_size = 0;
uint32_t name_size, blob_size = 0;
const void *blob = NULL; const void *blob = NULL;
const char *name; const uint8_t *end;
name_size = fx_parser_read_u32(parser); size = fx_parser_read_u32(parser);
name = fx_parser_get_ptr(parser, name_size); end = parser->ptr + size;
fx_parser_skip(parser, name_size);
if (!name || (uint8_t *)name >= end) fx_2_parse_string_literal(parser, 0, false, "array \"", "\"\n");
fx_parser_error(parser, VKD3D_SHADER_ERROR_FX_INVALID_DATA,
"Malformed name entry in the array selector.");
if (parser->ptr <= end) if (parser->ptr <= end)
{ {
@@ -4257,11 +4258,6 @@ static void fx_parse_fx_2_array_selector(struct fx_parser *parser, uint32_t size
"Malformed blob entry in the array selector."); "Malformed blob entry in the array selector.");
} }
if (name)
{
fx_print_string(&parser->buffer, "array \"", name, name_size);
vkd3d_string_buffer_printf(&parser->buffer, "\"\n");
}
if (blob) if (blob)
{ {
parse_fx_print_indent(parser); parse_fx_print_indent(parser);
@@ -4296,23 +4292,19 @@ static void fx_parse_fx_2_complex_state(struct fx_parser *parser)
state.technique, state.index, state.state); state.technique, state.index, state.state);
} }
size = fx_parser_read_u32(parser);
parse_fx_print_indent(parser); parse_fx_print_indent(parser);
if (state.assignment_type == FX_2_ASSIGNMENT_PARAMETER) if (state.assignment_type == FX_2_ASSIGNMENT_PARAMETER)
{ {
data = fx_parser_get_ptr(parser, size); fx_2_parse_string_literal(parser, 0, false, "parameter \"", "\"\n");
fx_print_string(&parser->buffer, "parameter \"", data, size);
vkd3d_string_buffer_printf(&parser->buffer, "\"\n");
fx_parser_skip(parser, align(size, 4));
} }
else if (state.assignment_type == FX_2_ASSIGNMENT_ARRAY_SELECTOR) else if (state.assignment_type == FX_2_ASSIGNMENT_ARRAY_SELECTOR)
{ {
fx_parse_fx_2_array_selector(parser, size); fx_parse_fx_2_array_selector(parser);
} }
else else
{ {
size = fx_parser_read_u32(parser);
vkd3d_string_buffer_printf(&parser->buffer, "blob size %u\n", size); vkd3d_string_buffer_printf(&parser->buffer, "blob size %u\n", size);
data = fx_parser_get_ptr(parser, size); data = fx_parser_get_ptr(parser, size);
fx_dump_blob(parser, data, size); fx_dump_blob(parser, data, size);