soc/interconnect/stream: BufferizeEndpoints params
BufferizeEndpoints params now includes parameters which to pipeline the valid/data or ready path
This commit is contained in:
parent
ff67781f11
commit
91e1e53662
|
@ -985,7 +985,7 @@ class Pipeline(Module):
|
||||||
|
|
||||||
# Add buffers on Endpoints (can be used to improve timings)
|
# Add buffers on Endpoints (can be used to improve timings)
|
||||||
class BufferizeEndpoints(ModuleTransformer):
|
class BufferizeEndpoints(ModuleTransformer):
|
||||||
def __init__(self, endpoint_dict):
|
def __init__(self, endpoint_dict, pipe_valid=True, pipe_ready=False):
|
||||||
self.endpoint_dict = endpoint_dict
|
self.endpoint_dict = endpoint_dict
|
||||||
|
|
||||||
def transform_instance(self, submodule):
|
def transform_instance(self, submodule):
|
||||||
|
@ -993,13 +993,20 @@ class BufferizeEndpoints(ModuleTransformer):
|
||||||
endpoint = getattr(submodule, name)
|
endpoint = getattr(submodule, name)
|
||||||
# add buffer on sinks
|
# add buffer on sinks
|
||||||
if direction == DIR_SINK:
|
if direction == DIR_SINK:
|
||||||
buf = Buffer(endpoint.description)
|
buf = Buffer(
|
||||||
|
endpoint.description,
|
||||||
|
pipe_valid=pipe_valid,
|
||||||
|
pipe_ready=pipe_ready
|
||||||
|
)
|
||||||
submodule.submodules += buf
|
submodule.submodules += buf
|
||||||
setattr(submodule, name, buf.sink)
|
setattr(submodule, name, buf.sink)
|
||||||
submodule.comb += buf.source.connect(endpoint)
|
submodule.comb += buf.source.connect(endpoint)
|
||||||
# add buffer on sources
|
# add buffer on sources
|
||||||
elif direction == DIR_SOURCE:
|
elif direction == DIR_SOURCE:
|
||||||
buf = Buffer(endpoint.description)
|
buf = Buffer(endpoint.description,
|
||||||
|
pipe_valid=pipe_valid,
|
||||||
|
pipe_ready=pipe_ready
|
||||||
|
)
|
||||||
submodule.submodules += buf
|
submodule.submodules += buf
|
||||||
submodule.comb += endpoint.connect(buf.sink)
|
submodule.comb += endpoint.connect(buf.sink)
|
||||||
setattr(submodule, name, buf.source)
|
setattr(submodule, name, buf.source)
|
||||||
|
|
Loading…
Reference in New Issue