mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 17:44:09 +00:00
Use mem2reg on memories that only have constant-index write ports
Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
parent
03237de686
commit
7cfae2c52f
|
@ -214,6 +214,8 @@ namespace AST
|
||||||
MEM2REG_FL_SET_ASYNC = 0x00000800,
|
MEM2REG_FL_SET_ASYNC = 0x00000800,
|
||||||
MEM2REG_FL_EQ2 = 0x00001000,
|
MEM2REG_FL_EQ2 = 0x00001000,
|
||||||
MEM2REG_FL_CMPLX_LHS = 0x00002000,
|
MEM2REG_FL_CMPLX_LHS = 0x00002000,
|
||||||
|
MEM2REG_FL_CONST_LHS = 0x00004000,
|
||||||
|
MEM2REG_FL_VAR_LHS = 0x00008000,
|
||||||
|
|
||||||
/* proc flags */
|
/* proc flags */
|
||||||
MEM2REG_FL_EQ1 = 0x01000000,
|
MEM2REG_FL_EQ1 = 0x01000000,
|
||||||
|
|
|
@ -113,6 +113,9 @@ bool AstNode::simplify(bool const_fold, bool at_zero, bool in_lvalue, int stage,
|
||||||
if (memflags & AstNode::MEM2REG_FL_CMPLX_LHS)
|
if (memflags & AstNode::MEM2REG_FL_CMPLX_LHS)
|
||||||
goto verbose_activate;
|
goto verbose_activate;
|
||||||
|
|
||||||
|
if ((memflags & AstNode::MEM2REG_FL_CONST_LHS) && !(memflags & AstNode::MEM2REG_FL_VAR_LHS))
|
||||||
|
goto verbose_activate;
|
||||||
|
|
||||||
// log("Note: Not replacing memory %s with list of registers (flags=0x%08lx).\n", mem->str.c_str(), long(memflags));
|
// log("Note: Not replacing memory %s with list of registers (flags=0x%08lx).\n", mem->str.c_str(), long(memflags));
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -2936,6 +2939,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
|
||||||
|
if (children[0]->children.size() && children[0]->children[0]->type == AST_RANGE && children[0]->children[0]->children.size()) {
|
||||||
|
if (children[0]->children[0]->children[0]->type == AST_CONSTANT)
|
||||||
|
mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_CONST_LHS;
|
||||||
|
else
|
||||||
|
mem2reg_candidates[mem] |= AstNode::MEM2REG_FL_VAR_LHS;
|
||||||
|
}
|
||||||
|
|
||||||
// remember where this is
|
// remember where this is
|
||||||
if (flags & MEM2REG_FL_INIT) {
|
if (flags & MEM2REG_FL_INIT) {
|
||||||
if (!(mem2reg_candidates[mem] & AstNode::MEM2REG_FL_SET_INIT))
|
if (!(mem2reg_candidates[mem] & AstNode::MEM2REG_FL_SET_INIT))
|
||||||
|
|
Loading…
Reference in a new issue