Generator

Stream generators.

class torii_usb.stream.generator.ConstantStreamGenerator(*args: Any, src_loc_at: int = 0, **kwargs: Any)

Gateware that generates stream of constant data.

Attributes:
  • start (Signal(), input) – Strobe that indicates when the stream should be started.

  • done (Signal(), output) – Strobe that pulses high when we’re finishing a transmission.

  • start_position (Signal(range(len(data)), input) – Specifies the starting position in the constant stream; applied when start() is pulsed.

  • max_length (Signal(max_length_width), input) – The maximum length to be sent -in bytes-. Defaults to the length of the stream. Only present if the max_length_width parameter is provided on creation.

  • output_length (Signal(max_length_width), output) – Indicates the actual data length for the stream currently being output. Will always be the lesser of our data length and :attr:max_length. Only present if the max_length_width parameter is provided on creation.

  • stream (stream_type(), output stream) – The generated stream interface.

Parameters:
  • constant_data (bytes, or equivalent) – The constant data for the stream to be generated. Should be an iterable of integers; or, if data_width is divisible by 8, a bytes-like object.

  • domain (str) – The clock domain this generator should belong to. (default: ‘sync’)

  • stream_type (StreamInterface, or subclass) – The type of stream we’ll be multiplexing.

  • data_width (int | None) – The width of the constant payload. If not provided; will be taken from the stream’s payload width. (default: None)

  • max_length_width (int | None) – If provided, a max_length signal will be present that can limit the total length transmitted. (default: None)

  • data_endianness ('little' | 'big') – If bytes are provided, and our data width is greater. (default: ‘little’)

class torii_usb.stream.generator.StreamSerializer(*args: Any, src_loc_at: int = 0, **kwargs: Any)

Gateware that serializes a short Array input onto a stream.

I/O port:

I: start – Strobe that indicates when the stream should be started. O: done – Strobe that pulses high when we’re finishing a transmission.

I: data[] – The data stream to be sent out. Length is set by the data_length initializer argument. I: max_length[] – The maximum length to be sent. Defaults to the length of the stream.

Only present if the max_length_width parameter is provided on creation.

*: stream – The generated stream interface.