diff options
author | Clifford Wolf <clifford@clifford.at> | 2014-08-17 02:17:49 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2014-08-17 02:17:49 +0200 |
commit | 64713647a966e8a14dff39f9ac18aafe9c882f46 (patch) | |
tree | 6a4002bfcc4dc9c09779d80744fbf2412c921313 | |
parent | f3326a642178b66ba98b6371245077ff93ffe215 (diff) | |
download | yosys-64713647a966e8a14dff39f9ac18aafe9c882f46.tar.gz yosys-64713647a966e8a14dff39f9ac18aafe9c882f46.tar.bz2 yosys-64713647a966e8a14dff39f9ac18aafe9c882f46.zip |
Improved AST ProcessGenerator performance
-rw-r--r-- | frontends/ast/genrtlil.cc | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/frontends/ast/genrtlil.cc b/frontends/ast/genrtlil.cc index 4eb4f6c44..1936146b3 100644 --- a/frontends/ast/genrtlil.cc +++ b/frontends/ast/genrtlil.cc @@ -357,7 +357,7 @@ struct AST_INTERNAL::ProcessGenerator // e.g. when the last statement in the code "a = 23; if (b) a = 42; a = 0;" is processed this // function is called to clean up the first two assignments as they are overwritten by // the third assignment. - void removeSignalFromCaseTree(RTLIL::SigSpec pattern, RTLIL::CaseRule *cs) + void removeSignalFromCaseTree(const std::set<RTLIL::SigBit> &pattern, RTLIL::CaseRule *cs) { for (auto it = cs->actions.begin(); it != cs->actions.end(); it++) it->first.remove2(pattern, &it->second); @@ -411,7 +411,7 @@ struct AST_INTERNAL::ProcessGenerator subst_rvalue_map.set(unmapped_lvalue[i], rvalue[i]); } - removeSignalFromCaseTree(lvalue, current_case); + removeSignalFromCaseTree(lvalue.to_sigbit_set(), current_case); current_case->actions.push_back(RTLIL::SigSig(lvalue, rvalue)); } break; @@ -487,7 +487,7 @@ struct AST_INTERNAL::ProcessGenerator subst_rvalue_map.set(this_case_eq_lvalue[i], this_case_eq_ltemp[i]); this_case_eq_lvalue.replace(subst_lvalue_map.stdmap()); - removeSignalFromCaseTree(this_case_eq_lvalue, current_case); + removeSignalFromCaseTree(this_case_eq_lvalue.to_sigbit_set(), current_case); addChunkActions(current_case->actions, this_case_eq_lvalue, this_case_eq_ltemp); } break; |