



# Efficient Debug Strategies for PCIe Gen6 Verification Using Verification IP (VIP)

Satish Kumar Padhi  
(Cadence Design Systems)

**cadence**<sup>®</sup>

**accellera**  
SYSTEMS INITIATIVE

# Abstract

PCI Express Gen6 (PCIe® 6.0/6.1) introduces significant complexity with new features such as FLIT mode, 64GT/s PAM4 signaling, and enhanced protocols, making verification and debug extremely challenging. This paper presents an efficient debug methodology for complex PCIe® Gen6 designs using Cadence's PCIe Gen6 Verification IP (VIP). We focus on two key aspects: leveraging the VIP's built-in protocol checking capabilities and utilizing trace file logs to streamline debug and analysis. The proposed approach embeds Cadence VIP as a smart agent in the testbench to automatically flag specification violations across transaction, data link, and physical layers. When issues arise, a user can utilize detailed trace files generated by the VIP to quickly pinpoint protocol errors and timing mismatches. We will demonstrate how this combination of proactive protocol checks and trace-driven debugging accelerates root-cause analysis in a PCIe Gen6 environment. Our strategy enables faster identification of FLIT format errors and credit exhaustion, reducing debug time by a significant margin. The results show improved verification efficiency, thorough coverage of PCIe 6.0 features, and insights that can be applied to other complex interface protocols. Overall, the methodology benefits teams facing advanced PCIe verification by ensuring robust, compliance-checked designs with a streamlined debug cycle.

# Agenda

- **Introduction**
  - Brief overview of PCIe® Gen6
  - FLIT Mode in TL and DL
- **PCIe DUT Verification with Passive VIP Monitor**
  - Architecture and setup
  - Benefits of Smart Passive Monitoring Agent
- **Efficient Error Messages for Debugging**
  - Designing meaningful error messages
  - Real-world examples and impact
- **Robust Callbacks and Error Injection Approach**
  - Callback mechanisms
  - Error injection strategies for corner-case validation
- **Extensive Debug Info Support**
  - Extend of debug information
- **Smart and Efficient Debugging with Waveforms**
  - Waveform-based debugging techniques
  - Tools and tips for faster traceability
- **Enhancing Debugging by Tracking Packets**
  - Packet-level tracking methodology
  - Correlation with protocol events
- **Automated Result Debug**
  - Automation scripts and frameworks
  - Reducing manual effort in debug cycles
- **Conclusion**
  - Summary of key takeaways
- **Q&A / Discussion**
  - Open floor for questions and feedback

# PCIe Gen6 Update (Basic)

- All prior major revisions of PCIe® doubled its bandwidth by doubling the frequency with which bits were sent. For PCIe 6.0, instead of trying to double the signaling rate, it doubles the amount of data sent per unit interval with **1b/1b encoding**.
- Fixed-sized **Flits** (256B) were chosen to enable **Forward Error Correction** (FEC) to be added without drastically increasing latency and complexity.
- One or more TLPs can be held within a Flit, and a single TLP may span across multiple Flits (based on max payload size and start location within the Flit)
- The **Ack/Nak protocol** and retry mechanisms are on the Flit level and not the TLP level.
- Flit Mode introduces the idea of dedicated receive buffers and **shared receive buffers**
- When performing the Tx EQ process for the 64GT/s data rate, **TS0** ordered sets are used in Phase 0, Phase 1, and in the upstream direction during Phase 2

# FLIT Mode Representation

Table 4-10 Flit Layout in a x16 Link §

