mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-07 13:38:06 +02:00
st/glsl_to_tgsi: fix block copies of arrays of structs
Use a full writemask in this case. This is relevant e.g. when a function
has an inout argument which is an array of structs.
v2: use C-style comment (Timothy Arceri)
Reviewed-by: Marek Olšák <marek.olsak@amd.com> (v1)
Cc: 13.0 <mesa-stable@lists.freedesktop.org>
(cherry picked from commit a1895685f8)
This commit is contained in:
parent
3581e21d5b
commit
8f807e914f
1 changed files with 4 additions and 2 deletions
|
|
@ -2941,10 +2941,12 @@ glsl_to_tgsi_visitor::visit(ir_assignment *ir)
|
|||
} else if (ir->write_mask == 0) {
|
||||
assert(!ir->lhs->type->is_scalar() && !ir->lhs->type->is_vector());
|
||||
|
||||
if (ir->lhs->type->is_array() || ir->lhs->type->is_matrix()) {
|
||||
unsigned num_elements = ir->lhs->type->without_array()->vector_elements;
|
||||
unsigned num_elements = ir->lhs->type->without_array()->vector_elements;
|
||||
|
||||
if (num_elements) {
|
||||
l.writemask = u_bit_consecutive(0, num_elements);
|
||||
} else {
|
||||
/* The type is a struct or an array of (array of) structs. */
|
||||
l.writemask = WRITEMASK_XYZW;
|
||||
}
|
||||
} else {
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue