Only set MEM2REG_FL_CONST_LHS/MEM2REG_FL_VAR_LHS for non-init writes, fixes #867

Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
Clifford Wolf 2019-03-12 20:09:47 +01:00
parent ef48b62cb1
commit ab5b50ae3c
1 changed files with 8 additions and 6 deletions

View File

@ -2954,12 +2954,14 @@ void AstNode::mem2reg_as_needed_pass1(dict<AstNode*, pool<std::string>> &mem2reg
proc_flags[mem] |= AstNode::MEM2REG_FL_EQ1; proc_flags[mem] |= AstNode::MEM2REG_FL_EQ1;
} }
// remember if this is a constant index or not // for proper (non-init) writes: remember if this is a constant index or not
if (children[0]->children.size() && children[0]->children[0]->type == AST_RANGE && children[0]->children[0]->children.size()) { if ((flags & MEM2REG_FL_INIT) == 0) {
if (children[0]->children[0]->children[0]->type == AST_CONSTANT) if (children[0]->children.size() && children[0]->children[0]->type == AST_RANGE && children[0]->children[0]->children.size()) {
mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_CONST_LHS; if (children[0]->children[0]->children[0]->type == AST_CONSTANT)
else mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_CONST_LHS;
mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_VAR_LHS; else
mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_VAR_LHS;
}
} }
// remember where this is // remember where this is