mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2025-04-13 05:43:18 -07:00
vkd3d-shader: Use correct base index for relative addressing of aggregates.
Signed-off-by: Józef Kucia <jkucia@codeweavers.com> Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
committed by
Alexandre Julliard
parent
d300e6f84c
commit
a0069d9fb7
@ -2571,13 +2571,13 @@ static void vkd3d_dxbc_compiler_emit_dereference_register(struct vkd3d_dxbc_comp
|
|||||||
}
|
}
|
||||||
else if (register_info->is_aggregate)
|
else if (register_info->is_aggregate)
|
||||||
{
|
{
|
||||||
|
struct vkd3d_shader_register_index reg_idx = reg->idx[0];
|
||||||
|
|
||||||
if (reg->idx[1].rel_addr)
|
if (reg->idx[1].rel_addr)
|
||||||
FIXME("Relative addressing not implemented.\n");
|
FIXME("Relative addressing not implemented.\n");
|
||||||
|
|
||||||
if (reg->idx[0].rel_addr)
|
reg_idx.offset = register_info->member_idx;
|
||||||
indexes[index_count++] = vkd3d_dxbc_compiler_emit_register_addressing(compiler, ®->idx[0]);
|
indexes[index_count++] = vkd3d_dxbc_compiler_emit_register_addressing(compiler, ®_idx);
|
||||||
else
|
|
||||||
indexes[index_count++] = vkd3d_dxbc_compiler_get_constant_uint(compiler, register_info->member_idx);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user