| Description | Lane     |          |          |          |          |          |          |          |          |          |     |             |             |             |             |             |
|-------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----|-------------|-------------|-------------|-------------|-------------|
|             | 0        | 1        | 2        | 3        | 4        | 5        | 6        | 7        | 8        | 9        | 10  | 11          | 12          | 13          | 14          | 15          |
| ONE FLIT    | 0        | 1        | 2        | 3        | 4        | 5        | 6        | 7        | 8        | 9        | 10  | 11          | 12          | 13          | 14          | 15          |
|             | 16       | 17       | 18       | 19       | 20       | 21       | 22       | 23       | 24       | 25       | 26  | 27          | 28          | 29          | 30          | 31          |
|             | 32       | 33       | 34       | 35       | 36       | 37       | 38       | 39       | 40       | 41       | 42  | 43          | 44          | 45          | 46          | 47          |
|             | 48       | 49       | 50       | 51       | 52       | 53       | 54       | 55       | 56       | 57       | 58  | 59          | 60          | 61          | 62          | 63          |
|             | 64       | 65       | 66       | 67       | 68       | 69       | 70       | 71       | 72       | 73       | 74  | 75          | 76          | 77          | 78          | 79          |
|             | 80       | 81       | 82       | 83       | 84       | 85       | 86       | 87       | 88       | 89       | 90  | 91          | 92          | 93          | 94          | 95          |
|             | 96       | 97       | 98       | 99       | 100      | 101      | 102      | 103      | 104      | 105      | 106 | 107         | 108         | 109         | 110         | 111         |
|             | 112      | 113      | 114      | 115      | 116      | 117      | 118      | 119      | 120      | 121      | 122 | 123         | 124         | 125         | 126         | 127         |
|             | 128      | 129      | 130      | 131      | 132      | 133      | 134      | 135      | 136      | 137      | 138 | 139         | 140         | 141         | 142         | 143         |
|             | 144      | 145      | 146      | 147      | 148      | 149      | 150      | 151      | 152      | 153      | 154 | 155         | 156         | 157         | 158         | 159         |
|             | 160      | 161      | 162      | 163      | 164      | 165      | 166      | 167      | 168      | 169      | 170 | 171         | 172         | 173         | 174         | 175         |
|             | 176      | 177      | 178      | 179      | 180      | 181      | 182      | 183      | 184      | 185      | 186 | 187         | 188         | 189         | 190         | 191         |
|             | 192      | 193      | 194      | 195      | 196      | 197      | 198      | 199      | 200      | 201      | 202 | 203         | 204         | 205         | 206         | 207         |
|             | 208      | 209      | 210      | 211      | 212      | 213      | 214      | 215      | 216      | 217      | 218 | 219         | 220         | 221         | 222         | 223         |
|             | 224      | 225      | 226      | 227      | 228      | 229      | 230      | 231      | 232      | 233      | 234 | 235         | DLP<br>0    | DLP<br>1    | DLP<br>2    | DLP<br>3    |
|             | DLP<br>4 | DLP<br>5 | CRC<br>0 | CRC<br>1 | CRC<br>2 | CRC<br>3 | CRC<br>4 | CRC<br>5 | CRC<br>6 | CRC<br>7 | [0] | ECC1<br>[0] | ECC0<br>[0] | ECC1<br>[1] | ECC2<br>[1] | ECC0<br>[1] |

Physical Layer adds CRC (8 bytes) and ECC (6 bytes)

Transaction layer adds TLP (236 Bytes).

Note: When TLP is absent in 236 bytes, it contains all zeros.

In FM, the basic unit of transfer is no longer packets, but is a fixed-sized (256B) Flit.

Data Link Layer adds DLP (6 Bytes).

# Non-Flit Mode vs Flit Mode as per DL

## **Non-Flit Mode**

- Data Link Layer adds CRC (4 bytes) and LCRC (2 bytes)
  - Ack/Nak DLLPs are transmitted by DL as per Ack/Nak Frequency
  - Sequence number size is 12 bytes and is used to track TLPs
  - Framing symbols are present in front of each TLP and DLLP

## Flit Mode

- No LCRC
  - CRC generation/checking has moved to the physical layer with much stronger protection and an 8-byte size. CRC covers TLP and DLP bytes  
