aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/register.cc
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2020-01-11 07:59:56 -0800
committerEddie Hung <eddie@fpgeh.com>2020-01-11 07:59:56 -0800
commit93e680b7d3114d989cf11e3bd4b4dfa65537bc7b (patch)
treeb96fa3f21d4fe7a17d6f0bf57e697d546fbfa885 /kernel/register.cc
parent9005bb97ff35513a510344108db203c5f5193ec6 (diff)
parentd2df2a8fef8d01b70fa5faa4397e1d628b9ceb5b (diff)
downloadyosys-93e680b7d3114d989cf11e3bd4b4dfa65537bc7b.tar.gz
yosys-93e680b7d3114d989cf11e3bd4b4dfa65537bc7b.tar.bz2
yosys-93e680b7d3114d989cf11e3bd4b4dfa65537bc7b.zip
Merge remote-tracking branch 'origin/master' into eddie/abc9_mfs
Diffstat (limited to 'kernel/register.cc')
-rw-r--r--kernel/register.cc15
1 files changed, 15 insertions, 0 deletions
diff --git a/kernel/register.cc b/kernel/register.cc
index 37f2e5e1b..5d0fb3c8c 100644
--- a/kernel/register.cc
+++ b/kernel/register.cc
@@ -114,20 +114,35 @@ void Pass::run_register()
void Pass::init_register()
{
+ vector<Pass*> added_passes;
while (first_queued_pass) {
+ added_passes.push_back(first_queued_pass);
first_queued_pass->run_register();
first_queued_pass = first_queued_pass->next_queued_pass;
}
+ for (auto added_pass : added_passes)
+ added_pass->on_register();
}
void Pass::done_register()
{
+ for (auto &it : pass_register)
+ it.second->on_shutdown();
+
frontend_register.clear();
pass_register.clear();
backend_register.clear();
log_assert(first_queued_pass == NULL);
}
+void Pass::on_register()
+{
+}
+
+void Pass::on_shutdown()
+{
+}
+
Pass::~Pass()
{
}