From 81b99d83f514f7693cbe53a2a6a33bfc8407fcee Mon Sep 17 00:00:00 2001 From: "Emil J. Tywoniak" Date: Wed, 1 Apr 2026 13:12:41 +0200 Subject: [PATCH] hierarchy: tolerance for apparent recursive instances in techmap files --- passes/hierarchy/hierarchy.cc | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/passes/hierarchy/hierarchy.cc b/passes/hierarchy/hierarchy.cc index 4580f14be..4b8830dbd 100644 --- a/passes/hierarchy/hierarchy.cc +++ b/passes/hierarchy/hierarchy.cc @@ -686,6 +686,8 @@ bool set_keep_print(std::map &cache, RTLIL::Module *mod) { if (cache.count(mod) == 0) for (auto c : mod->cells()) { + if (mod->name == c->type) + continue; RTLIL::Module *m = mod->design->module(c->type); if ((m != nullptr && set_keep_print(cache, m)) || c->type == ID($print)) return cache[mod] = true; @@ -697,6 +699,8 @@ bool set_keep_assert(std::map &cache, RTLIL::Module *mod) { if (cache.count(mod) == 0) for (auto c : mod->cells()) { + if (mod->name == c->type) + continue; RTLIL::Module *m = mod->design->module(c->type); if ((m != nullptr && set_keep_assert(cache, m)) || c->type.in(ID($check), ID($assert), ID($assume), ID($live), ID($fair), ID($cover))) return cache[mod] = true;