diff options
author | Clifford Wolf <clifford@clifford.at> | 2014-08-03 15:00:38 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2014-08-03 15:00:38 +0200 |
commit | 653edd7a2f857d09bd8cecc48cc9ac76aea33098 (patch) | |
tree | 67b010b78e6c435276bacca0fffe019d763eaa68 | |
parent | 75423169c59022b3680aa3bf7de0877bc43a8082 (diff) | |
download | yosys-653edd7a2f857d09bd8cecc48cc9ac76aea33098.tar.gz yosys-653edd7a2f857d09bd8cecc48cc9ac76aea33098.tar.bz2 yosys-653edd7a2f857d09bd8cecc48cc9ac76aea33098.zip |
Added query() API to ModIndex
-rw-r--r-- | kernel/modtools.h | 54 |
1 files changed, 46 insertions, 8 deletions
diff --git a/kernel/modtools.h b/kernel/modtools.h index 09f2ae65e..56bc1882d 100644 --- a/kernel/modtools.h +++ b/kernel/modtools.h @@ -29,11 +29,11 @@ YOSYS_NAMESPACE_BEGIN struct ModIndex : public RTLIL::Monitor { struct PortInfo { - const RTLIL::Cell* cell; - const RTLIL::IdString &port; - const int offset; + RTLIL::Cell* cell; + RTLIL::IdString port; + int offset; - PortInfo(RTLIL::Cell* _c, const RTLIL::IdString &_p, int _o) : cell(_c), port(_p), offset(_o) { } + PortInfo(RTLIL::Cell* _c, RTLIL::IdString _p, int _o) : cell(_c), port(_p), offset(_o) { } bool operator<(const PortInfo &other) const { if (cell != other.cell) @@ -57,13 +57,13 @@ struct ModIndex : public RTLIL::Monitor std::map<RTLIL::SigBit, SigBitInfo> database; bool auto_reload_module; - void port_add(RTLIL::Cell *cell, const RTLIL::IdString &port, const RTLIL::SigSpec &sig) + void port_add(RTLIL::Cell *cell, RTLIL::IdString port, const RTLIL::SigSpec &sig) { for (int i = 0; i < SIZE(sig); i++) database[sigmap(sig[i])].ports.insert(PortInfo(cell, port, i)); } - void port_del(RTLIL::Cell *cell, const RTLIL::IdString &port, const RTLIL::SigSpec &sig) + void port_del(RTLIL::Cell *cell, RTLIL::IdString port, const RTLIL::SigSpec &sig) { for (int i = 0; i < SIZE(sig); i++) database[sigmap(sig[i])].ports.erase(PortInfo(cell, port, i)); @@ -122,14 +122,52 @@ struct ModIndex : public RTLIL::Monitor auto_reload_module = true; } - ModIndex(RTLIL::Module *_m) : module(_m) { + ModIndex(RTLIL::Module *_m) : module(_m) + { auto_reload_module = true; module->monitors.insert(this); } - ~ModIndex() { + ~ModIndex() + { module->monitors.erase(this); } + + SigBitInfo *query(RTLIL::SigBit bit) + { + if (auto_reload_module) + reload_module(); + auto it = database.find(sigmap(bit)); + if (it == database.end()) + return nullptr; + else + return &it->second; + } + + bool query_is_input(RTLIL::SigBit bit) + { + const SigBitInfo *info = query(bit); + if (info == nullptr) + return false; + return info->is_input; + } + + bool query_is_output(RTLIL::SigBit bit) + { + const SigBitInfo *info = query(bit); + if (info == nullptr) + return false; + return info->is_output; + } + + std::set<PortInfo> &query_ports(RTLIL::SigBit bit) + { + static std::set<PortInfo> empty_result_set; + SigBitInfo *info = query(bit); + if (info == nullptr) + return empty_result_set; + return info->ports; + } }; struct ModWalker |