mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2025-12-15 08:03:30 -08:00
vkd3d-shader/msl: Implement VKD3DSPR_THREADID.
This commit is contained in:
committed by
Henri Verbeet
parent
6ecfcf1910
commit
ad8e41f8f2
Notes:
Henri Verbeet
2025-09-30 17:25:50 +02:00
Approved-by: Henri Verbeet (@hverbeet) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/1756
@@ -486,6 +486,10 @@ static enum msl_data_type msl_print_register_name(struct vkd3d_string_buffer *bu
|
|||||||
vkd3d_string_buffer_printf(buffer, "o_mask");
|
vkd3d_string_buffer_printf(buffer, "o_mask");
|
||||||
return MSL_DATA_UNION;
|
return MSL_DATA_UNION;
|
||||||
|
|
||||||
|
case VKD3DSPR_THREADID:
|
||||||
|
vkd3d_string_buffer_printf(buffer, "v_thread_id");
|
||||||
|
return MSL_DATA_UNION;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
msl_compiler_error(gen, VKD3D_SHADER_ERROR_MSL_INTERNAL,
|
msl_compiler_error(gen, VKD3D_SHADER_ERROR_MSL_INTERNAL,
|
||||||
"Internal compiler error: Unhandled register type %#x.", reg->type);
|
"Internal compiler error: Unhandled register type %#x.", reg->type);
|
||||||
@@ -1997,6 +2001,12 @@ static void msl_generate_entrypoint_prologue(struct msl_generator *gen)
|
|||||||
msl_print_write_mask(buffer, e->mask);
|
msl_print_write_mask(buffer, e->mask);
|
||||||
vkd3d_string_buffer_printf(buffer, ";\n");
|
vkd3d_string_buffer_printf(buffer, ";\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_THREADID))
|
||||||
|
{
|
||||||
|
msl_print_indent(gen->buffer, 1);
|
||||||
|
vkd3d_string_buffer_printf(buffer, "v_thread_id.u = uint4(thread_id, 0u);\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void msl_generate_entrypoint_epilogue(struct msl_generator *gen)
|
static void msl_generate_entrypoint_epilogue(struct msl_generator *gen)
|
||||||
@@ -2083,6 +2093,12 @@ static void msl_generate_entrypoint(struct msl_generator *gen)
|
|||||||
vkd3d_string_buffer_printf(gen->buffer, "uint vertex_id [[vertex_id]],\n");
|
vkd3d_string_buffer_printf(gen->buffer, "uint vertex_id [[vertex_id]],\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_THREADID))
|
||||||
|
{
|
||||||
|
msl_print_indent(gen->buffer, 2);
|
||||||
|
vkd3d_string_buffer_printf(gen->buffer, "uint3 thread_id [[thread_position_in_grid]],\n");
|
||||||
|
}
|
||||||
|
|
||||||
msl_print_indent(gen->buffer, 2);
|
msl_print_indent(gen->buffer, 2);
|
||||||
vkd3d_string_buffer_printf(gen->buffer, "vkd3d_%s_in input [[stage_in]])\n{\n", gen->prefix);
|
vkd3d_string_buffer_printf(gen->buffer, "vkd3d_%s_in input [[stage_in]])\n{\n", gen->prefix);
|
||||||
|
|
||||||
@@ -2092,6 +2108,8 @@ static void msl_generate_entrypoint(struct msl_generator *gen)
|
|||||||
vkd3d_string_buffer_printf(gen->buffer, " vkd3d_%s_out output;\n", gen->prefix);
|
vkd3d_string_buffer_printf(gen->buffer, " vkd3d_%s_out output;\n", gen->prefix);
|
||||||
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
||||||
vkd3d_string_buffer_printf(gen->buffer, " vkd3d_scalar o_mask;\n");
|
vkd3d_string_buffer_printf(gen->buffer, " vkd3d_scalar o_mask;\n");
|
||||||
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_THREADID))
|
||||||
|
vkd3d_string_buffer_printf(gen->buffer, " vkd3d_vec4 v_thread_id;\n");
|
||||||
vkd3d_string_buffer_printf(gen->buffer, "\n");
|
vkd3d_string_buffer_printf(gen->buffer, "\n");
|
||||||
|
|
||||||
msl_generate_entrypoint_prologue(gen);
|
msl_generate_entrypoint_prologue(gen);
|
||||||
@@ -2103,6 +2121,8 @@ static void msl_generate_entrypoint(struct msl_generator *gen)
|
|||||||
vkd3d_string_buffer_printf(gen->buffer, ", output.shader_out_depth");
|
vkd3d_string_buffer_printf(gen->buffer, ", output.shader_out_depth");
|
||||||
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ", o_mask");
|
vkd3d_string_buffer_printf(gen->buffer, ", o_mask");
|
||||||
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_THREADID))
|
||||||
|
vkd3d_string_buffer_printf(gen->buffer, ", v_thread_id");
|
||||||
if (gen->program->descriptors.descriptor_count)
|
if (gen->program->descriptors.descriptor_count)
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ", descriptors");
|
vkd3d_string_buffer_printf(gen->buffer, ", descriptors");
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ");\n\n");
|
vkd3d_string_buffer_printf(gen->buffer, ");\n\n");
|
||||||
@@ -2176,6 +2196,8 @@ static int msl_generator_generate(struct msl_generator *gen, struct vkd3d_shader
|
|||||||
vkd3d_string_buffer_printf(gen->buffer, ", thread float &o_depth");
|
vkd3d_string_buffer_printf(gen->buffer, ", thread float &o_depth");
|
||||||
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_SAMPLEMASK))
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ", thread vkd3d_scalar &o_mask");
|
vkd3d_string_buffer_printf(gen->buffer, ", thread vkd3d_scalar &o_mask");
|
||||||
|
if (bitmap_is_set(gen->program->io_dcls, VKD3DSPR_THREADID))
|
||||||
|
vkd3d_string_buffer_printf(gen->buffer, ", thread vkd3d_vec4 &v_thread_id");
|
||||||
if (gen->program->descriptors.descriptor_count)
|
if (gen->program->descriptors.descriptor_count)
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ", constant descriptor *descriptors");
|
vkd3d_string_buffer_printf(gen->buffer, ", constant descriptor *descriptors");
|
||||||
vkd3d_string_buffer_printf(gen->buffer, ")\n{\n");
|
vkd3d_string_buffer_printf(gen->buffer, ")\n{\n");
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ void main(uint3 thread_id : SV_DispatchThreadId)
|
|||||||
}
|
}
|
||||||
|
|
||||||
[test]
|
[test]
|
||||||
todo(msl) dispatch 13 13 1
|
dispatch 13 13 1
|
||||||
probe uav 0 (0, 0) u32(0, 0, 0, 1)
|
probe uav 0 (0, 0) u32(0, 0, 0, 1)
|
||||||
probe uav 0 (14, 38) u32(14, 38, 0, 1)
|
probe uav 0 (14, 38) u32(14, 38, 0, 1)
|
||||||
probe uav 0 (49, 49) u32(49, 49, 0, 1)
|
probe uav 0 (49, 49) u32(49, 49, 0, 1)
|
||||||
|
|||||||
@@ -219,7 +219,7 @@ void main(uint2 id : sv_dispatchthreadid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
[test]
|
[test]
|
||||||
todo(msl) dispatch 1 1 1
|
dispatch 1 1 1
|
||||||
probe uav 0 (0, 0) f32(2.0)
|
probe uav 0 (0, 0) f32(2.0)
|
||||||
if(sm<6) probe uav 0 (0, 1) f32(1.0)
|
if(sm<6) probe uav 0 (0, 1) f32(1.0)
|
||||||
if(sm<6) probe uav 0 (1, 0) f32(2.0)
|
if(sm<6) probe uav 0 (1, 0) f32(2.0)
|
||||||
|
|||||||
Reference in New Issue
Block a user