mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2024-11-21 16:46:41 -08:00
vkd3d-shader: Introduce struct vkd3d_shader_scan_descriptor_info1.
This commit is contained in:
parent
fd4a820c4b
commit
4e9798f6f7
Notes:
Alexandre Julliard
2023-08-14 21:00:15 +02:00
Approved-by: Henri Verbeet (@hverbeet) Approved-by: Alexandre Julliard (@julliard) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/295
@ -2310,7 +2310,7 @@ struct spirv_compiler
|
||||
|
||||
uint32_t binding_idx;
|
||||
|
||||
const struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info;
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info;
|
||||
unsigned int input_control_point_count;
|
||||
unsigned int output_control_point_count;
|
||||
bool use_vocp;
|
||||
@ -2380,7 +2380,7 @@ static void spirv_compiler_destroy(struct spirv_compiler *compiler)
|
||||
|
||||
static struct spirv_compiler *spirv_compiler_create(const struct vkd3d_shader_version *shader_version,
|
||||
struct vkd3d_shader_desc *shader_desc, const struct vkd3d_shader_compile_info *compile_info,
|
||||
const struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info,
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info,
|
||||
struct vkd3d_shader_message_context *message_context, const struct vkd3d_shader_location *location)
|
||||
{
|
||||
const struct shader_signature *patch_constant_signature = &shader_desc->patch_constant_signature;
|
||||
@ -5695,13 +5695,13 @@ static SpvImageFormat image_format_for_image_read(enum vkd3d_shader_component_ty
|
||||
}
|
||||
}
|
||||
|
||||
static const struct vkd3d_shader_descriptor_info *spirv_compiler_get_descriptor_info(
|
||||
static const struct vkd3d_shader_descriptor_info1 *spirv_compiler_get_descriptor_info(
|
||||
struct spirv_compiler *compiler, enum vkd3d_shader_descriptor_type type,
|
||||
const struct vkd3d_shader_register_range *range)
|
||||
{
|
||||
const struct vkd3d_shader_scan_descriptor_info *descriptor_info = compiler->scan_descriptor_info;
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *descriptor_info = compiler->scan_descriptor_info;
|
||||
unsigned int register_last = (range->last == ~0u) ? range->first : range->last;
|
||||
const struct vkd3d_shader_descriptor_info *d;
|
||||
const struct vkd3d_shader_descriptor_info1 *d;
|
||||
unsigned int i;
|
||||
|
||||
for (i = 0; i < descriptor_info->descriptor_count; ++i)
|
||||
@ -5721,7 +5721,7 @@ static uint32_t spirv_compiler_get_image_type_id(struct spirv_compiler *compiler
|
||||
bool raw_structured, uint32_t depth)
|
||||
{
|
||||
struct vkd3d_spirv_builder *builder = &compiler->spirv_builder;
|
||||
const struct vkd3d_shader_descriptor_info *d;
|
||||
const struct vkd3d_shader_descriptor_info1 *d;
|
||||
bool uav_read, uav_atomics;
|
||||
uint32_t sampled_type_id;
|
||||
SpvImageFormat format;
|
||||
@ -5756,7 +5756,7 @@ static void spirv_compiler_emit_combined_sampler_declarations(struct spirv_compi
|
||||
const struct vkd3d_shader_combined_resource_sampler *current;
|
||||
uint32_t image_type_id, type_id, ptr_type_id, var_id;
|
||||
enum vkd3d_shader_binding_flag resource_type_flag;
|
||||
const struct vkd3d_shader_descriptor_info *d;
|
||||
const struct vkd3d_shader_descriptor_info1 *d;
|
||||
struct vkd3d_symbol symbol;
|
||||
unsigned int i;
|
||||
bool depth;
|
||||
@ -5889,7 +5889,7 @@ static void spirv_compiler_emit_resource_declaration(struct spirv_compiler *comp
|
||||
|
||||
if (is_uav)
|
||||
{
|
||||
const struct vkd3d_shader_descriptor_info *d;
|
||||
const struct vkd3d_shader_descriptor_info1 *d;
|
||||
|
||||
d = spirv_compiler_get_descriptor_info(compiler,
|
||||
VKD3D_SHADER_DESCRIPTOR_TYPE_UAV, &resource->range);
|
||||
@ -9635,7 +9635,7 @@ static int spirv_compiler_generate_spirv(struct spirv_compiler *compiler,
|
||||
}
|
||||
|
||||
int spirv_compile(struct vkd3d_shader_parser *parser,
|
||||
const struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info,
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info,
|
||||
const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_code *out, struct vkd3d_shader_message_context *message_context)
|
||||
{
|
||||
|
@ -579,7 +579,7 @@ static bool vkd3d_shader_signature_from_shader_signature(struct vkd3d_shader_sig
|
||||
|
||||
struct vkd3d_shader_scan_context
|
||||
{
|
||||
struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info;
|
||||
struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info;
|
||||
size_t descriptors_size;
|
||||
|
||||
struct vkd3d_shader_message_context *message_context;
|
||||
@ -612,7 +612,7 @@ struct vkd3d_shader_scan_context
|
||||
|
||||
static void vkd3d_shader_scan_context_init(struct vkd3d_shader_scan_context *context,
|
||||
const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info,
|
||||
struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info,
|
||||
struct vkd3d_shader_message_context *message_context)
|
||||
{
|
||||
unsigned int i;
|
||||
@ -769,8 +769,8 @@ static bool vkd3d_shader_scan_add_descriptor(struct vkd3d_shader_scan_context *c
|
||||
enum vkd3d_shader_resource_type resource_type, enum vkd3d_shader_resource_data_type resource_data_type,
|
||||
unsigned int flags)
|
||||
{
|
||||
struct vkd3d_shader_scan_descriptor_info *info = context->scan_descriptor_info;
|
||||
struct vkd3d_shader_descriptor_info *d;
|
||||
struct vkd3d_shader_scan_descriptor_info1 *info = context->scan_descriptor_info;
|
||||
struct vkd3d_shader_descriptor_info1 *d;
|
||||
|
||||
if (!vkd3d_array_reserve((void **)&info->descriptors, &context->descriptors_size,
|
||||
info->descriptor_count + 1, sizeof(*info->descriptors)))
|
||||
@ -1104,24 +1104,64 @@ static int vkd3d_shader_scan_instruction(struct vkd3d_shader_scan_context *conte
|
||||
return VKD3D_OK;
|
||||
}
|
||||
|
||||
static int scan_with_parser(const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_message_context *message_context, struct vkd3d_shader_parser *parser)
|
||||
static enum vkd3d_result convert_descriptor_info(struct vkd3d_shader_scan_descriptor_info *info,
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *info1)
|
||||
{
|
||||
struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info;
|
||||
unsigned int i;
|
||||
|
||||
if (!(info->descriptors = vkd3d_calloc(info1->descriptor_count, sizeof(*info->descriptors))))
|
||||
return VKD3D_ERROR_OUT_OF_MEMORY;
|
||||
|
||||
for (i = 0; i < info1->descriptor_count; ++i)
|
||||
{
|
||||
const struct vkd3d_shader_descriptor_info1 *src = &info1->descriptors[i];
|
||||
struct vkd3d_shader_descriptor_info *dst = &info->descriptors[i];
|
||||
|
||||
dst->type = src->type;
|
||||
dst->register_space = src->register_space;
|
||||
dst->register_index = src->register_index;
|
||||
dst->resource_type = src->resource_type;
|
||||
dst->resource_data_type = src->resource_data_type;
|
||||
dst->flags = src->flags;
|
||||
dst->count = src->count;
|
||||
}
|
||||
info->descriptor_count = info1->descriptor_count;
|
||||
|
||||
return VKD3D_OK;
|
||||
}
|
||||
|
||||
static void vkd3d_shader_free_scan_descriptor_info1(struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info)
|
||||
{
|
||||
TRACE("scan_descriptor_info %p.\n", scan_descriptor_info);
|
||||
|
||||
vkd3d_free(scan_descriptor_info->descriptors);
|
||||
}
|
||||
|
||||
static int scan_with_parser(const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_message_context *message_context,
|
||||
struct vkd3d_shader_scan_descriptor_info1 *descriptor_info1, struct vkd3d_shader_parser *parser)
|
||||
{
|
||||
struct vkd3d_shader_scan_descriptor_info1 local_descriptor_info1 = {0};
|
||||
struct vkd3d_shader_scan_descriptor_info *descriptor_info;
|
||||
struct vkd3d_shader_scan_signature_info *signature_info;
|
||||
struct vkd3d_shader_instruction *instruction;
|
||||
struct vkd3d_shader_scan_context context;
|
||||
int ret = VKD3D_OK;
|
||||
unsigned int i;
|
||||
|
||||
if ((scan_descriptor_info = vkd3d_find_struct(compile_info->next, SCAN_DESCRIPTOR_INFO)))
|
||||
descriptor_info = vkd3d_find_struct(compile_info->next, SCAN_DESCRIPTOR_INFO);
|
||||
if (descriptor_info1)
|
||||
{
|
||||
scan_descriptor_info->descriptors = NULL;
|
||||
scan_descriptor_info->descriptor_count = 0;
|
||||
descriptor_info1->descriptors = NULL;
|
||||
descriptor_info1->descriptor_count = 0;
|
||||
}
|
||||
else if (descriptor_info)
|
||||
{
|
||||
descriptor_info1 = &local_descriptor_info1;
|
||||
}
|
||||
signature_info = vkd3d_find_struct(compile_info->next, SCAN_SIGNATURE_INFO);
|
||||
|
||||
vkd3d_shader_scan_context_init(&context, compile_info, scan_descriptor_info, message_context);
|
||||
vkd3d_shader_scan_context_init(&context, compile_info, descriptor_info1, message_context);
|
||||
|
||||
if (TRACE_ON())
|
||||
{
|
||||
@ -1156,13 +1196,22 @@ static int scan_with_parser(const struct vkd3d_shader_compile_info *compile_info
|
||||
}
|
||||
}
|
||||
|
||||
if (!ret && descriptor_info)
|
||||
ret = convert_descriptor_info(descriptor_info, descriptor_info1);
|
||||
|
||||
if (ret < 0)
|
||||
{
|
||||
if (scan_descriptor_info)
|
||||
vkd3d_shader_free_scan_descriptor_info(scan_descriptor_info);
|
||||
if (descriptor_info)
|
||||
vkd3d_shader_free_scan_descriptor_info(descriptor_info);
|
||||
if (descriptor_info1)
|
||||
vkd3d_shader_free_scan_descriptor_info1(descriptor_info1);
|
||||
if (signature_info)
|
||||
vkd3d_shader_free_scan_signature_info(signature_info);
|
||||
}
|
||||
else
|
||||
{
|
||||
vkd3d_shader_free_scan_descriptor_info1(&local_descriptor_info1);
|
||||
}
|
||||
vkd3d_shader_scan_context_cleanup(&context);
|
||||
return ret;
|
||||
}
|
||||
@ -1179,7 +1228,7 @@ static int scan_dxbc(const struct vkd3d_shader_compile_info *compile_info,
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = scan_with_parser(compile_info, message_context, parser);
|
||||
ret = scan_with_parser(compile_info, message_context, NULL, parser);
|
||||
vkd3d_shader_parser_destroy(parser);
|
||||
|
||||
return ret;
|
||||
@ -1197,7 +1246,7 @@ static int scan_d3dbc(const struct vkd3d_shader_compile_info *compile_info,
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = scan_with_parser(compile_info, message_context, parser);
|
||||
ret = scan_with_parser(compile_info, message_context, NULL, parser);
|
||||
vkd3d_shader_parser_destroy(parser);
|
||||
|
||||
return ret;
|
||||
@ -1215,7 +1264,7 @@ static int scan_dxil(const struct vkd3d_shader_compile_info *compile_info,
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = scan_with_parser(compile_info, message_context, parser);
|
||||
ret = scan_with_parser(compile_info, message_context, NULL, parser);
|
||||
vkd3d_shader_parser_destroy(parser);
|
||||
|
||||
return ret;
|
||||
@ -1274,7 +1323,7 @@ static int vkd3d_shader_parser_compile(struct vkd3d_shader_parser *parser,
|
||||
const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_code *out, struct vkd3d_shader_message_context *message_context)
|
||||
{
|
||||
struct vkd3d_shader_scan_descriptor_info scan_descriptor_info;
|
||||
struct vkd3d_shader_scan_descriptor_info1 scan_descriptor_info;
|
||||
struct vkd3d_glsl_generator *glsl_generator;
|
||||
struct vkd3d_shader_compile_info scan_info;
|
||||
int ret;
|
||||
@ -1282,11 +1331,8 @@ static int vkd3d_shader_parser_compile(struct vkd3d_shader_parser *parser,
|
||||
vkd3d_shader_dump_shader(compile_info->source_type, parser->shader_version.type, &compile_info->source);
|
||||
|
||||
scan_info = *compile_info;
|
||||
scan_descriptor_info.type = VKD3D_SHADER_STRUCTURE_TYPE_SCAN_DESCRIPTOR_INFO;
|
||||
scan_descriptor_info.next = scan_info.next;
|
||||
scan_info.next = &scan_descriptor_info;
|
||||
|
||||
if ((ret = scan_with_parser(&scan_info, message_context, parser)) < 0)
|
||||
if ((ret = scan_with_parser(&scan_info, message_context, &scan_descriptor_info, parser)) < 0)
|
||||
return ret;
|
||||
|
||||
switch (compile_info->target_type)
|
||||
@ -1300,7 +1346,7 @@ static int vkd3d_shader_parser_compile(struct vkd3d_shader_parser *parser,
|
||||
message_context, &parser->location)))
|
||||
{
|
||||
ERR("Failed to create GLSL generator.\n");
|
||||
vkd3d_shader_free_scan_descriptor_info(&scan_descriptor_info);
|
||||
vkd3d_shader_free_scan_descriptor_info1(&scan_descriptor_info);
|
||||
return VKD3D_ERROR;
|
||||
}
|
||||
|
||||
@ -1318,7 +1364,7 @@ static int vkd3d_shader_parser_compile(struct vkd3d_shader_parser *parser,
|
||||
assert(0);
|
||||
}
|
||||
|
||||
vkd3d_shader_free_scan_descriptor_info(&scan_descriptor_info);
|
||||
vkd3d_shader_free_scan_descriptor_info1(&scan_descriptor_info);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -1110,6 +1110,23 @@ static inline void vkd3d_shader_parser_destroy(struct vkd3d_shader_parser *parse
|
||||
parser->ops->parser_destroy(parser);
|
||||
}
|
||||
|
||||
struct vkd3d_shader_descriptor_info1
|
||||
{
|
||||
enum vkd3d_shader_descriptor_type type;
|
||||
unsigned int register_space;
|
||||
unsigned int register_index;
|
||||
enum vkd3d_shader_resource_type resource_type;
|
||||
enum vkd3d_shader_resource_data_type resource_data_type;
|
||||
unsigned int flags;
|
||||
unsigned int count;
|
||||
};
|
||||
|
||||
struct vkd3d_shader_scan_descriptor_info1
|
||||
{
|
||||
struct vkd3d_shader_descriptor_info1 *descriptors;
|
||||
unsigned int descriptor_count;
|
||||
};
|
||||
|
||||
void vkd3d_shader_trace(const struct vkd3d_shader_instruction_array *instructions,
|
||||
const struct vkd3d_shader_version *shader_version);
|
||||
|
||||
@ -1232,7 +1249,7 @@ void vkd3d_glsl_generator_destroy(struct vkd3d_glsl_generator *generator);
|
||||
#define SPIRV_MAX_SRC_COUNT 6
|
||||
|
||||
int spirv_compile(struct vkd3d_shader_parser *parser,
|
||||
const struct vkd3d_shader_scan_descriptor_info *scan_descriptor_info,
|
||||
const struct vkd3d_shader_scan_descriptor_info1 *scan_descriptor_info,
|
||||
const struct vkd3d_shader_compile_info *compile_info,
|
||||
struct vkd3d_shader_code *out, struct vkd3d_shader_message_context *message_context);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user