nir: make lower_clamp_color pass work after lower i/o
authorRob Clark <robclark@freedesktop.org>
Sun, 1 May 2016 12:06:34 +0000 (08:06 -0400)
committerRob Clark <robclark@freedesktop.org>
Mon, 2 May 2016 18:25:38 +0000 (14:25 -0400)
Kinda important to work with tgsi_to_nir, which generates nir which
already has i/o lowered.

Signed-off-by: Rob Clark <robclark@freedesktop.org>
src/compiler/nir/nir_lower_clamp_color_outputs.c

index 37c4ff00a3dca3f5ede06dea77839ae997e422f0..68bfbed81aa9025064baa4317950e61b63d09dbd 100644 (file)
@@ -62,14 +62,28 @@ is_color_output(lower_state *state, nir_variable *out)
 static void
 lower_intrinsic(lower_state *state, nir_intrinsic_instr *intr)
 {
-   nir_variable *out;
+   nir_variable *out = NULL;
    nir_builder *b = &state->b;
    nir_ssa_def *s;
 
-   if (intr->intrinsic != nir_intrinsic_store_var)
+   switch (intr->intrinsic) {
+   case nir_intrinsic_store_var:
+      out = intr->variables[0]->var;
+      break;
+   case nir_intrinsic_store_output:
+      /* already had i/o lowered.. lookup the matching output var: */
+      nir_foreach_variable(var, &state->shader->outputs) {
+         int drvloc = var->data.driver_location;
+         if (nir_intrinsic_base(intr) == drvloc) {
+            out = var;
+            break;
+         }
+      }
+      assert(out);
+      break;
+   default:
       return;
-
-   out = intr->variables[0]->var;
+   }
 
    if (out->data.mode != nir_var_shader_out)
       return;