ECRC is still a part of each TLP
  - DLLPs can be transmitted as part of Flit only
  - Ack/Nak DLLP encodings are not supported in FM. Rather, the information is accommodated in 6 DLP bytes present in Flit Mode. The replay command (as part of DLP bytes) holds the Ack/Nak information, and the sequence number is processed accordingly. The concept of Ack/Nak Protocol is the same
  - Apart from the Standard Nak, **Selective Nak** is new and requesting a replay of Single Flit
  - Sequence number size is 10 bytes and is used to track Payload Flits only (not tracking TLPs)
  - Traditional Flow credits are termed Dedicated Credits
  - New Flow credits are introduced as **Shared Credits**
  - No framing symbols

Shows NOP Flit shows Zero means No TLP is present, Replay command as ACK with ACK's Sequence number and NEW DLLP Optimized Update FC

## Snippet from VIP Trace Debug Print:

# Trace File Debug on FLIT Structure



# DL FLIT and PL FLIT Debug Representation

# IDLE FLIT (Logical Idle)

```
4 H Debug: [port_0] PL_TX_end_packet PlFlit(LogicalIdle) Seq={usage : 0, prior : 0, cmd : Explicit, num : 0}
DllpPayload={0x00000000} (256 bytes) (CRC=0x0000000000000000 ECC_0=0x0000 ECC_1=0x0000
ECC_2=0x0000 ) {00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}
```

# PCIE DUT Verification with VIP MON



# Efficient Error Messages for Debugging

To enable users to identify the root cause of errors unambiguously, PCIe® GEN6 VIP error messages should include the following structured information:

- **Error Context – What Happened?**  
Clearly describe the event or condition that triggered the error
- **Root Cause – Why Did It Happen?**  
Provide a concise explanation of the underlying reason for the error
- **Debug Guidance – How to Proceed?**  
Suggest actionable steps or a recommended approach to debug and resolve the issue
- **Specification Reference**  
Include direct references to the **PCIe® Base Specification**, along with the **version details**, to support a deeper investigation

# Continued...

- **Relevant Data Checks**

Highlight key data points to verify, such as:

- Configuration settings
- Register values
- Pin states

- **Direction Details**

Specify the data flow direction involved in the error:

**Tx (Transmit) or Rx (Receive)**

- **Protocol Layer Information**

Indicate the relevant **protocol layer**, **port**, and **lane** involved, as observed inside the checker

- **Debug Hint**

Provide a helpful hint or insight that can accelerate the debugging process

# PCIe Base Spec Reference on Error:

6.0-1.0-PUB — PCI Express® Base Specification Revision 6.0



## PCI Express® Base Specification Revision 6.0

16 December 2021

Copyright© 2002-2021 PCI-SIG

PCI-SIG disclaims all warranties and liability for the use of this document and the information contained herein and assumes no responsibility for any errors that may appear in this document, nor does PCI-SIG make a commitment to update the information contained herein.

This PCI Specification is provided "as is" without any warranties of any kind, including any warranty of merchantability, non-infringement, fitness for any particular purpose, or any warranty otherwise arising out of any proposal, specification, or sample. PCI-SIG disclaims all liability for infringement of proprietary rights, relating to use of information in this specification. This document itself may not be modified in any way, including by removing the copyright notice or references to PCI-SIG. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted herein. PCI, PCI Express, PCIe, and PCI-SIG are trademarks or registered trademarks of PCI-SIG. All other product names are trademarks, registered trademarks, or servicemarks of their respective owners.

- 357464433825 fs –  
C H Detected[cfg\_0\_0] [] PL\_LTSSM\_STATE [PCISIG]. [port\_0] LTSSM state L0 => Recovery.RcvrLock
- 357470575654 fs –  
C H Error: Detected[cfg\_0\_0] (TX) []  
**PL\_FLIT\_FEC\_ECC\_SINGLE\_BYTE\_ERROR** [PCISIG-PCIE 6.0 Rev 0.9]. [Port\_0] Detected Tx single byte error on group ECC\_0. Byte position 51, error value 0, corrected value 225.
- M \*Denali\* Error:  
<top.pipe\_mon.phy\_mon>@357470575654 fs ::  
Detected[cfg\_0\_0] (TX) []  
**PL\_FLIT\_FEC\_ECC\_SINGLE\_BYTE\_ERROR** [**PCISIG-PCIE 6.0 Rev 0.9**]. [Port\_0] Detected Tx single byte error on group ECC\_0. Byte position 51, error value 0, corrected value 225.

