2022-11-30 23:50:43 +01:00
|
|
|
# See LICENSE for licensing information.
|
|
|
|
|
#
|
|
|
|
|
# Copyright (c) 2016-2022 Regents of the University of California, Santa Cruz
|
|
|
|
|
# All rights reserved.
|
|
|
|
|
#
|
2022-06-15 02:57:04 +02:00
|
|
|
import os
|
2022-07-14 01:37:47 +02:00
|
|
|
import re
|
2022-11-27 22:01:20 +01:00
|
|
|
from math import ceil, log
|
|
|
|
|
from openram import OPTS
|
|
|
|
|
from .template import template
|
2022-06-10 06:40:19 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class sram_multibank:
|
|
|
|
|
|
|
|
|
|
def __init__(self, sram):
|
2022-06-15 02:57:04 +02:00
|
|
|
rw_ports = [i for i in sram.all_ports if i in sram.read_ports and i in sram.write_ports]
|
|
|
|
|
r_ports = [i for i in sram.all_ports if i in sram.read_ports and i not in sram.write_ports]
|
|
|
|
|
w_ports = [i for i in sram.all_ports if i not in sram.read_ports and i in sram.write_ports]
|
|
|
|
|
self.dict = {
|
2022-08-18 20:03:13 +02:00
|
|
|
'module_name': sram.name + '_top',
|
|
|
|
|
'bank_module_name': sram.name,
|
2022-06-15 02:57:04 +02:00
|
|
|
'vdd': 'vdd',
|
|
|
|
|
'gnd': 'gnd',
|
|
|
|
|
'ports': sram.all_ports,
|
|
|
|
|
'rw_ports': rw_ports,
|
|
|
|
|
'r_ports': r_ports,
|
|
|
|
|
'w_ports': w_ports,
|
|
|
|
|
'banks': list(range(sram.num_banks)),
|
|
|
|
|
'data_width': sram.word_size,
|
2022-07-08 22:50:24 +02:00
|
|
|
'addr_width': sram.bank_addr_size + ceil(log(sram.num_banks, 2)),
|
2022-06-15 02:57:04 +02:00
|
|
|
'bank_sel': ceil(log(sram.num_banks, 2)),
|
2022-07-14 01:37:47 +02:00
|
|
|
'num_wmask': sram.num_wmasks,
|
|
|
|
|
'write_size': sram.write_size
|
2022-07-29 00:07:19 +02:00
|
|
|
}
|
2022-06-10 06:40:19 +02:00
|
|
|
|
2022-06-15 02:57:04 +02:00
|
|
|
def verilog_write(self, name):
|
2022-08-11 01:34:49 +02:00
|
|
|
template_filename = os.path.join(os.path.abspath(os.environ["OPENRAM_HOME"]), "modules/sram_multibank_template.v")
|
2022-06-15 02:57:04 +02:00
|
|
|
t = template(template_filename, self.dict)
|
|
|
|
|
t.write(name)
|
2022-07-14 01:37:47 +02:00
|
|
|
with open(name, 'r') as f:
|
|
|
|
|
text = f.read()
|
2022-08-18 20:03:13 +02:00
|
|
|
badComma = re.compile(r',(\s*\n\s*\);)')
|
2022-07-14 01:37:47 +02:00
|
|
|
text = badComma.sub(r'\1', text)
|
|
|
|
|
with open(name, 'w') as f:
|
|
|
|
|
f.write(text)
|