i965/vs: Always store pull constant offsets in GRFs on Gen8.
We need to SEND from a GRF, and we can only obtain those prior to register allocation. This allows us to do pull constant loads without the MRF hack. v2: Reword comments (suggested by Paul). Signed-off-by: Kenneth Graunke <kenneth@whitecape.org> Reviewed-by: Paul Berry <stereotype441@gmail.com>
This commit is contained in:
parent
dd159f25e4
commit
93658054c0
|
@ -1581,7 +1581,16 @@ vec4_visitor::visit(ir_expression *ir)
|
|||
src_reg surf_index =
|
||||
src_reg(prog_data->base.binding_table.ubo_start + uniform_block->value.u[0]);
|
||||
if (const_offset_ir) {
|
||||
offset = src_reg(const_offset / 16);
|
||||
if (brw->gen >= 8) {
|
||||
/* Store the offset in a GRF so we can send-from-GRF. */
|
||||
offset = src_reg(this, glsl_type::int_type);
|
||||
emit(MOV(dst_reg(offset), src_reg(const_offset / 16)));
|
||||
} else {
|
||||
/* Immediates are fine on older generations since they'll be moved
|
||||
* to a (potentially fake) MRF at the generator level.
|
||||
*/
|
||||
offset = src_reg(const_offset / 16);
|
||||
}
|
||||
} else {
|
||||
offset = src_reg(this, glsl_type::uint_type);
|
||||
emit(SHR(dst_reg(offset), op[1], src_reg(4)));
|
||||
|
@ -2982,6 +2991,11 @@ vec4_visitor::get_pull_constant_offset(vec4_instruction *inst,
|
|||
}
|
||||
|
||||
return index;
|
||||
} else if (brw->gen >= 8) {
|
||||
/* Store the offset in a GRF so we can send-from-GRF. */
|
||||
src_reg offset = src_reg(this, glsl_type::int_type);
|
||||
emit_before(inst, MOV(dst_reg(offset), src_reg(reg_offset)));
|
||||
return offset;
|
||||
} else {
|
||||
int message_header_scale = brw->gen < 6 ? 16 : 1;
|
||||
return src_reg(reg_offset * message_header_scale);
|
||||
|
|
Loading…
Reference in New Issue