# Spec Reference Continued..

- 360647230375 fs –

6 H Error: Detected[cfg\_0\_0] (TX)

[] **TL\_FC\_SHARED\_CREDIT\_OVERFLOW [PCI SIG-PCIE 6.1 Section 2.6.1]**

[PCI SIG-PCIE 6.1 Section 2.6.1]. Port\_0: When advertising 128 allowed PH shared credits for VC 0, the sum of the shared credits across all VCs (128) should not be greater than what the current scale factor (0) can represent (127). Limiting allowed credits for the current VC to 124

\*Denali\* Error:

<uvm\_test\_top.m\_env.rcep[0].pcie\_agent.m\_vip\_agent>@15197.921 ns :: Detected[cfg\_0\_0] (TX)

[] **TL\_FC\_SHARED\_CREDIT\_INIT\_CPLD**

[PCISIG-PCIE 6.1 Section 2.6.1]. The sum of the shared InitFC value across all VCs (2080) is less than the minimum shared CPLD FC credit requirement (UNLIMITED). The number of enabled VCs: 1

6.1-1.0-PUB — PCI Express® Base Specification Revision 6.1

## 2.6.1 Flow Control (FC) Rules §

In this and other sections of this specification, rules are described using conceptual “registers” that a device could use in order to implement a compliant implementation. This description does not imply or require a particular implementation and is used only to clarify the requirements.

- Flow Control (FC) information is transferred using Flow Control Packets (FCPs), which are a type of DLLP (see § Section 3.5 ), and, in some cases, the Optimized\_Update\_FC.
- **FC Unit Size** indicates the number of DW covered by one flow control credit:
  - For Data, the FC Unit Size is 4 DW.
  - For Headers in Non-Flit Mode:
    - For Receivers that do not support TLP Prefixes, FC Unit Size is the sum of one maximum-size Header and TLP Digest.
    - For Receivers that support End-End TLP Prefixes, FC Unit Size is the sum of one maximum-size Header, TLP Digest, and the maximum number of End-End TLP Prefixes permitted in a TLP.
    - The management of FC for Receivers that support Local TLP Prefixes is dependent on the Local TLP Prefix type.
  - For Headers in Flit Mode:
    - For Switch Port Receivers, FC Unit Size is the sum of one maximum-size Base Header, OHC-A, OHC-B, OHC-C, OHC-E if supported, and one maximum-size TLP Trailer.
    - For Endpoint Upstream Port and Root Port Receivers, FC Unit Size is the sum of one Base Header of the largest supported size, OHC-A, OHC-B, OHC-C, OHC-E if supported, and one TLP Trailer of the largest size supported.
  - For NFM and for dedicated credits in FM, each Virtual Channel has independent FC.

# Spec Reference Continued...

3 H Error: Detected[cfg\_0\_0] (TX)

|| TL\_IDE\_INVALID\_LINK\_STREAM\_ID [PCISI]

G-PCIe IDE ECN Section 6.99.4]. [Port\_0]:

Detected non-Selective IDE pkt TLP for TC 2  
with StreamID 0 which is associated with TC 0.  
Discard incoming TLP.

\*Denali\* Error:

<uvm\_test\_top.sve.link\_env.dev\_env0.vip\_wrap\_  
env.pcie\_ep\_env.active\_bfm>@207.112 us ::  
Detected[cfg\_0\_0] (RX) []

TL\_IDE\_INVALID\_K\_BIT\_TOGGLING [PCISIG-]

PCIe IDE ECN Section 6.99.4]. [Port\_0]:

Detected Bit K toggled to 1 but KeySet 1 are  
invalid.

## 6.99.4 IDE TLPs

