2015-02-10 09:11:06 -05:00
|
|
|
from collections import OrderedDict
|
|
|
|
|
2015-02-28 03:02:28 -05:00
|
|
|
from misoclib.com.liteeth.common import *
|
|
|
|
from misoclib.com.liteeth.generic import *
|
2015-02-10 09:11:06 -05:00
|
|
|
|
2015-04-13 04:20:02 -04:00
|
|
|
|
2015-02-10 09:11:06 -05:00
|
|
|
class LiteEthCrossbar(Module):
|
2015-04-13 03:53:43 -04:00
|
|
|
def __init__(self, master_port, dispatch_param):
|
|
|
|
self.users = OrderedDict()
|
|
|
|
self.master = master_port(8)
|
|
|
|
self.dispatch_param = dispatch_param
|
2015-02-10 09:11:06 -05:00
|
|
|
|
2015-04-13 03:53:43 -04:00
|
|
|
# overload this in derived classes
|
|
|
|
def get_port(self, *args, **kwargs):
|
|
|
|
pass
|
2015-02-10 09:11:06 -05:00
|
|
|
|
2015-04-13 03:53:43 -04:00
|
|
|
def do_finalize(self):
|
|
|
|
# TX arbitrate
|
|
|
|
sinks = [port.sink for port in self.users.values()]
|
|
|
|
self.submodules.arbiter = Arbiter(sinks, self.master.source)
|
2015-02-10 09:11:06 -05:00
|
|
|
|
2015-04-13 03:53:43 -04:00
|
|
|
# RX dispatch
|
|
|
|
sources = [port.source for port in self.users.values()]
|
2015-04-13 07:02:04 -04:00
|
|
|
self.submodules.dispatcher = Dispatcher(self.master.sink,
|
|
|
|
sources,
|
|
|
|
one_hot=True)
|
2015-04-13 03:53:43 -04:00
|
|
|
cases = {}
|
|
|
|
cases["default"] = self.dispatcher.sel.eq(0)
|
|
|
|
for i, (k, v) in enumerate(self.users.items()):
|
|
|
|
cases[k] = self.dispatcher.sel.eq(2**i)
|
|
|
|
self.comb += \
|
|
|
|
Case(getattr(self.master.sink, self.dispatch_param), cases)
|