Skip to content

Commit

Permalink
asmicon: simple selector option
Browse files Browse the repository at this point in the history
  • Loading branch information
Sebastien Bourdeauducq committed Jul 13, 2012
1 parent 768a3a8 commit 6073f68
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 21 deletions.
4 changes: 2 additions & 2 deletions milkymist/asmicon/__init__.py
Expand Up @@ -20,7 +20,7 @@ def __init__(self, bank_a, row_a, col_a):
self.mux_a = max(row_a, col_a)

class TimingSettings:
def __init__(self, tRP, tRCD, tWR, tREFI, tRFC, CL, rd_delay, slot_time, read_time, write_time):
def __init__(self, tRP, tRCD, tWR, tREFI, tRFC, CL, rd_delay, read_time, write_time, slot_time=0):
self.tRP = tRP
self.tRCD = tRCD
self.tWR = tWR
Expand All @@ -30,9 +30,9 @@ def __init__(self, tRP, tRCD, tWR, tREFI, tRFC, CL, rd_delay, slot_time, read_ti
self.CL = CL
self.rd_delay = rd_delay

self.slot_time = slot_time
self.read_time = read_time
self.write_time = write_time
self.slot_time = slot_time

class ASMIcon:
def __init__(self, phy_settings, geom_settings, timing_settings):
Expand Down
62 changes: 44 additions & 18 deletions milkymist/asmicon/bankmachine.py
Expand Up @@ -46,9 +46,46 @@ def __init__(self, slicer, bankn, slots):
self.adr = Signal(self.slots[0].adr.bv)
self.we = Signal()

# derived classes should drive rr.request
self.rr = RoundRobin(self.nslots, SP_CE)

def get_fragment(self):
comb = []
rr = self.rr

# Multiplex
state = Signal(BV(2))
comb += [
state.eq(Array(slot.state for slot in self.slots)[rr.grant]),
self.adr.eq(Array(slot.adr for slot in self.slots)[rr.grant]),
self.we.eq(Array(slot.we for slot in self.slots)[rr.grant]),
self.stb.eq(
(self.slicer.bank(self.adr) == self.bankn) \
& (state == SLOT_PENDING)),
rr.ce.eq(self.ack),
self.tag.eq(rr.grant)
]
comb += [If((rr.grant == i) & self.stb & self.ack, slot.process.eq(1))
for i, slot in enumerate(self.slots)]

return Fragment(comb) + rr.get_fragment()

class _SimpleSelector(_Selector):
def get_fragment(self):
comb = []
for i, slot in enumerate(self.slots):
comb.append(self.rr.request[i].eq(
(self.slicer.bank(slot.adr) == self.bankn) & \
(slot.state == SLOT_PENDING)
))

return Fragment(comb) + super().get_fragment()

class _FullSelector(_Selector):
def get_fragment(self):
comb = []
sync = []
rr = self.rr

# List outstanding requests for our bank
outstandings = []
Expand Down Expand Up @@ -112,22 +149,7 @@ def get_fragment(self):
select_stmt = If(has_mature, *best_mature).Else(select_stmt)
comb.append(select_stmt)

# Multiplex
state = Signal(BV(2))
comb += [
state.eq(Array(slot.state for slot in self.slots)[rr.grant]),
self.adr.eq(Array(slot.adr for slot in self.slots)[rr.grant]),
self.we.eq(Array(slot.we for slot in self.slots)[rr.grant]),
self.stb.eq(
(self.slicer.bank(self.adr) == self.bankn) \
& (state == SLOT_PENDING)),
rr.ce.eq(self.ack),
self.tag.eq(rr.grant)
]
comb += [If((rr.grant == i) & self.stb & self.ack, slot.process.eq(1))
for i, slot in enumerate(self.slots)]

return Fragment(comb, sync) + rr.get_fragment()
return Fragment(comb, sync) + super().get_fragment()

class _Buffer:
def __init__(self, source):
Expand Down Expand Up @@ -156,12 +178,13 @@ def get_fragment(self):
return Fragment(comb, sync)

class BankMachine:
def __init__(self, geom_settings, timing_settings, address_align, bankn, slots):
def __init__(self, geom_settings, timing_settings, address_align, bankn, slots, full_selector=False):
self.geom_settings = geom_settings
self.timing_settings = timing_settings
self.address_align = address_align
self.bankn = bankn
self.slots = slots
self.full_selector = full_selector

self.refresh_req = Signal()
self.refresh_gnt = Signal()
Expand All @@ -174,7 +197,10 @@ def get_fragment(self):

# Sub components
slicer = _AddressSlicer(self.geom_settings, self.address_align)
selector = _Selector(slicer, self.bankn, self.slots)
if self.full_selector:
selector = _FullSelector(slicer, self.bankn, self.slots)
else:
selector = _SimpleSelector(slicer, self.bankn, self.slots)
buf = _Buffer(selector)

# Row tracking
Expand Down
1 change: 0 additions & 1 deletion top.py
Expand Up @@ -42,7 +42,6 @@ def ns(t, margin=True):
CL=3,
rd_delay=4,

slot_time=16,
read_time=32,
write_time=16
)
Expand Down

0 comments on commit 6073f68

Please sign in to comment.