TLPs secured by IDE are called IDE TLPs. All IDE TLPs must use the IDE prefix (see Figure 7-17), and this prefix must precede all other End-End TLP prefixes.



Figure 7-17 IDE TLP Prefix

The IDE Prefix includes:

- M bit – When Set, indicates this TLP includes a MAC
  - When aggregation is not used, the M bit must be Set for all IDE TLPs.
  - Rules for the use of aggregation are given below.
- K bit – Indicates the key set used for this TLP
  - After Transmitting a TLP with the K bit toggled for any Sub-Stream, subsequent TLP Transmissions for different Sub-Streams of the same Stream must also use the new value for the K bit.
  - After receiving a TLP with the K bit toggled, the Receiver must transition to the new key and JV set for that TLP and all subsequent TLPs associated with the Sub-Stream, and must mark the old key and JV set invalid until reprogrammed.
    - Such transitions must not affect other Sub-Streams of the IDE Stream at the Receiver.
- T bit – When Set, indicates the TLP originated from within a trusted execution environment (see Section 6.99.1)
  - It is permitted for IDE TLPs to originate from both trusted and non-trusted execution environments, and the value of the T bit does not modify the handling of TLPs within IDE per se; the rules for trusted execution environments are not defined in this document.
  - The T bit must be Clear unless the use of the T bit has been explicitly defined by TEE management mechanisms outside the scope of this document.
- P bit – When Set, indicates the TLP includes PCRC.

# Efficient Debug Hint

- Error: Detected[cfg\_0\_0] (RX) [NONFATAL-UnsupportedRequest] TL\_ATS\_DEVID\_EN\_UR [PCISIG]. Translation Requests received as MWr\_64 from Device ID 0x301 are not supported by TA, as ATS is not enabled for the device
- **DEBUG\_HINT:** To avoid this error, set the ATS Control Register's Enable Bit in the DUT's PF. Test can do this by sending CfgWr packet as a front-door or by a backdoor DUT configuration on the ATS control register in config space. RC VIP shadow space will get updated with the actual value after it receives completion of the CfgRd packet from device ID 0x301

# Robust Callbacks and Error Inject Approach

- **Packet Manipulation and Error Injection**

- Modify specific fields within a packet to simulate various scenarios
- Discard packets intentionally to test system resilience
- Inject errors into packets after generation by the VIP but before transmission to the physical link

- **Data Synchronization and Verification**

- Synchronize transaction data between the VIP and the DUT to ensure consistency
- Connect to scoreboards to compare DUT responses against expected results
- Synchronize with model events without relying on polling mechanisms

- **Enhanced Callback Mechanism**

- Extend callback capabilities within the PCIe® Link environment to support advanced verification needs
- Define a comprehensive set of UVM callbacks corresponding to each VIP callback
- Dynamically activate or deactivate callbacks during simulation
- Enable or disable callbacks at specific simulation points or stages in the packet flow

# Additional Debug Info Support

Setting this in VIP simulation can add significant information to the log that can ease the further debug process.

- `CDN_PCIE_PRINT_AFTER_SCRAMBLER`: Data after scrambler
- `CDN_PCIE_PRINT_LANE_SYMCOUNT`: Symbol Count on the lanes
- `CDN_PCIE_PRINT_RXMARGIN`: RX Margin
- `CDN_PCIE_PRINT_PIPE_PM`: Pipe Power Management
- `CDN_PCIE_PRINT_ACK_NAK`: Ack/Nak Timer information
- `CDN_PCIE_PRINT_SKEW`: Skew data

# Efficient Debugging With Waveforms

- **Graphical Visualization of PCIe® Protocol**

View PCIe protocol transactions and packets in a graphical waveform format for intuitive debugging

- **In-Waveform Protocol Specification Error Display**

Protocol specification errors are directly visualized within the waveform, enabling quick identification and resolution

- **Layered Transaction View**

Access a per-layer breakdown of PCIe transactions and packets for detailed protocol analysis

