r600/sfn: Fix dest-swizzle for GS vertex loads
authorGert Wollny <gert.wollny@collabora.com>
Sat, 28 Nov 2020 15:36:04 +0000 (16:36 +0100)
committerMarge Bot <eric+marge@anholt.net>
Mon, 7 Dec 2020 20:24:40 +0000 (20:24 +0000)
Signed-off-by: Gert Wollny <gert.wollny@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7962>

src/gallium/drivers/r600/sfn/sfn_shader_geometry.cpp

index 8fb23fdfbaad933132d82415c35fed8989021fc1..915acadd57f5350c2733a954a2f9ef882ee14957 100644 (file)
@@ -393,7 +393,12 @@ bool GeometryShaderFromNir::emit_vertex(nir_intrinsic_instr* instr, bool cut)
 
 bool GeometryShaderFromNir::emit_load_per_vertex_input(nir_intrinsic_instr* instr)
 {
-   auto dest = vec_from_nir(instr->dest, instr->num_components);
+   auto dest = vec_from_nir(instr->dest, 4);
+
+   std::array<int, 4> swz = {7,7,7,7};
+   for (unsigned i = 0; i < nir_dest_num_components(instr->dest); ++i) {
+      swz[i] = i + nir_intrinsic_component(instr);
+   }
 
    auto literal_index = nir_src_as_const_value(instr->src[0]);
 
@@ -408,6 +413,8 @@ bool GeometryShaderFromNir::emit_load_per_vertex_input(nir_intrinsic_instr* inst
    auto fetch = new FetchInstruction(vc_fetch, no_index_offset, dest, addr,
                                      16 * nir_intrinsic_base(instr),
                                      R600_GS_RING_CONST_BUFFER, PValue(), bim_none, true);
+   fetch->set_dest_swizzle(swz);
+
    emit_instruction(fetch);
    return true;
 }