1.1.1. Altera® AXI4 Memory-Mapped Specification Support
1.1.2. Altera® AXI4 Memory-Mapped BFM Components
1.1.3. Altera® AXI4 Memory-Mapped Supported Features
1.1.4. Altera® AXI4 Memory-Mapped BFM SystemVerilog Packages
1.1.5. Altera® AXI4 Memory-Mapped BFM Supported Flows
1.1.6. Altera® AXI4 Memory-Mapped BFM Supported Simulators
1.3.1. Altera® AXI4 Memory-Mapped Manager BFM Configuration
1.3.2. Altera® AXI4 Memory-Mapped Manager BFM Interface
1.3.3. Altera® AXI4 Memory-Mapped Subordinate BFM Configuration
1.3.4. Altera® AXI4 Memory-Mapped Subordinate BFM Interface
1.3.5. Altera® AXI4-Lite Memory-Mapped Manager BFM Configuration
1.3.6. Altera® AXI4-Lite Memory-Mapped Manager BFM Interface
1.3.7. Altera® AXI4-Lite Memory-Mapped Subordinate BFM Configuration
1.3.8. Altera® AXI4-Lite Memory-Mapped Subordinate BFM Interface
1.3.9. Altera® AXI4 Memory-Mapped Inline Monitor Configuration
1.3.10. Altera® AXI4 Inline Monitor Interface
1.4.1. Using the Altera® AXI4 Memory-Mapped Manager BFM Flow
1.4.2. Using the Altera® AXI4 Memory-Mapped Subordinate BFM Flow
1.4.3. Using the Altera® AXI4 Memory-Mapped Monitor BFM Flow
1.4.4. Altera® AXI4 Memory-Mapped Manager RTL Implementation Example
1.4.5. Altera® AXI4 Memory-Mapped Manager Platform Designer BFM Implementation Example
1.5.1. Altera® AXI4 Memory-Mapped BFM Configuration API
1.5.2. Altera® AXI4 Memory-Mapped BFM Reset API
1.5.3. Altera® AXI4 Memory-Mapped Manager Transaction Creation API
1.5.4. Altera® AXI4 Memory-Mapped Subordinate Transaction Creation API
1.5.5. Altera® AXI4 Memory-Mapped Transaction Configuration API
1.5.6. Altera® AXI4 Memory-Mapped BFM Transaction Execution API
1.5.7. Altera® AXI4 Memory-Mapped Host Memory API
2.5.1.2.1. Class Axi4StreamBytes
2.5.1.2.2. Data Members in Axi4StreamBytes Class
2.5.1.2.3. Methods in Axi4StreamBytes Class
2.5.1.2.4. Class Axi4StreamBytesData
2.5.1.2.5. Methods in Axi4StreamBytesData Class
2.5.1.2.6. Class Axi4StreamBytesPosition
2.5.1.2.7. Methods in Axi4StreamBytesPosition Class
2.5.1.2.8. Class Axi4StreamBytesNull
2.5.1.2.9. Methods in Axi4StreamBytesNull Class
2.5.1.2.10. Class Axi4StreamBytesDataError
2.5.1.2.11. Data Members in Axi4StreamBytesDataError Class
2.5.1.2.12. Methods in Class Axi4StreamBytesDataError
2.5.1.2.13. Class Axi4StreamBytesPositionError
2.5.1.2.14. Data Members in Class Axi4StreamBytesPositionError
2.5.1.2.15. Methods in Class Axi4StreamBytesPositionError
2.5.1.2.16. Class Axi4StreamBytesNullError
2.5.1.2.17. Data Members in Class Axi4StreamBytesNullError
2.5.1.2.18. Methods in Class Axi4StreamBytesNullError
2.5.1.1.3. Interface axi4_stream_if
The axi4_stream_if AXI4 streaming interface is for use as the port to the both the Transmitter and Receiver BFMs.
AXI4 Streaming Interface
interface axi4_stream_if #( parameter AXI4_STREAMING_DATA_BUS_WIDTH = 32, parameter AXI4_STREAMING_TID_WIDTH = 12, parameter AXI4_STREAMING_TDEST_WIDTH = 12, parameter AXI4_STREAMING_TUSER_WIDTH = 12 )( input wire clk, input wire rst_n );
The interface definition begins with four parameters that are passed to the axi4_stream_if interface.
Specify the AXI4_STREAMING_DATA_BUS_WIDTH data bus width parameter in bytes to provide the width required for the TDATA signal on the bus. The bus has a default width of 32 bytes or 256 bits.
AXI4_STREAMING_TID_WIDTH and AXI4_STREAMING_TDEST_WIDTH provide the Source and Destination IDs width parameters for the bus TID and TDEST signals, respectively. The default values are set at their maximum width of 12 bits each.
AXI4_STREAMING_TUSER_WIDTH provides the TUSER width parameter. The width of TUSER is per data byte, and calculated by:
AXI4_STREAMING_DATA_BUS_WIDTH * AXI4_STREAMING_TUSER_WIDTH
This calculation is to align with the AMBA AXI4-Stream Protocol Specification that specifies the width of this field is an integer multiple of AXI4_STREAMING_DATA_BUS_WIDTH (bytes), allowing TUSER values on a per-byte basis.7
7 AMBA AXI4-Stream Protocol Specification, ARM IHI0051B ID040921.