ac/nir: convert several ifs to a switch
authorGrazvydas Ignotas <notasas@gmail.com>
Tue, 6 Jun 2017 22:55:26 +0000 (01:55 +0300)
committerGrazvydas Ignotas <notasas@gmail.com>
Wed, 7 Jun 2017 21:02:26 +0000 (00:02 +0300)
Also solve "outinfo may be used uninitialized" warning by putting in an
unreachable().

Signed-off-by: Grazvydas Ignotas <notasas@gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
src/amd/common/ac_nir_to_llvm.c

index 02281904f80ba336f9fed263d467177cb1cfe3a6..42be6de99c92a50dac273cb9f1f0ea608d330ba4 100644 (file)
@@ -5760,23 +5760,25 @@ ac_nir_eliminate_const_vs_outputs(struct nir_to_llvm_context *ctx)
 {
        struct ac_vs_output_info *outinfo;
 
-       if (ctx->stage == MESA_SHADER_FRAGMENT ||
-           ctx->stage == MESA_SHADER_COMPUTE ||
-           ctx->stage == MESA_SHADER_TESS_CTRL ||
-           ctx->stage == MESA_SHADER_GEOMETRY)
+       switch (ctx->stage) {
+       case MESA_SHADER_FRAGMENT:
+       case MESA_SHADER_COMPUTE:
+       case MESA_SHADER_TESS_CTRL:
+       case MESA_SHADER_GEOMETRY:
                return;
-
-       if (ctx->stage == MESA_SHADER_VERTEX) {
+       case MESA_SHADER_VERTEX:
                if (ctx->options->key.vs.as_ls ||
                    ctx->options->key.vs.as_es)
                        return;
                outinfo = &ctx->shader_info->vs.outinfo;
-       }
-
-       if (ctx->stage == MESA_SHADER_TESS_EVAL) {
+               break;
+       case MESA_SHADER_TESS_EVAL:
                if (ctx->options->key.vs.as_es)
                        return;
                outinfo = &ctx->shader_info->tes.outinfo;
+               break;
+       default:
+               unreachable("Unhandled shader type");
        }
 
        ac_optimize_vs_outputs(&ctx->ac,