OSDN Git Service

nir/info: Add a few bits of info for fragment shaders
authorJason Ekstrand <jason.ekstrand@intel.com>
Thu, 8 Oct 2015 22:47:09 +0000 (15:47 -0700)
committerJason Ekstrand <jason.ekstrand@intel.com>
Mon, 19 Oct 2015 15:47:03 +0000 (08:47 -0700)
Reviewed-by: Topi Pohjolainen <topi.pohjolainen@intel.com>
src/glsl/nir/glsl_to_nir.cpp
src/glsl/nir/nir.h
src/mesa/program/prog_to_nir.c

index d230ad4..76e1382 100644 (file)
@@ -173,6 +173,16 @@ glsl_to_nir(const struct gl_shader_program *shader_prog,
       shader->info.gs.invocations = sh->Geom.Invocations;
       break;
 
+   case MESA_SHADER_FRAGMENT: {
+      struct gl_fragment_program *fp =
+         (struct gl_fragment_program *)sh->Program;
+
+      shader->info.fs.uses_discard = fp->UsesKill;
+      shader->info.fs.early_fragment_tests = sh->EarlyFragmentTests;
+      shader->info.fs.depth_layout = fp->FragDepthLayout;
+      break;
+   }
+
    case MESA_SHADER_COMPUTE: {
       struct gl_compute_program *cp = (struct gl_compute_program *)sh->Program;
       shader->info.cs.local_size[0] = cp->LocalSize[0];
index 32259e7..2ab48fb 100644 (file)
@@ -1503,6 +1503,19 @@ typedef struct nir_shader_info {
       } gs;
 
       struct {
+         bool uses_discard;
+
+         /**
+          * Whether early fragment tests are enabled as defined by
+          * ARB_shader_image_load_store.
+          */
+         bool early_fragment_tests;
+
+         /** gl_FragDepth layout for ARB_conservative_depth. */
+         enum gl_frag_depth_layout depth_layout;
+      } fs;
+
+      struct {
          unsigned local_size[3];
       } cs;
    };
index da61a2b..539e3c0 100644 (file)
@@ -1129,6 +1129,12 @@ prog_to_nir(const struct gl_program *prog,
    s->info.uses_clip_distance_out = false;
    s->info.separate_shader = false;
 
+   if (stage == MESA_SHADER_FRAGMENT) {
+      struct gl_fragment_program *fp = (struct gl_fragment_program *)prog;
+
+      s->info.fs.uses_discard = fp->UsesKill;
+   }
+
 fail:
    if (c->error) {
       ralloc_free(s);