aboutsummaryrefslogtreecommitdiffstats
path: root/passes/memory/memory_share.cc
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2020-03-18 12:21:40 -0700
committerEddie Hung <eddie@fpgeh.com>2020-03-18 12:21:40 -0700
commit7ad7f41bc555d7fc77a2201cdc485702505df637 (patch)
treeca262dbd1d7e7e598228c3bf97898e5fac535b57 /passes/memory/memory_share.cc
parenta0cc795e85541b0326b6d4396a726142f0d0f8bb (diff)
downloadyosys-7ad7f41bc555d7fc77a2201cdc485702505df637.tar.gz
yosys-7ad7f41bc555d7fc77a2201cdc485702505df637.tar.bz2
yosys-7ad7f41bc555d7fc77a2201cdc485702505df637.zip
kernel: share a single CellTypes within a pass
Diffstat (limited to 'passes/memory/memory_share.cc')
-rw-r--r--passes/memory/memory_share.cc20
1 files changed, 16 insertions, 4 deletions
diff --git a/passes/memory/memory_share.cc b/passes/memory/memory_share.cc
index eb912cfd4..236c3c99c 100644
--- a/passes/memory/memory_share.cc
+++ b/passes/memory/memory_share.cc
@@ -665,9 +665,18 @@ struct MemoryShareWorker
// Setup and run
// -------------
- MemoryShareWorker(RTLIL::Design *design, RTLIL::Module *module) :
- design(design), module(module), sigmap(module)
+ MemoryShareWorker(RTLIL::Design *design) :
+ design(design), modwalker(design)
{
+ }
+
+ void operator()(RTLIL::Module* module)
+ {
+ this->module = module;
+ sigmap.set(module);
+ sig_to_mux.clear();
+ conditions_logic_cache.clear();
+
std::map<std::string, std::pair<std::vector<RTLIL::Cell*>, std::vector<RTLIL::Cell*>>> memindex;
sigmap_xmux = sigmap;
@@ -717,7 +726,7 @@ struct MemoryShareWorker
cone_ct.cell_types.erase("$shift");
cone_ct.cell_types.erase("$shiftx");
- modwalker.setup(design, module, &cone_ct);
+ modwalker.setup(module, &cone_ct);
for (auto &it : memindex)
consolidate_wr_using_sat(it.first, it.second.second);
@@ -755,8 +764,11 @@ struct MemorySharePass : public Pass {
void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE {
log_header(design, "Executing MEMORY_SHARE pass (consolidating $memrd/$memwr cells).\n");
extra_args(args, 1, design);
+
+ MemoryShareWorker msw(design);
+
for (auto module : design->selected_modules())
- MemoryShareWorker(design, module);
+ msw(module);
}
} MemorySharePass;