This section describes the transaction viewing features specific to AXI-MM protocol instances. A protocol instance of an AXI-MM interface appears in the wave window with a wave object hierarchy as shown in the following figure.
Understanding the Top Summary Row
The top of the wave object hierarchy of an AXI-MM protocol instance is the top summary row. This transaction waveform shows the overall read and write activity of an AXI interface based on the following rules:
- If one or more AXI read transactions are in progress, the top summary shows a Read transaction bar in purple color.
- If one or more AXI write transactions are in progress, the top summary shows a Write transaction bar in pink color.
- If one or more of AXI read and write transactions are in progress, the top summary shows Read/Write transaction bar in teal color.
An AXI transaction is an abstract concept not to be confused with the graphical transaction bar. It is a complete data exchange carried out using AXI signaling including the Address, Data, and optionally Response phases.
Understanding the Outstanding Reads and Outstanding Writes Rows
There are a group of outstanding AXI read transactions and a group of write
transactions located under the top of the wave object hierarchy of an AXI-MM
protocol instance. An AXI transaction is known as outstanding if the interface
master has raised A*VALID
or WVALID
but the last
data phase or optionally response phase has not yet completed. The outstanding reads
row shows the current count of outstanding AXI read transactions or is inactive
(shown as a thin line) to indicate zero outstanding AXI read transactions.
Similarly, the outstanding writes row shows the current count of outstanding AXI
write transactions or is inactive to indicate zero outstanding AXI write
transactions.
Understanding the Transaction Summary Rows
There is a set of transaction summary rows under each outstanding read and write row labeled as Row <n>, where <n> is an integer. A transaction summary is a transaction bar that depicts a single AXI transaction starting at the first phase and ending at the last phase of an AXI transaction. The assignment of a transaction summary to a specific numbered row conveys no special meaning. Instead, it prevents overlapping of multiple outstanding AXI transactions in the same row.
Each transaction summary is labeled with a sequence number. The first AXI transaction has a sequence number of 1, the second AXI transaction has a sequence number of 2, and so forth. The progression of sequence numbers for reads and writes are separate from each other and from the AXI transactions of all other protocol instances. For example, a particular protocol instance can have an AXI read transaction with the sequence number 16 and a separate AXI write transaction with the sequence number 16.
Understanding Channel Rows
The channels wave object group is collapsed by default. When you expand the group, you see logic signals for the AXI interface clock and reset (if present) and one transaction row for each AXI channel present in the interface.
Each channel row shows a transaction bar summarizing individual handshakes of that AXI channel from VALID to READY, except that the multiple contiguous data beats of the same AXI transaction appear as a single transaction bar. To visually tie all channel transaction bars of an AXI transaction together, each channel transaction bar is tagged with the same sequence number as the corresponding transaction summary. You can expand the channel row to show key AXI signals for that channel.
When you hover over any channel transaction bar, association, or transaction summary using your mouse, a tool tip appears showing the values of the informational AXI address channel signals from the address phase of the AXI transaction.
When you select a channel transaction bar, associations appear for all channel transaction bars participating in the same AXI transaction as the selected transaction bar. You can click the tails of the association arrows to follow the progress of the AXI transaction from address phase through response phase. The chain of associations always begins with the address phase transaction even if the data phase precedes the address phase.
Error Conditions
If there is a handshaking error on the interface, you may see a sequence number on a channel transaction consisting of a string of all 9s. This sequence number indicates that the data and/or response phases could not be matched with an address and/or data phase. Common causes are mismatched read/write ID tags and the protocol analyzer being held in reset (ARESET or ARESETn signal active) while the AXI phases are in progress.