diff options
author | Marcelina KoĆcielnicka <mwk@0x04.net> | 2022-04-15 15:05:08 +0200 |
---|---|---|
committer | Marcelina KoĆcielnicka <mwk@0x04.net> | 2022-04-15 22:01:00 +0200 |
commit | 25ff83f0b5075fe1f6f2a2daa7f4596f08a1a638 (patch) | |
tree | 3d339519313aa6bc0e2a4c05dbb763d957978748 /passes | |
parent | 48eea3efcf4d88d16b170a1915bda0fe691924a1 (diff) | |
download | yosys-25ff83f0b5075fe1f6f2a2daa7f4596f08a1a638.tar.gz yosys-25ff83f0b5075fe1f6f2a2daa7f4596f08a1a638.tar.bz2 yosys-25ff83f0b5075fe1f6f2a2daa7f4596f08a1a638.zip |
memory_share: Fix up mismatched address widths.
Diffstat (limited to 'passes')
-rw-r--r-- | passes/memory/memory_share.cc | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/passes/memory/memory_share.cc b/passes/memory/memory_share.cc index ceea725d8..1ddc13f90 100644 --- a/passes/memory/memory_share.cc +++ b/passes/memory/memory_share.cc @@ -82,6 +82,11 @@ struct MemoryShareWorker log("Consolidating read ports of memory %s.%s by address:\n", log_id(module), log_id(mem.memid)); bool changed = false; + int abits = 0; + for (auto &port: mem.rd_ports) { + if (GetSize(port.addr) > abits) + abits = GetSize(port.addr); + } for (int i = 0; i < GetSize(mem.rd_ports); i++) { auto &port1 = mem.rd_ports[i]; @@ -114,6 +119,8 @@ struct MemoryShareWorker int wide_log2 = std::max(port1.wide_log2, port2.wide_log2); SigSpec addr1 = sigmap_xmux(port1.addr); SigSpec addr2 = sigmap_xmux(port2.addr); + addr1.extend_u0(abits); + addr2.extend_u0(abits); if (GetSize(addr1) <= wide_log2) continue; if (GetSize(addr2) <= wide_log2) @@ -192,6 +199,11 @@ struct MemoryShareWorker log("Consolidating write ports of memory %s.%s by address:\n", log_id(module), log_id(mem.memid)); bool changed = false; + int abits = 0; + for (auto &port: mem.wr_ports) { + if (GetSize(port.addr) > abits) + abits = GetSize(port.addr); + } for (int i = 0; i < GetSize(mem.wr_ports); i++) { auto &port1 = mem.wr_ports[i]; @@ -216,6 +228,8 @@ struct MemoryShareWorker int wide_log2 = std::max(port1.wide_log2, port2.wide_log2); SigSpec addr1 = sigmap_xmux(port1.addr); SigSpec addr2 = sigmap_xmux(port2.addr); + addr1.extend_u0(abits); + addr2.extend_u0(abits); if (GetSize(addr1) <= wide_log2) continue; if (GetSize(addr2) <= wide_log2) |