mirror of
https://github.com/enjoy-digital/liteeth.git
synced 2025-01-03 03:43:37 -05:00
test_stream: allow premature stopping of the stream_collector
Support passing a stop_cond function which can cause the stream_collector to exit on a user-defined condition. Signed-off-by: Leon Schuermann <leon@is.currently.online>
This commit is contained in:
parent
ea0a65d357
commit
23ab5d2eb7
1 changed files with 9 additions and 0 deletions
|
@ -187,6 +187,7 @@ def stream_collector(
|
|||
source,
|
||||
dest=[],
|
||||
expect_npackets=None,
|
||||
stop_cond=None,
|
||||
seed=42,
|
||||
ready_rand=50,
|
||||
debug_print=False):
|
||||
|
@ -194,6 +195,10 @@ def stream_collector(
|
|||
`source`. If `source` has a `last_be` signal, that is respected
|
||||
properly.
|
||||
|
||||
`stop_cond` can be passed a function which is invoked whenever the
|
||||
collector has a chance to cease operations (when a packet has been
|
||||
fully read). If when invoked it returns true, this function will
|
||||
exit.
|
||||
"""
|
||||
|
||||
prng = random.Random(seed)
|
||||
|
@ -219,6 +224,10 @@ def stream_collector(
|
|||
|
||||
# Loop for collecting individual packets, separated by source.last
|
||||
while expect_npackets == None or len(dest) < expect_npackets:
|
||||
if stop_cond is not None:
|
||||
if stop_cond():
|
||||
break
|
||||
|
||||
# Buffer for the current packet
|
||||
collected_bytes = []
|
||||
param_signal_states = {}
|
||||
|
|
Loading…
Reference in a new issue