aboutsummaryrefslogtreecommitdiffstats
path: root/backends/edif/edif.cc
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2017-03-19 14:53:28 +0100
committerClifford Wolf <clifford@clifford.at>2017-03-19 14:53:28 +0100
commit850f8299a9374ae4b9caeca8b6cd888be7c0a406 (patch)
tree4f332696647cb6579e6b2a18b3110d08271d0aaf /backends/edif/edif.cc
parent1390e9a0a7d4872e24a9fe53e258b8097932392a (diff)
downloadyosys-850f8299a9374ae4b9caeca8b6cd888be7c0a406.tar.gz
yosys-850f8299a9374ae4b9caeca8b6cd888be7c0a406.tar.bz2
yosys-850f8299a9374ae4b9caeca8b6cd888be7c0a406.zip
Fix EDIF: portRef member 0 is always the MSB bit
Diffstat (limited to 'backends/edif/edif.cc')
-rw-r--r--backends/edif/edif.cc9
1 files changed, 3 insertions, 6 deletions
diff --git a/backends/edif/edif.cc b/backends/edif/edif.cc
index e0eea85c9..229b039b9 100644
--- a/backends/edif/edif.cc
+++ b/backends/edif/edif.cc
@@ -317,10 +317,7 @@ struct EdifBackend : public Backend {
*f << stringf(" (port (array %s %d) (direction %s))\n", EDIF_DEFR(wire->name, port_rename, b[0], b[1]), wire->width, dir);
for (int i = 0; i < wire->width; i++) {
RTLIL::SigSpec sig = sigmap(RTLIL::SigSpec(wire, i));
- if (wire->upto)
- net_join_db[sig].insert(stringf("(portRef (member %s %d))", EDIF_REF(wire->name), GetSize(wire)-i-1));
- else
- net_join_db[sig].insert(stringf("(portRef (member %s %d))", EDIF_REF(wire->name), i));
+ net_join_db[sig].insert(stringf("(portRef (member %s %d))", EDIF_REF(wire->name), GetSize(wire)-i-1));
}
}
}
@@ -363,11 +360,11 @@ struct EdifBackend : public Backend {
else if (sig.size() == 1)
net_join_db[sig[i]].insert(stringf("(portRef %s (instanceRef %s))", EDIF_REF(p.first), EDIF_REF(cell->name)));
else {
- int member_idx = i;
+ int member_idx = GetSize(sig)-i-1;
auto m = design->module(cell->type);
if (m) {
auto w = m->wire(p.first);
- if (w && w->upto)
+ if (w)
member_idx = GetSize(w)-i-1;
}
net_join_db[sig[i]].insert(stringf("(portRef (member %s %d) (instanceRef %s))",