aboutsummaryrefslogtreecommitdiffstats
path: root/passes
diff options
context:
space:
mode:
authorwhitequark <whitequark@whitequark.org>2020-11-03 15:36:27 +0000
committerwhitequark <whitequark@whitequark.org>2020-11-03 15:36:27 +0000
commitd6a93b8b903bb74b9eb10a16f8766958a83f8cf9 (patch)
treec708703205f49d386daebf20220da3389c0e5468 /passes
parent191406f930ea27c10f08fe1abcbe954fc537dcba (diff)
downloadyosys-d6a93b8b903bb74b9eb10a16f8766958a83f8cf9.tar.gz
yosys-d6a93b8b903bb74b9eb10a16f8766958a83f8cf9.tar.bz2
yosys-d6a93b8b903bb74b9eb10a16f8766958a83f8cf9.zip
check: add support for processes.
Diffstat (limited to 'passes')
-rw-r--r--passes/cmds/check.cc41
1 files changed, 38 insertions, 3 deletions
diff --git a/passes/cmds/check.cc b/passes/cmds/check.cc
index 54b9b340d..36febb98a 100644
--- a/passes/cmds/check.cc
+++ b/passes/cmds/check.cc
@@ -98,9 +98,6 @@ struct CheckPass : public Pass {
for (auto module : design->selected_whole_modules_warn())
{
- if (module->has_processes_warn())
- continue;
-
log("Checking module %s...\n", log_id(module));
SigMap sigmap(module);
@@ -109,6 +106,44 @@ struct CheckPass : public Pass {
pool<SigBit> used_wires;
TopoSort<string> topo;
+ for (auto &proc_it : module->processes)
+ {
+ std::vector<RTLIL::CaseRule*> all_cases = {&proc_it.second->root_case};
+ for (size_t i = 0; i < all_cases.size(); i++) {
+ for (auto action : all_cases[i]->actions) {
+ for (auto bit : sigmap(action.first))
+ if (bit.wire) {
+ wire_drivers[bit].push_back(
+ stringf("action %s <= %s (case rule) in process %s",
+ log_signal(action.first), log_signal(action.second), log_id(proc_it.first)));
+ }
+ for (auto bit : sigmap(action.second))
+ if (bit.wire) used_wires.insert(bit);
+ }
+ for (auto switch_ : all_cases[i]->switches) {
+ for (auto case_ : switch_->cases) {
+ all_cases.push_back(case_);
+ for (auto compare : case_->compare)
+ for (auto bit : sigmap(compare))
+ if (bit.wire) used_wires.insert(bit);
+ }
+ }
+ }
+ for (auto &sync : proc_it.second->syncs) {
+ for (auto bit : sigmap(sync->signal))
+ if (bit.wire) used_wires.insert(bit);
+ for (auto action : sync->actions) {
+ for (auto bit : sigmap(action.first))
+ if (bit.wire)
+ wire_drivers[bit].push_back(
+ stringf("action %s <= %s (sync rule) in process %s",
+ log_signal(action.first), log_signal(action.second), log_id(proc_it.first)));
+ for (auto bit : sigmap(action.second))
+ if (bit.wire) used_wires.insert(bit);
+ }
+ }
+ }
+
for (auto cell : module->cells())
{
if (mapped && cell->type.begins_with("$") && design->module(cell->type) == nullptr) {