litex/misoclib/mem/litesata/frontend/arbiter.py

31 lines
1,019 B
Python
Raw Normal View History

from misoclib.mem.litesata.common import *
from misoclib.mem.litesata.frontend.common import *
2015-01-14 03:19:41 -05:00
from migen.genlib.roundrobin import *
2015-04-13 09:12:39 -04:00
2015-01-16 17:52:41 -05:00
class LiteSATAArbiter(Module):
def __init__(self, users, master):
self.rr = RoundRobin(len(users))
self.submodules += self.rr
self.grant = self.rr.grant
cases = {}
for i, slave in enumerate(users):
sink, source = slave.sink, slave.source
start = Signal()
done = Signal()
ongoing = Signal()
self.comb += [
start.eq(sink.stb & sink.sop),
done.eq(source.stb & source.last & source.eop & source.ack)
]
self.sync += \
If(start,
ongoing.eq(1)
).Elif(done,
ongoing.eq(0)
)
self.comb += self.rr.request[i].eq((start | ongoing) & ~done)
cases[i] = [users[i].connect(master)]
self.comb += Case(self.grant, cases)