Visible to Intel only — GUID: zhu1600487489821
Ixiasoft
Visible to Intel only — GUID: zhu1600487489821
Ixiasoft
7.3. RX MAC Avalon ST Aligned Client Interface
The F-Tile Ethernet Intel® FPGA Hard IP RX client interface in MAC+PCS variations employs the Avalon® streaming interface protocol. The Avalon® streaming interface protocol is a synchronous point-to-point, unidirectional interface that connects the producer of a data stream (source) to a consumer of data (sink). The key properties of this interface include:
- Start of packet (SOP) and end of packet (EOP) signals delimit frame transfers.
- The SOP must always be in the MSB, simplifying the interpretation and processing of data you receive on this interface.
- A valid signal qualifies signals from source to sink.
The RX MAC acts as a source and the client acts as a sink in the receive direction.
Name |
Width |
Description |
---|---|---|
o_rx_data[511:0] o_rx_data[127:0] o_rx_data[63:0] |
512 bits (100GE) 128 bits (50GE/40GE) 64 bits (25GE/10GE) |
Output data to the MAC when the rate is 10GE/25/40GE/50GE/100GE. Bits 0 is the LSB. |
o_rx_valid |
1 bit | When asserted, indicates that RX data is valid. Only valid between the SOP and EOP signals. This signal might be deasserted between the assertion of the SOP and EOP signals. |
o_rx_empty[5:0] o_rx_empty[3:0] o_rx_empty[2:0] |
6 bits (100GE) 4 bits (50GE/40GE) 3 bits (10GE/25GE) |
Indicates the number of empty bytes on the RX data signal when EOP signal is asserted, starting from the least significant byte (LSB). |
o_rx_startofpacket |
1 bit | When asserted, indicates that the RX data signal holds the first clock cycle of data in a packet (start of packet). The IP core asserts this signal for only a single clock cycle for each packet. When the SOP signal is asserted, the MSB of the RX data signal drives the start of packet. |
o_rx_endofpacket |
1 bit | When asserted, indicates that the RX data signal holds the final clock cycle of data in a packet (end of packet). The IP core asserts this signal for only a single clock cycle for each packet. In the case of an undersized frame or in the case of a frame that is exactly 64 bytes long, the SOP and EOP signals might be asserted in the same clock cycle. |
o_rx_error[5:0] |
6 bits | Reports certain types of errors in the Ethernet frame whose contents are currently being transmitted on the client interface. This signal is valid in EOP cycles only. The individual bits report different types of errors:
|
o_rxstatus_valid |
1 bit | When asserted, indicates that o_rxstatus_data is driving valid data. |
o_rxstatus_data[39:0] |
40 bits | Specifies information about the received frame. The following fields are defined:
|
o_rx_preamble[63:0] |
64 bits | Reads the preamble value of an RX frame. This signal is valid when the o_rx_valid and the o_rx_startofpacket signals are asserted.
This signal is only available when you turn on Preamble Passthrough in the parameter editor for 40GE/50GE channels.
Note: For preamble passthrough with other rates, use the first eight bytes of the o_rx_data signal.
|
i_rx_serial[3:0] |
4 bits | Input RX serial transceiver signal to connect from RX pins on board to RX serial pins on the transceiver for lane reverse ordering. |
The figure above shows how to receive data using the RX MAC Avalon ST client interface. The interface complies with the Avalon® streaming interface specification.
- Packets always start on the MSB of o_rx_data (SOP aligned).
- When the frame ends, o_rx_empty is set to the number of unused bytes in o_rx_data, starting from the right (byte 0).
- In this example, o_rx_data on the last cycle of the packet has 5 empty bytes.
- The minimum number of bytes on the last cycle is 1.
- The framing and data ports are only valid when o_rx_data is high.