mirror of https://github.com/VLSIDA/OpenRAM.git
Created wmask AND array en pin to go through to top layer.
This commit is contained in:
parent
aa4803f3c4
commit
0d7170eb95
|
|
@ -545,7 +545,6 @@ class port_data(design.design):
|
||||||
self.add_path("metal2", [wdriver_sel_out_pin.center(), wdriver_sel_in_pin.center()])
|
self.add_path("metal2", [wdriver_sel_out_pin.center(), wdriver_sel_in_pin.center()])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def route_bitline_pins(self):
|
def route_bitline_pins(self):
|
||||||
""" Add the bitline pins for the given port """
|
""" Add the bitline pins for the given port """
|
||||||
|
|
||||||
|
|
@ -582,9 +581,9 @@ class port_data(design.design):
|
||||||
if self.write_driver_array_inst:
|
if self.write_driver_array_inst:
|
||||||
if self.write_mask_and_array_inst:
|
if self.write_mask_and_array_inst:
|
||||||
for bit in range(self.num_wmasks):
|
for bit in range(self.num_wmasks):
|
||||||
wdriver_en_pin = self.write_driver_array_inst.get_pin("en_{}".format(bit))
|
self.copy_layout_pin(self.write_driver_array_inst, "en_{}".format(bit), "wdriver_sel_{}".format(bit))
|
||||||
|
|
||||||
# self.copy_layout_pin(self.write_driver_array_inst, "en_{}".format(bit), "wdriver_sel_{}".format(bit))
|
wdriver_en_pin = self.write_driver_array_inst.get_pin("en_{}".format(bit))
|
||||||
self.add_via_center(layers=("metal1", "via1", "metal2"),
|
self.add_via_center(layers=("metal1", "via1", "metal2"),
|
||||||
offset=wdriver_en_pin.center())
|
offset=wdriver_en_pin.center())
|
||||||
self.add_layout_pin_rect_center(text="wdriver_sel_{0}".format(bit),
|
self.add_layout_pin_rect_center(text="wdriver_sel_{0}".format(bit),
|
||||||
|
|
@ -594,6 +593,7 @@ class port_data(design.design):
|
||||||
self.copy_layout_pin(self.write_driver_array_inst, "en", "w_en")
|
self.copy_layout_pin(self.write_driver_array_inst, "en", "w_en")
|
||||||
if self.write_mask_and_array_inst:
|
if self.write_mask_and_array_inst:
|
||||||
self.copy_layout_pin(self.write_mask_and_array_inst, "en", "w_en")
|
self.copy_layout_pin(self.write_mask_and_array_inst, "en", "w_en")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def channel_route_bitlines(self, inst1, inst2, num_bits,
|
def channel_route_bitlines(self, inst1, inst2, num_bits,
|
||||||
|
|
|
||||||
|
|
@ -51,7 +51,7 @@ class write_mask_and_array(design.design):
|
||||||
|
|
||||||
self.place_and2_array()
|
self.place_and2_array()
|
||||||
self.add_layout_pins()
|
self.add_layout_pins()
|
||||||
self.route_enable()
|
# self.route_enable()
|
||||||
self.add_boundary()
|
self.add_boundary()
|
||||||
self.DRC_LVS()
|
self.DRC_LVS()
|
||||||
|
|
||||||
|
|
@ -121,9 +121,12 @@ class write_mask_and_array(design.design):
|
||||||
offset=en_pin.center())
|
offset=en_pin.center())
|
||||||
self.add_via_center(layers=("metal2", "via2", "metal3"),
|
self.add_via_center(layers=("metal2", "via2", "metal3"),
|
||||||
offset=en_pin.center())
|
offset=en_pin.center())
|
||||||
self.add_layout_pin_rect_center(text="en",
|
if i < self.num_wmasks-1:
|
||||||
layer="metal3",
|
self.add_layout_pin(text="en",
|
||||||
offset=en_pin.center())
|
layer="metal3",
|
||||||
|
offset=en_pin.ll(),
|
||||||
|
width = self.en_width(i),
|
||||||
|
height = en_pin.height())
|
||||||
|
|
||||||
wmask_out_pin = self.and2_insts[i].get_pin("Z")
|
wmask_out_pin = self.and2_insts[i].get_pin("Z")
|
||||||
self.add_layout_pin(text="wmask_out_{0}".format(i),
|
self.add_layout_pin(text="wmask_out_{0}".format(i),
|
||||||
|
|
@ -146,14 +149,20 @@ class write_mask_and_array(design.design):
|
||||||
layer="metal3",
|
layer="metal3",
|
||||||
offset=pin_pos)
|
offset=pin_pos)
|
||||||
|
|
||||||
|
def en_width(self, pin):
|
||||||
|
en_pin = self.and2_insts[pin].get_pin("B")
|
||||||
|
next_en_pin = self.and2_insts[pin+1].get_pin("B")
|
||||||
|
width = next_en_pin.lr() - en_pin.ll()
|
||||||
|
return width[0]
|
||||||
|
|
||||||
def route_enable(self):
|
|
||||||
for i in range(self.num_wmasks-1):
|
# def route_enable(self):
|
||||||
en_pin = self.and2_insts[i].get_pin("B")
|
# for i in range(self.num_wmasks-1):
|
||||||
next_en_pin = self.and2_insts[i+1].get_pin("B")
|
# en_pin = self.and2_insts[i].get_pin("B")
|
||||||
offset = en_pin.center()
|
# next_en_pin = self.and2_insts[i+1].get_pin("B")
|
||||||
next_offset = next_en_pin.center()
|
# offset = en_pin.center()
|
||||||
self.add_path("metal3", [offset, next_offset])
|
# next_offset = next_en_pin.center()
|
||||||
|
# self.add_path("metal3", [offset, next_offset])
|
||||||
|
|
||||||
def get_cin(self):
|
def get_cin(self):
|
||||||
"""Get the relative capacitance of all the input connections in the bank"""
|
"""Get the relative capacitance of all the input connections in the bank"""
|
||||||
|
|
|
||||||
|
|
@ -125,11 +125,13 @@ class sram_1bank(sram_base):
|
||||||
-max_gap_size - self.data_dff_insts[port].height)
|
-max_gap_size - self.data_dff_insts[port].height)
|
||||||
self.data_dff_insts[port].place(data_pos[port])
|
self.data_dff_insts[port].place(data_pos[port])
|
||||||
|
|
||||||
# Add the write mask flops to the left of the din flops.
|
# Add the write mask flops below the din flops.
|
||||||
if self.write_size is not None:
|
if self.write_size is not None:
|
||||||
if port in self.write_ports:
|
if port in self.write_ports:
|
||||||
wmask_pos[port] = vector(self.bank.bank_array_ll.x - self.control_logic_insts[port].width,
|
wmask_pos[port] = vector(self.bank.bank_array_ll.x,
|
||||||
-max_gap_size - self.wmask_dff_insts[port].height)
|
-max_gap_size - self.wmask_dff_insts[port].height)
|
||||||
|
# wmask_pos[port] = vector(self.bank.bank_array_ll.x - self.control_logic_insts[port].width,
|
||||||
|
# -max_gap_size - self.wmask_dff_insts[port].height)
|
||||||
self.wmask_dff_insts[port].place(wmask_pos[port])
|
self.wmask_dff_insts[port].place(wmask_pos[port])
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -501,7 +501,7 @@ class sram_base(design, verilog, lef):
|
||||||
temp.append("clk{}".format(port))
|
temp.append("clk{}".format(port))
|
||||||
temp.append("rbl_bl{}".format(port))
|
temp.append("rbl_bl{}".format(port))
|
||||||
|
|
||||||
# Ouputs
|
# Outputs
|
||||||
if port in self.read_ports:
|
if port in self.read_ports:
|
||||||
temp.append("s_en{}".format(port))
|
temp.append("s_en{}".format(port))
|
||||||
if port in self.write_ports:
|
if port in self.write_ports:
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,7 @@ import debug
|
||||||
class write_driver_test(openram_test):
|
class write_driver_test(openram_test):
|
||||||
|
|
||||||
def runTest(self):
|
def runTest(self):
|
||||||
globals.init_openram("config_{0}".format(OPTS.tech_name))
|
globals.init("config_{0}".format(OPTS.tech_name))
|
||||||
|
|
||||||
# check write driver array for single port
|
# check write driver array for single port
|
||||||
debug.info(2, "Testing write_driver_array for columns=8, word_size=8, write_size=4")
|
debug.info(2, "Testing write_driver_array for columns=8, word_size=8, write_size=4")
|
||||||
|
|
@ -36,19 +36,19 @@ class write_driver_test(openram_test):
|
||||||
self.local_check(a)
|
self.local_check(a)
|
||||||
|
|
||||||
# check write driver array for multi-port
|
# check write driver array for multi-port
|
||||||
# OPTS.bitcell = "pbitcell"
|
OPTS.bitcell = "pbitcell"
|
||||||
# OPTS.num_rw_ports = 1
|
OPTS.num_rw_ports = 1
|
||||||
# OPTS.num_w_ports = 0
|
OPTS.num_w_ports = 0
|
||||||
# OPTS.num_r_ports = 0
|
OPTS.num_r_ports = 0
|
||||||
#
|
|
||||||
# factory.reset()
|
factory.reset()
|
||||||
# debug.info(2, "Testing write_driver_array for columns=8, word_size=8, write_size=4 (multi-port case)")
|
debug.info(2, "Testing write_driver_array for columns=8, word_size=8, write_size=4 (multi-port case)")
|
||||||
# a = factory.create(module_type="write_driver_array", columns=8, word_size=8, write_size=4)
|
a = factory.create(module_type="write_driver_array", columns=8, word_size=8, write_size=4)
|
||||||
# self.local_check(a)
|
self.local_check(a)
|
||||||
#
|
|
||||||
# debug.info(2, "Testing write_driver_array for columns=16, word_size=8, write_size=4 (multi-port case)")
|
debug.info(2, "Testing write_driver_array for columns=16, word_size=8, write_size=4 (multi-port case)")
|
||||||
# a = factory.create(module_type="write_driver_array", columns=16, word_size=8, write_size=4)
|
a = factory.create(module_type="write_driver_array", columns=16, word_size=8, write_size=4)
|
||||||
# self.local_check(a)
|
self.local_check(a)
|
||||||
|
|
||||||
globals.end_openram()
|
globals.end_openram()
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue