Connected wmask in the spice netlist.

This commit is contained in:
jsowash 2019-07-19 13:17:55 -07:00
parent 082decba18
commit 45cb159d7f
8 changed files with 102 additions and 31 deletions

View File

@ -290,6 +290,18 @@ class functional(simulation):
for port in self.readwrite_ports:
self.stim.gen_pwl("WEB{}".format(port), self.cycle_times , self.web_values[port], self.period, self.slew, 0.05)
# Generate wmask bits
for port in self.write_ports:
self.sf.write("\n* Generation of wmask signals\n")
if (self.write_size != self.word_size):
num_wmask = int(self.word_size / self.write_size)
for bit in range(num_wmask):
sig_name = "WMASK{0}_{1} ".format(port, bit)
self.stim.gen_pwl(sig_name, self.cycle_times, self.data_values[port][bit], self.period,
self.slew, 0.05)
# self.stim.gen_pwl(sig_name, self.cycle_times, self.wmask_values[port][bit], self.period,
# self.slew, 0.05)
# Generate CLK signals
for port in self.all_ports:
self.stim.gen_pulse(sig_name="{0}{1}".format(tech.spice["clk"], port),

View File

@ -79,6 +79,7 @@ class simulation():
# Three dimensional list to handle each addr and data bits for wach port over the number of checks
self.addr_values = [[[] for bit in range(self.addr_size)] for port in self.all_ports]
self.data_values = [[[] for bit in range(self.word_size)] for port in self.write_ports]
self.wmask_values = [[[] for bit in range(self.num_wmask)] for port in self.write_ports]
# For generating comments in SPICE stimulus
self.cycle_comments = []
@ -130,6 +131,20 @@ class simulation():
else:
debug.error("Non-binary address string",1)
bit -= 1
def add_wmask(self, wmask, port):
""" Add the array of address values """
debug.check(len(wmask) == self.num_wmask, "Invalid wmask size.")
bit = self.addr_size - 1
for c in wmask:
if c == "0":
self.wmask_values[port][bit].append(0)
elif c == "1":
self.wmask_values[port][bit].append(1)
else:
debug.error("Non-binary address string", 1)
bit -= 1
def add_write(self, comment, address, data, port):
""" Add the control values for a write cycle. """
@ -281,13 +296,14 @@ class simulation():
for port in range(total_ports):
if (port in read_index) and (port in write_index):
pin_names.append("WEB{0}".format(port))
for port in range(total_ports):
pin_names.append("{0}{1}".format(tech.spice["clk"], port))
if (self.write_size != self.word_size):
num_wmask = int(self.word_size/self.write_size)
for bit in range(num_wmask):
pin_names.append("WMASK{0}_{1}".format(port,bit))
for port in range(total_ports):
pin_names.append("{0}{1}".format(tech.spice["clk"], port))
for read_output in read_index:
for i in range(dbits):

View File

@ -30,6 +30,8 @@ class bank(design.design):
self.sram_config = sram_config
sram_config.set_local_config(self)
if (self.word_size != self.write_size):
self.num_wmask = int(self.word_size/self.write_size)
if name == "":
name = "bank_{0}_{1}".format(self.word_size, self.num_words)
@ -98,6 +100,11 @@ class bank(design.design):
self.add_pin("p_en_bar{0}".format(port), "INPUT")
for port in self.write_ports:
self.add_pin("w_en{0}".format(port), "INPUT")
if (self.word_size != self.write_size):
for bit in range(self.num_wmask):
self.add_pin("bank_wmask{0}_{1}".format(port,bit),"INPUT")
# for bit in range(self.num_wmask):
# self.add_pin("wdriver_sel{0}_{1}".format(port, bit),"INOUT")
for port in self.all_ports:
self.add_pin("wl_en{0}".format(port), "INPUT")
self.add_pin("vdd","POWER")
@ -406,6 +413,11 @@ class bank(design.design):
temp.append("p_en_bar{0}".format(port))
if port in self.write_ports:
temp.append("w_en{0}".format(port))
if (self.word_size != self.write_size):
for bit in range(self.num_wmask):
temp.append("bank_wmask{0}_{1}".format(port, bit))
# for bit in range(self.num_wmask):
# temp.append("wdriver_sel_{0}_{1}".format(port, bit))
temp.extend(["vdd","gnd"])
self.connect_inst(temp)

View File

@ -21,7 +21,8 @@ class port_data(design.design):
sram_config.set_local_config(self)
self.port = port
self.num_wmask = int(self.word_size/self.write_size)
if (self.word_size != self.write_size):
self.num_wmask = int(self.word_size/self.write_size)
if name == "":
name = "port_data_{0}".format(self.port)
@ -96,6 +97,11 @@ class port_data(design.design):
self.add_pin("p_en_bar", "INPUT")
if self.port in self.write_ports:
self.add_pin("w_en", "INPUT")
if (self.word_size != self.write_size):
for bit in range(self.num_wmask):
self.add_pin("bank_wmask_{}".format(bit),"INPUT")
# for bit in range(self.num_wmask):
# self.add_pin("wdriver_sel_{}".format(bit), "INOUT")
self.add_pin("vdd","POWER")
self.add_pin("gnd","GROUND")
@ -168,7 +174,8 @@ class port_data(design.design):
if self.port in self.write_ports:
self.write_driver_array = factory.create(module_type="write_driver_array",
columns=self.num_cols,
word_size=self.word_size)
word_size=self.word_size,
write_size=self.write_size)
self.add_mod(self.write_driver_array)
if (self.word_size != self.write_size):
self.write_mask_and_array = factory.create(module_type="write_mask_and_array",
@ -282,9 +289,8 @@ class port_data(design.design):
mod=self.write_driver_array)
temp = []
m
for bit in range(self.word_size):
temp.append("din_{}".format(bit))
for bit in range(self.word_size):
temp.append("din_{}".format(bit))
for bit in range(self.word_size):
if (self.words_per_row == 1):
@ -293,7 +299,16 @@ class port_data(design.design):
else:
temp.append(self.bl_names[self.port]+"_out_{0}".format(bit))
temp.append(self.br_names[self.port]+"_out_{0}".format(bit))
temp.extend(["w_en", "vdd", "gnd"])
if (self.write_size != self.word_size):
i = 0
for bit in range(0,self.word_size,self.write_size):
for x in range(self.write_size):
temp.append("wdriver_sel_{}".format(i))
i+=1
else:
temp.append("w_en")
temp.extend(["vdd", "gnd"])
self.connect_inst(temp)
@ -304,8 +319,11 @@ class port_data(design.design):
temp = []
for bit in range(self.num_wmask):
temp.append("write_mask_{}".format(bit))
temp.extend(["w_en", "vdd", "gnd"])
temp.append("bank_wmask_{}".format(bit))
temp.extend(["w_en"])
for bit in range(self.num_wmask):
temp.append("wdriver_sel_{}".format(bit))
temp.extend(["vdd", "gnd"])
self.connect_inst(temp)

