i965/vec4: fix move_uniform_array_access_to_pull_constant() for 64-bit data
authorIago Toral Quiroga <itoral@igalia.com>
Wed, 29 Jun 2016 06:41:11 +0000 (08:41 +0200)
committerSamuel Iglesias Gonsálvez <siglesias@igalia.com>
Tue, 3 Jan 2017 10:26:51 +0000 (11:26 +0100)
v2: adapt to changes in offset()

Reviewed-by: Matt Turner <mattst88@gmail.com>
src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp

index 2d0822b5a5a94611c350b4b8081728f4dbe5a8ba..9d7afb56f2d6872666a3836c7564ab4d9ce7765c 100644 (file)
@@ -1801,8 +1801,24 @@ vec4_visitor::move_uniform_array_access_to_pull_constants()
 
       assert(inst->src[0].swizzle == BRW_SWIZZLE_NOOP);
 
-      emit_pull_constant_load(block, inst, inst->dst, inst->src[0],
-                              pull_constant_loc[uniform_nr], inst->src[1]);
+      if (type_sz(inst->src[0].type) != 8) {
+         emit_pull_constant_load(block, inst, inst->dst, inst->src[0],
+                                 pull_constant_loc[uniform_nr], inst->src[1]);
+      } else {
+         dst_reg shuffled = dst_reg(this, glsl_type::dvec4_type);
+         dst_reg shuffled_float = retype(shuffled, BRW_REGISTER_TYPE_F);
+
+         emit_pull_constant_load(block, inst, shuffled_float, inst->src[0],
+                                 pull_constant_loc[uniform_nr], inst->src[1]);
+         emit_pull_constant_load(block, inst,
+                                 offset(shuffled_float, 8, 1),
+                                 offset(inst->src[0], 8, 1),
+                                 pull_constant_loc[uniform_nr], inst->src[1]);
+
+         shuffle_64bit_data(retype(inst->dst, BRW_REGISTER_TYPE_DF),
+                            src_reg(shuffled), false, block, inst);
+      }
+
       inst->remove(block);
    }