i965: Don't try to decode types for non-existent src1.
authorKenneth Graunke <kenneth@whitecape.org>
Sat, 7 Oct 2017 07:14:34 +0000 (00:14 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Tue, 10 Oct 2017 22:11:35 +0000 (15:11 -0700)
KHR-GL45.shader_ballot_tests.ShaderBallotBitmasks has a MOV that hits
this validation path.  MOVs don't have a src1 file, but calling
brw_inst_src1_type() was tripping on src1.file being BRW_IMMEDIATE_VALUE
and the hw_type being something invalid for immediates.

To work around this, just pretend src1 is src0 if there isn't a src1.

Fixes: 2572c2771d0cab0b9bc489d354ede44dfc88547b (i965: Validate "Special
       Requirements for Handling Double Precision Data Types")
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=102680
Reviewed-by: Alejandro PiƱeiro <apinheiro@igalia.com>
src/intel/compiler/brw_eu_validate.c

index 8568f712d77e1d35248f57bc4e2162b215807ac3..9f72c650ddbd67ac6e18675027ddcbe1ff454b17 100644 (file)
@@ -1225,7 +1225,8 @@ special_requirements_for_handling_double_precision_data_types(
     */
    if (devinfo->gen >= 8) {
       enum brw_reg_type src0_type = brw_inst_src0_type(devinfo, inst);
-      enum brw_reg_type src1_type = brw_inst_src1_type(devinfo, inst);
+      enum brw_reg_type src1_type =
+         num_sources > 1 ? brw_inst_src1_type(devinfo, inst) : src0_type;
       unsigned src0_type_size = brw_reg_type_to_size(src0_type);
       unsigned src1_type_size = brw_reg_type_to_size(src1_type);