mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
soc/interconnect: add avalon with converters to/from native streams
This commit is contained in:
parent
d860eeea4f
commit
a92e90b215
1 changed files with 38 additions and 0 deletions
38
litex/soc/interconnect/avalon.py
Normal file
38
litex/soc/interconnect/avalon.py
Normal file
|
@ -0,0 +1,38 @@
|
|||
from migen import *
|
||||
|
||||
from litex.soc.interconnect import stream
|
||||
|
||||
# AvalonST to/from Native --------------------------------------------------------------------------
|
||||
|
||||
class Native2AvalonST(Module):
|
||||
def __init__(self, layout, latency=2):
|
||||
self.sink = sink = stream.Endpoint(layout)
|
||||
self.source = source = stream.Endpoint(layout)
|
||||
|
||||
# # #
|
||||
|
||||
_from = sink
|
||||
for n in range(latency):
|
||||
_to = stream.Endpoint(layout)
|
||||
self.sync += _from.connect(_to, omit={"ready"})
|
||||
if n == 0:
|
||||
self.sync += _to.valid.eq(sink.valid & source.ready)
|
||||
_from = _to
|
||||
self.comb += _to.connect(source, omit={"ready"})
|
||||
self.comb += sink.ready.eq(source.ready)
|
||||
|
||||
|
||||
class AvalonST2Native(Module):
|
||||
def __init__(self, layout, latency=2):
|
||||
self.sink = sink = stream.Endpoint(layout)
|
||||
self.source = source = stream.Endpoint(layout)
|
||||
|
||||
# # #
|
||||
|
||||
buf = stream.SyncFIFO(layout, max(latency, 4))
|
||||
self.submodules += buf
|
||||
self.comb += [
|
||||
sink.connect(buf.sink, omit={"ready"}),
|
||||
sink.ready.eq(source.ready),
|
||||
buf.source.connect(source)
|
||||
]
|
Loading…
Reference in a new issue