mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-24 17:30:12 +01:00
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 <kenneth@whitecape.org> Reviewed-by: Chad Versace <chad.versace@intel.com> Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
This commit is contained in:
parent
7ec0c97896
commit
9e04b190b5
1 changed files with 5 additions and 6 deletions
|
|
@ -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);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue