diff options
Diffstat (limited to 'src/panfrost')
-rw-r--r-- | src/panfrost/midgard/midgard_schedule.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/panfrost/midgard/midgard_schedule.c b/src/panfrost/midgard/midgard_schedule.c index 18c36a8d290..a365cfaf09e 100644 --- a/src/panfrost/midgard/midgard_schedule.c +++ b/src/panfrost/midgard/midgard_schedule.c @@ -456,9 +456,18 @@ mir_adjust_constants(midgard_instruction *ins, if (ins->src[src] != SSA_FIXED_REGISTER(REGISTER_CONSTANT)) continue; - if (!mir_adjust_constant(ins, src, &bundle_constant_mask, + /* First, try lower half (or whole for !16) */ + if (mir_adjust_constant(ins, src, &bundle_constant_mask, comp_mapping[src], bundle_constants, false)) - return false; + continue; + + /* Next, try upper half */ + if (mir_adjust_constant(ins, src, &bundle_constant_mask, + comp_mapping[src], bundle_constants, true)) + continue; + + /* Otherwise bail */ + return false; } /* If non-destructive, we're done */ |