From: Eric Anholt Date: Wed, 7 Jul 2010 01:31:32 +0000 (-0700) Subject: glsl2: Put the declaration in the instruction stream before its initializer. X-Git-Tag: mesa-7.9-rc1~1173^2~485 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d4d630b72c7b7f38074addda0f1b819608247d93;p=platform%2Fupstream%2Fmesa.git glsl2: Put the declaration in the instruction stream before its initializer. This fixes a regression in the generated code from when I did the ir_validate.cpp-driven rework of assignments. --- diff --git a/src/glsl/ast_to_hir.cpp b/src/glsl/ast_to_hir.cpp index f5e93b0..3de754f 100644 --- a/src/glsl/ast_to_hir.cpp +++ b/src/glsl/ast_to_hir.cpp @@ -1772,6 +1772,8 @@ ast_declarator_list::hir(exec_list *instructions, } } + instructions->push_tail(var); + if (decl->initializer != NULL) { YYLTYPE initializer_loc = decl->initializer->get_location(); @@ -1918,8 +1920,6 @@ ast_declarator_list::hir(exec_list *instructions, decl->identifier); } - instructions->push_tail(var); - /* Add the variable to the symbol table after processing the initializer. * This differs from most C-like languages, but it follows the GLSL * specification. From page 28 (page 34 of the PDF) of the GLSL 1.50