diff options
author | Jason Ekstrand <[email protected]> | 2017-05-03 17:40:54 -0700 |
---|---|---|
committer | Jason Ekstrand <[email protected]> | 2017-05-09 15:08:06 -0700 |
commit | 0d5f89cdc376445c46f4aa1ae126286cbaebde2b (patch) | |
tree | 0b43282df7fd51ae678d938772b1a39c9c43e0a5 /src/intel/compiler/brw_vec4_nir.cpp | |
parent | 80aa6e9d325b4784b7391cf24f1b0c291514f37b (diff) |
i965/vec4: Use NIR remapping for VS attributes
The NIR pass already handles remapping system values to attributes for
us so we delete the system value code as part of the conversion.
We also change nir_lower_vs_inputs to take an explicit inputs_read
bitmask and pass in the inputs_read from prog_data instead from pulling
it out of NIR. This is because the version in prog_data may get
EDGEFLAG added to it on some old platforms.
Reviewed-by: Alejandro PiƱeiro <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Diffstat (limited to 'src/intel/compiler/brw_vec4_nir.cpp')
-rw-r--r-- | src/intel/compiler/brw_vec4_nir.cpp | 49 |
1 files changed, 2 insertions, 47 deletions
diff --git a/src/intel/compiler/brw_vec4_nir.cpp b/src/intel/compiler/brw_vec4_nir.cpp index 8424e17e25c..32297b1830d 100644 --- a/src/intel/compiler/brw_vec4_nir.cpp +++ b/src/intel/compiler/brw_vec4_nir.cpp @@ -50,45 +50,6 @@ vec4_visitor::emit_nir_code() void vec4_visitor::nir_setup_system_value_intrinsic(nir_intrinsic_instr *instr) { - dst_reg *reg; - - switch (instr->intrinsic) { - case nir_intrinsic_load_vertex_id: - unreachable("should be lowered by lower_vertex_id()."); - - case nir_intrinsic_load_vertex_id_zero_base: - reg = &nir_system_values[SYSTEM_VALUE_VERTEX_ID_ZERO_BASE]; - if (reg->file == BAD_FILE) - *reg = *make_reg_for_system_value(SYSTEM_VALUE_VERTEX_ID_ZERO_BASE); - break; - - case nir_intrinsic_load_base_vertex: - reg = &nir_system_values[SYSTEM_VALUE_BASE_VERTEX]; - if (reg->file == BAD_FILE) - *reg = *make_reg_for_system_value(SYSTEM_VALUE_BASE_VERTEX); - break; - - case nir_intrinsic_load_instance_id: - reg = &nir_system_values[SYSTEM_VALUE_INSTANCE_ID]; - if (reg->file == BAD_FILE) - *reg = *make_reg_for_system_value(SYSTEM_VALUE_INSTANCE_ID); - break; - - case nir_intrinsic_load_base_instance: - reg = &nir_system_values[SYSTEM_VALUE_BASE_INSTANCE]; - if (reg->file == BAD_FILE) - *reg = *make_reg_for_system_value(SYSTEM_VALUE_BASE_INSTANCE); - break; - - case nir_intrinsic_load_draw_id: - reg = &nir_system_values[SYSTEM_VALUE_DRAW_ID]; - if (reg->file == BAD_FILE) - *reg = *make_reg_for_system_value(SYSTEM_VALUE_DRAW_ID); - break; - - default: - break; - } } static bool @@ -826,14 +787,8 @@ vec4_visitor::nir_emit_intrinsic(nir_intrinsic_instr *instr) case nir_intrinsic_load_instance_id: case nir_intrinsic_load_base_instance: case nir_intrinsic_load_draw_id: - case nir_intrinsic_load_invocation_id: { - gl_system_value sv = nir_system_value_from_intrinsic(instr->intrinsic); - src_reg val = src_reg(nir_system_values[sv]); - assert(val.file != BAD_FILE); - dest = get_nir_dest(instr->dest, val.type); - emit(MOV(dest, val)); - break; - } + case nir_intrinsic_load_invocation_id: + unreachable("should be lowered by brw_nir_lower_vs_inputs()"); case nir_intrinsic_load_uniform: { /* Offsets are in bytes but they should always be multiples of 4 */ |