diff options
author | Eric Anholt <[email protected]> | 2011-04-09 10:27:02 -1000 |
---|---|---|
committer | Eric Anholt <[email protected]> | 2011-04-13 15:48:26 -0700 |
commit | 9e04b190b5f59c5b375645f5756a6edd98a7f90c (patch) | |
tree | 343a56dd34c02dd352d97f8ce56693c74313e164 /src/glsl | |
parent | 7ec0c9789669ac88fcdd66c562e6d58281b477ce (diff) |
glsl: Semantically check the RHS of `||' even when short-circuiting.
We just do the AST-to-HIR processing, and only push the instructions
if needed in the constant false case.
Fixes glslparsertest/glsl2/logic-02.frag
Reviewed-by: Kenneth Graunke <[email protected]>
Reviewed-by: Chad Versace <[email protected]>
Reviewed-by: Ian Romanick <[email protected]>
Diffstat (limited to 'src/glsl')
-rw-r--r-- | src/glsl/ast_to_hir.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/src/glsl/ast_to_hir.cpp b/src/glsl/ast_to_hir.cpp index d92a437cbce..108c7c35d37 100644 --- a/src/glsl/ast_to_hir.cpp +++ b/src/glsl/ast_to_hir.cpp @@ -1151,16 +1151,18 @@ ast_expression::hir(exec_list *instructions, } case ast_logic_or: { + exec_list rhs_instructions; op[0] = get_scalar_boolean_operand(instructions, state, this, 0, "LHS", &error_emitted); + op[1] = get_scalar_boolean_operand(&rhs_instructions, state, this, 1, + "RHS", &error_emitted); ir_constant *op0_const = op[0]->constant_expression_value(); if (op0_const) { if (op0_const->value.b[0]) { result = op0_const; } else { - result = get_scalar_boolean_operand(instructions, state, this, 1, - "RHS", &error_emitted); + result = op[1]; } type = glsl_type::bool_type; } else { @@ -1172,15 +1174,12 @@ ast_expression::hir(exec_list *instructions, ir_if *const stmt = new(ctx) ir_if(op[0]); instructions->push_tail(stmt); - op[1] = get_scalar_boolean_operand(&stmt->else_instructions, - state, this, 1, - "RHS", &error_emitted); - ir_dereference *const then_deref = new(ctx) ir_dereference_variable(tmp); ir_assignment *const then_assign = new(ctx) ir_assignment(then_deref, new(ctx) ir_constant(true), NULL); stmt->then_instructions.push_tail(then_assign); + stmt->else_instructions.append_list(&rhs_instructions); ir_dereference *const else_deref = new(ctx) ir_dereference_variable(tmp); ir_assignment *const else_assign = new(ctx) ir_assignment(else_deref, op[1], NULL); |