- **ASCII Representation of Values**

Wherever applicable, values such as FSM states and enum variables are displayed in ASCII for better readability

- **Graphical PCIe Register Representation**

PCIe registers are visualized graphically, simplifying register-level debugging

# Continued...

- **Transaction Attribute Viewer**

Inspect packet contents through a dedicated transaction attributes view to streamline debugging

- **Unified Debugger Window**

Signals and transactions can be logged and viewed together in the same waveform debugger window

- **FSM State Transition Visualization**

Finite State Machine (FSM) transitions are clearly visualized on the waveform for easier state tracking

- **Multi-Protocol Debugging Support**

Simultaneously debug multiple protocols in a single SoC setup

- **Smart Log Integration**

Smart logging highlights UVM\_ERROR messages along with their corresponding debug timestamps

# Smart Effective Debugging on Waveform



## Transaction attributes and their values

Label: \_EXP\_LINK\_ST

- `_LkSpd = 'h6'`
  - `_LkWidth = 'h08'`
  - `_TrainErr = 0`
  - `_LkTrain = 0`
  - `_slotClk = 1`
  - `_DLActive = 0`
  - `_mgmtWidth = 0`
  - `autoWidth = 0`

Label: DEN\_LTSSM STATE

- St = "RecoveryRcvrCfg"

Label: DEN LTSSM REASON

- Reason = "ALL\_LANES\_RX\_8\_MATCHING\_TS1\_OR\_TS2\_WITH\_SPEED\_CHANGE\_BIT\_EQUALS\_DIRECTED\_SPEED\_CHANGE"

- 20

# Enhancing Debugging by Tracking Packets

Enable VIP Packet Tracker

Run Simulation

Master Packet Tracker Generated  
(~350 fields)

Perform filtering via inbuild file

Extended Packet Tracker  
generated (Reduced fields)

| i | p                  | v seq     |           | PASID                     | AT        | address   | /         | status    | F L       | T            |               | h         |           | H         | H         | link   lane   nfts   drate] totrl |
|---|--------------------|-----------|-----------|---------------------------|-----------|-----------|-----------|-----------|-----------|--------------|---------------|-----------|-----------|-----------|-----------|-----------------------------------|
| n | o d                | c ---     |           | vidid   vdmag   vdrouting | /         | /         |           | msg       | E B       | P            | len           | A a T E   | R         | W         | V         | ALMP Type   VLIM State   Inst Num |
| a | r i                | / med     | a a       | mtlat   network   routing | / cmpl    | /         |           | msg       | E E       | H            | T S P P       | ECRC      | LCRC      | I t       | I H       | payload/data                      |
| L | 13860.3 0 T CfgRd0 | 0         | ---       | 0000                      | - 00      | - - - - - | 0 00 0100 | - - - - - | 3 0       | 0000 00001   | 0 0 0 0       | - - - - - | - - - - - | - - - - - | - - - - - | - - - - -                         |
| O | 13862.3 0 X CfgRd0 | 0         | ---       | 0000                      | - 00      | - - - - - | 0 00 0100 | - - - - - | 3 0       | 0000 00001   | 0 0 0 0       | - - - - - | - - - - - | - - - - - | - - - - - | - - - - -                         |
| O | 13837.1 0 T CplD   | 0         | ---       | 0000                      | - 00      | 0 004     | 00 0000   | - - - - - | BC        | - - - - -    | 00001 0 - - - | - - - - - | - - - - - | - - - - - | - - - - - | 00161EPD                          |
| L | 13840.1 0 X CplD   | 0         | ---       | 0000                      | - 00      | 0 004     | 00 0000   | - - - - - | BC        | - - - - -    | 00001 0 - - - | - - - - - | - - - - - | - - - - - | - - - - - | 00161EPD                          |
| L | 13940.3 0 T cfgWr0 | 0         | ---       | 0000                      | - 00      | - - - - - | 0 04 0100 | - - - - - | F         | 0 0000 00001 | 0 0 0 0       | - - - - - | - - - - - | - - - - - | 0000000C  | - - - - -                         |
| - | - - - - -          | - - - - - | - - - - - | - - - - -                 | - - - - - | - - - - - | - - - - - | - - - - - | - - - - - | - - - - -    | - - - - -     | - - - - - | - - - - - | - - - - - | - - - - - | - - - - -                         |