View File

@ -19,7 +19,7 @@ class write_driver_array(design.design):
Dynamically generated write driver array of all bitlines.
"""
def __init__(self, name, columns, word_size):
def __init__(self, name, columns, word_size,write_size):
design.design.__init__(self, name)
debug.info(1, "Creating {0}".format(self.name))
self.add_comment("columns: {0}".format(columns))
@ -27,6 +27,7 @@ class write_driver_array(design.design):
self.columns = columns
self.word_size = word_size
self.write_size = write_size
self.words_per_row = int(columns / word_size)
self.create_netlist()
@ -59,7 +60,11 @@ class write_driver_array(design.design):
for i in range(self.word_size):
self.add_pin("bl_{0}".format(i))
self.add_pin("br_{0}".format(i))
self.add_pin("en")
if self.word_size != self.write_size:
for i in range(self.word_size):
self.add_pin("en_{}".format(i))
else:
self.add_pin("en")
self.add_pin("vdd")
self.add_pin("gnd")
@ -79,10 +84,16 @@ class write_driver_array(design.design):
self.driver_insts[index]=self.add_inst(name=name,
mod=self.driver)
self.connect_inst(["data_{0}".format(index),
"bl_{0}".format(index),
"br_{0}".format(index),
"en", "vdd", "gnd"])
if self.word_size != self.write_size:
self.connect_inst(["data_{0}".format(index),
"bl_{0}".format(index),
"br_{0}".format(index),
"en_{0}".format(index), "vdd", "gnd"])
else:
self.connect_inst(["data_{0}".format(index),
"bl_{0}".format(index),
"br_{0}".format(index),
"en", "vdd", "gnd"])
def place_write_array(self):

View File

@ -60,10 +60,12 @@ class write_mask_and_array(design.design):
def add_pins(self):
for bit in range(self.num_wmask):
self.add_pin("wdriver_sel_{}".format(bit))
self.add_pin("en")
self.add_pin("vdd")
self.add_pin("gnd")
self.add_pin("wmask_in_{}".format(bit),"INPUT")
self.add_pin("en", "INPUT")
for bit in range(self.num_wmask):
self.add_pin("wmask_out_{}".format(bit),"OUTPUT")
self.add_pin("vdd","POWER")
self.add_pin("gnd","GROUND")
def add_modules(self):
self.wmask = factory.create(module_type="dff_buf")
@ -94,9 +96,9 @@ class write_mask_and_array(design.design):
name = "and2_{}".format(bit)
self.and2_insts[bit] = self.add_inst(name=name,
mod=self.and2)
self.connect_inst(["bank_wmask_{}".format(bit),
self.connect_inst(["wmask_in_{}".format(bit),
"en",
"wdriver_sel_{}".format(bit),
"wmask_out_{}".format(bit),
"vdd", "gnd"])

View File

@ -357,6 +357,11 @@ class sram_base(design, verilog, lef):
temp.append("p_en_bar{0}".format(port))
for port in self.write_ports:
temp.append("w_en{0}".format(port))
if (self.word_size != self.write_size):
for bit in range(self.num_masks):
temp.append("bank_wmask{}[{}]".format(port, bit))
# for bit in range(self.num_masks):
# temp.append("wdriver_sel{}[{}]".format(port, bit))
for port in self.all_ports:
temp.append("wl_en{0}".format(port))
temp.extend(["vdd", "gnd"])
@ -499,8 +504,6 @@ class sram_base(design, verilog, lef):
if port in self.readwrite_ports:
temp.append("web{}".format(port))
temp.append("clk{}".format(port))
# if port in self.write_ports:
# temp.append("wmask{}".format(port))
# for port in self.all_ports:
# self.add_pin("csb{}".format(port), "INPUT")
@ -508,11 +511,6 @@ class sram_base(design, verilog, lef):
# self.add_pin("web{}".format(port), "INPUT")
# for port in self.all_ports:
# self.add_pin("clk{}".format(port), "INPUT")
# # add the optional write mask pins
# if self.word_size != self.write_size:
# for port in self.write_ports:
# print("write_ports", port)
# self.add_pin("wmask{0}".format(port), "INPUT")
# Outputs
if port in self.read_ports:

View File

@ -15,7 +15,7 @@ from globals import OPTS
from sram_factory import factory
import debug
@unittest.skip("SKIPPING sram_wmask_func_test")
#@unittest.skip("SKIPPING sram_wmask_func_test")
class sram_wmask_func_test(openram_test):
def runTest(self):
@ -34,6 +34,8 @@ class sram_wmask_func_test(openram_test):
num_words=16,
write_size=4,
num_banks=1)
c.words_per_row=1
c.recompute_sizes_once()
debug.info(1, "Functional test for sram with {} bit words, {} words, {} words per row, {} bit writes, {} banks".format(c.word_size,
c.num_words,
c.words_per_row,