Standard Packet tracker

|     |   |           |                        |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
|-----|---|-----------|------------------------|---------------|------|--------|--------------------------------|---------------|-------------|----|--|--|--|--|--|--|--|
| 81  | # | instal    |                        |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 82  | 0 | Model:    | pcie                   | VIP Instance: | vvm_ | instal | top_pciesv0.AltPcieEp.activeEp | 0             | Device Mode | 31 |  |  |  |  |  |  |  |
| 281 | 0 | activeEp  | CB-@DL_TX_queue_enter  |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 282 | d | activeEpC | CB-@DL_TX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 283 | d | activeRc  | CB-@DL_TX_queue_enter  |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 284 | x | activeRc  | CB-@DL_TX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 285 | x | passiveEp | CB-@DL_RX_queue_enter  |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 286 | d | passiveEp | CB-@DL_RX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 287 | J | activeRc  | CB-@DL_RX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 288 | J | passiveRc | CB-@DL_RX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 289 | J | passiveRc | CB-@DL_TX_queue_enter  |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 290 | 0 | activeEp  | CB-@DL_RX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 291 | x | passiveEp | CB-@DL_RX_queue_exit   |               |      |        |                                |               |             |    |  |  |  |  |  |  |  |
| 292 | 0 | activeEp  | CB-@DL_TX_queue_enter  |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |
| 293 | 0 | activeEp  | CB-@DL_TX_queue_exit   |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |
| 294 | d | activeRc  | CB-@DL_TX_queue_enter  |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |
| 295 | d | activeRc  | CB-@DL_TX_queue_exit   |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |
| 296 | d | activeRc  | CB-@TL_TX_packet       |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |
| 297 | v | passiveEp | CB-@TL_TV_pktsv0_enter |               |      |        |                                | 1.43E+10 Dilp |             |    |  |  |  |  |  |  |  |

Legacy Packet tracker

User Centric Configurable Debug

# Automated Result Debug



# Summary and Best Practices

- **Comprehensive PCIe Gen6 Debug Strategy:** The methodology addresses the growing complexity of PCIe® 6.0/6.1 verification by combining protocol-aware VIP monitoring with smart trace and efficient visual-driven debugging
- **Smart Passive Monitoring Architecture:** Embedding PCIe Gen6 VIP as a passive monitor enables non-intrusive, real-time protocol checks across TL, DL, and PHY layers
- **FLIT Mode and Protocol Awareness:** The approach effectively handles FLIT mode intricacies, ensuring accurate validation of transactions and data link layer behaviors
- **Meaningful Error Messaging:** Carefully designed error messages, backed by real-world examples, enhance clarity and reduce time-to-debug
- **Robust Callbacks and Error Injection:** Callback mechanisms and targeted error injection strategies validate corner cases and stress-test the DUT under edge conditions
- **Extensive Debug Information:** Rich trace logs and protocol event correlation provide deep visibility into system behavior, aiding faster root-cause analysis

# Continued...

- **Waveform-Based Debugging:** Visual waveform techniques, combined with traceability tools, accelerate issue localization and resolution
- **Packet-Level Tracking:** Tracking packets across layers and correlating them with protocol events improves traceability and debugging accuracy
- **Automated Debug Frameworks:** Automation scripts reduce manual effort, enabling scalable and repeatable debug cycles
- **Improved Verification Efficiency:** The combined strategy significantly reduces debug time, improves coverage, and ensures compliance with PCIe® Gen6 specifications
- **Scalable to Other Protocols:** The methodology's modular and automation-friendly nature makes it adaptable to other high-speed interface protocols

# THANK YOU °°



## ANY QUESTIONS ?