

Verification Continuum™

# **VC Verification IP**

## **PCIe**

## **UVM User Guide**

---

Version S-2021.06, June 2021

**SYNOPSYS®**

# **Copyright Notice and Proprietary Information**

© 2021 Synopsys, Inc. All rights reserved. This software and documentation contain confidential and proprietary information that is the property of Synopsys, Inc. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Synopsys, Inc., or as expressly provided by the license agreement.

## **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

## **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

## **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at <https://www.synopsys.com/company/legal/trademarks-brands.html>.

All other product or company names may be trademarks of their respective owners.

## **Free and Open-Source Software Licensing Notices**

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

## **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

[www.synopsys.com](http://www.synopsys.com)

# Contents

|                                                                                              |    |
|----------------------------------------------------------------------------------------------|----|
| Preface .....                                                                                | 13 |
| Chapter 1 Introduction .....                                                                 | 17 |
| 1.1 Introduction .....                                                                       | 17 |
| 1.2 Prerequisites .....                                                                      | 18 |
| 1.3 Online Class Reference HTML Help .....                                                   | 18 |
| 1.4 Product Overview .....                                                                   | 18 |
| 1.5 Key Features .....                                                                       | 18 |
| 1.6 Other Supported Features .....                                                           | 19 |
| 1.6.1 Requester, Driver, and Completer Applications .....                                    | 19 |
| 1.6.2 Methodology Features .....                                                             | 20 |
| 1.6.3 ECN Support .....                                                                      | 20 |
| 1.7 Related Documentation .....                                                              | 20 |
| Chapter 2 Installation and Setup .....                                                       | 21 |
| 2.1 Verifying the Hardware Requirements .....                                                | 21 |
| 2.2 Verifying Software Requirements .....                                                    | 22 |
| 2.2.1 Platform/OS and Simulator Software .....                                               | 22 |
| 2.2.2 Synopsys Common Licensing (SCL) Software .....                                         | 22 |
| 2.2.3 Other Third Party Software .....                                                       | 22 |
| 2.3 Preparing for Installation .....                                                         | 22 |
| 2.4 Downloading and Installing .....                                                         | 23 |
| 2.4.1 Downloading From the Electronic Software Transfer (EST) System (Download Center) ..... | 23 |
| 2.4.2 Downloading Using FTP with a Web Browser .....                                         | 23 |
| 2.5 What's Next? .....                                                                       | 23 |
| 2.6 Licensing Information .....                                                              | 24 |
| 2.6.1 Controlling License Usage .....                                                        | 24 |
| 2.7 Environment Variable and Path Settings .....                                             | 25 |
| 2.7.1 Simulator-Specific Settings .....                                                      | 25 |
| 2.8 Determining Your Model Version .....                                                     | 25 |
| 2.9 Integrating a VC VIP into Your Testbench .....                                           | 25 |
| 2.9.1 Setting Up Project Directory .....                                                     | 26 |
| 2.9.2 Updating an Existing Model .....                                                       | 27 |

|                                                                                       |    |
|---------------------------------------------------------------------------------------|----|
| Chapter 3 General Concepts .....                                                      | 29 |
| 3.1 Introduction to UVM .....                                                         | 29 |
| 3.2 PCIe UVM Interface .....                                                          | 29 |
| 3.2.1 UVM Components of the PCIe Device Subenvironment .....                          | 30 |
| 3.2.2 UVM Components of the PCIe MAC Agent .....                                      | 30 |
| 3.2.3 Configuration Data Objects .....                                                | 30 |
| 3.2.4 Status Data Objects .....                                                       | 31 |
| 3.2.5 Sequence Item Data Objects .....                                                | 32 |
| 3.3 SVT Service Sequence/Sequencer .....                                              | 33 |
| Chapter 4 Verification Features .....                                                 | 35 |
| 4.1 The Transaction Logger .....                                                      | 35 |
| 4.1.1 Printing TLP Payload Data to a Transaction Log File .....                       | 36 |
| 4.1.2 Fields of the Transaction Log Header .....                                      | 36 |
| 4.2 The Symbol Logger .....                                                           | 43 |
| 4.2.1 Fields of the Symbol Log Header .....                                           | 44 |
| 4.2.2 Synchronization of Simulation Time Between Transaction Log and Symbol Log ..... | 47 |
| 4.3 The MBI Logger .....                                                              | 48 |
| 4.3.1 Fields of the MBI Log Header .....                                              | 49 |
| 4.4 The CTRL SKP Logger .....                                                         | 49 |
| 4.4.1 Fields of the Ctrl SKP Log Header .....                                         | 50 |
| 4.5 Using Native Protocol Analyzer for Debugging .....                                | 51 |
| 4.5.1 Introduction .....                                                              | 51 |
| 4.5.2 Enabling the Protocol Analyzer .....                                            | 51 |
| 4.5.3 Prerequisites .....                                                             | 52 |
| 4.5.4 Compile-Time Options .....                                                      | 53 |
| 4.5.5 Run Time Options .....                                                          | 53 |
| 4.5.6 Invoking Protocol Analyzer .....                                                | 53 |
| 4.5.7 Limitations .....                                                               | 54 |
| 4.6 Verification Planner .....                                                        | 54 |
| 4.7 Global Shadow Memory .....                                                        | 54 |
| 4.7.1 Global Shadow Memory Classes .....                                              | 55 |
| 4.7.2 Global Memory Examples .....                                                    | 57 |
| 4.7.3 Multiple Global Shadows .....                                                   | 57 |
| 4.7.4 Disabling Global Shadows .....                                                  | 59 |
| 4.8 Target Memory .....                                                               | 59 |
| 4.8.1 Ignoring Memory Ranges .....                                                    | 61 |
| 4.9 Data Link Monitor .....                                                           | 62 |
| Chapter 5 General VIP Protocol Features .....                                         | 65 |
| 5.1 PCIe Gen3 Support .....                                                           | 65 |
| 5.2 Compliance Patterns .....                                                         | 65 |
| 5.3 Power Management .....                                                            | 66 |
| 5.3.1 ASPM .....                                                                      | 66 |
| 5.3.2 L0s Entry .....                                                                 | 66 |
| 5.3.3 PM .....                                                                        | 67 |
| 5.3.4 VIP PM/ASPM Checks .....                                                        | 69 |
| 5.4 Setting Coefficient and Preset for Gen3 Equalization .....                        | 69 |
| 5.4.1 Enabling Equalization .....                                                     | 70 |
| 5.4.2 Specifying Coefficients, Presets, LF and FS Values .....                        | 72 |

|                                                                                   |            |
|-----------------------------------------------------------------------------------|------------|
| 5.4.3 Preset and Coefficient Tuning Through Windowed Filtering . . . . .          | 74         |
| <b>Chapter 6 Gen4 Features . . . . .</b>                                          | <b>77</b>  |
| 6.1 Gen4 Protocol Features . . . . .                                              | 77         |
| 6.1.1 Enabling Gen4 . . . . .                                                     | 78         |
| 6.1.2 Gen4 Feature Set . . . . .                                                  | 78         |
| 6.1.3 EEOS Format Change . . . . .                                                | 82         |
| 6.1.4 10-Bit Tag . . . . .                                                        | 82         |
| 6.1.5 Retimer . . . . .                                                           | 83         |
| 6.1.6 Retimer Equalization . . . . .                                              | 84         |
| 6.1.7 Retimer Latency . . . . .                                                   | 88         |
| 6.1.8 Flow Control Credit Scaling . . . . .                                       | 88         |
| 6.1.9 Rx Margining . . . . .                                                      | 89         |
| 6.1.10 Limitations . . . . .                                                      | 95         |
| 6.2 Using SKP Ordered Sets . . . . .                                              | 95         |
| 6.3 Address Translation Services . . . . .                                        | 97         |
| 6.3.1 VIP Services to Map Translation inside RC VIP for ATS . . . . .             | 97         |
| 6.3.2 VIP Service Sequences with ATS Services . . . . .                           | 97         |
| 6.3.3 Knobs to Control RC VIP ATS Operation . . . . .                             | 97         |
| 6.3.4 TL Status Class Events to Track Translation . . . . .                       | 98         |
| 6.3.5 Automatic Translated Response from VIP: . . . . .                           | 99         |
| 6.4 PCIe VIP Bare COM Support . . . . .                                           | 99         |
| 6.4.1 Background . . . . .                                                        | 99         |
| 6.4.2 Enabling VIP Bare COM transmission (to mimic the system scenario) . . . . . | 99         |
| 6.4.3 Enabling VIP Bare COM Reception . . . . .                                   | 100        |
| 6.5 OBFF Feature Support . . . . .                                                | 100        |
| 6.5.1 Basic Attributes . . . . .                                                  | 100        |
| 6.5.2 Signal Connectivity . . . . .                                               | 100        |
| 6.5.3 Generating CPU State Transition Using RCVIP . . . . .                       | 101        |
| 6.5.4 Decoding and Validating CPU State Transition Using EP VIP . . . . .         | 101        |
| 6.5.5 Protocol Checks . . . . .                                                   | 102        |
| 6.5.6 Known Limitations . . . . .                                                 | 102        |
| 6.6 Replay Timer . . . . .                                                        | 103        |
| 6.6.1 Configuration . . . . .                                                     | 103        |
| 6.7 SRIS/SRNS . . . . .                                                           | 105        |
| 6.7.1 Introduction . . . . .                                                      | 105        |
| 6.7.2 Basic Attributes . . . . .                                                  | 105        |
| 6.7.3 Enabling the SRNS Mode . . . . .                                            | 105        |
| 6.7.4 Enabling the SRIS Mode . . . . .                                            | 106        |
| 6.7.5 Configuring the VIP Receiver for SRIS/SRNS Mode . . . . .                   | 107        |
| <b>Chapter 7 Gen5 Features . . . . .</b>                                          | <b>109</b> |
| 7.1 Version Support . . . . .                                                     | 109        |
| 7.2 Supported Interfaces . . . . .                                                | 109        |
| 7.3 VIP License Requirements . . . . .                                            | 110        |
| 7.4 Supported Features . . . . .                                                  | 110        |
| 7.5 Enabling Gen5 Support . . . . .                                               | 110        |
| 7.6 Gen5 Configuration Settings . . . . .                                         | 111        |
| 7.6.1 32G Equalization . . . . .                                                  | 111        |
| 7.6.2 Configuring Coefficient and Preset Requests . . . . .                       | 112        |

|                                                                        |            |
|------------------------------------------------------------------------|------------|
| 7.6.3 Enhanced Link Behavior Control - TS1/2 Symbol 5 (Optional) ..... | 113        |
| 7.6.4 Skew Support for 32G .....                                       | 113        |
| 7.6.5 nFTS at 32G .....                                                | 113        |
| 7.6.6 Retimer Latency on RX Data Path .....                            | 114        |
| 7.6.7 Precoding .....                                                  | 114        |
| 7.6.8 32G Loopback Controls .....                                      | 114        |
| 7.7 EIEOSQ Controls .....                                              | 114        |
| 7.8 Gen5 Support for PIPE Interface .....                              | 114        |
| 7.8.1 Enabling Gen5 Support .....                                      | 114        |
| 7.8.2 Protocol Checks and Exceptions .....                             | 115        |
| 7.8.3 Gen5 Example .....                                               | 115        |
| 7.9 Gen5 Symbol Logging .....                                          | 115        |
| 7.9.1 Precoding Display .....                                          | 115        |
| 7.9.2 ELBC Display .....                                               | 116        |
| 7.9.3 EQ Via Loopback Display .....                                    | 117        |
| 7.9.4 use_modified_TS1_TS2_Ordered_Set Variable Display .....          | 117        |
| <b>Chapter 8 PIPE Features .....</b>                                   | <b>119</b> |
| 8.1 PIPE Support .....                                                 | 119        |
| 8.1.1 PIPE Version 2.0 .....                                           | 119        |
| 8.1.2 PIPE Version 4.0 .....                                           | 120        |
| 8.1.3 PIPE Version 4.2 .....                                           | 121        |
| 8.1.4 PIPE Version 4.3 .....                                           | 122        |
| 8.1.5 PIPE Version 4.4 .....                                           | 122        |
| 8.1.6 PIPE Version 4.4.1 .....                                         | 122        |
| 8.1.7 PIPE Version 5.1.1 .....                                         | 123        |
| 8.2 RxStandby/RxStandbyStatus Handshake Support .....                  | 123        |
| 8.2.1 Basic Attributes .....                                           | 123        |
| 8.2.2 Additional Attributes .....                                      | 123        |
| 8.2.3 Protocol Checks .....                                            | 124        |
| 8.3 Nominal Empty Mode for FIFO (Elastic Buffer Mode) .....            | 124        |
| 8.3.1 Interface .....                                                  | 124        |
| 8.3.2 Status .....                                                     | 124        |
| 8.3.3 Configuration .....                                              | 124        |
| 8.3.4 Protocol Checks .....                                            | 125        |
| 8.4 PIPE Signals Controllability in VIP .....                          | 125        |
| 8.4.1 Using MPIPE VIP .....                                            | 125        |
| 8.4.2 Using SPIPE VIP .....                                            | 133        |
| <b>Chapter 9 PIPE5 Features .....</b>                                  | <b>139</b> |
| 9.1 Version Support .....                                              | 139        |
| 9.2 Supported Interfaces .....                                         | 139        |
| 9.3 Supported Features .....                                           | 139        |
| 9.3.1 PIPE 5.1.1 Features .....                                        | 139        |
| 9.3.2 PIPE 5.1.1 Features Supported in Active VIP .....                | 140        |
| 9.4 VIP Requirements .....                                             | 142        |
| 9.5 Limitations .....                                                  | 143        |
| 9.5.1 Known Limitations in Active VIP .....                            | 143        |
| 9.6 PIPE Interface Usage Model .....                                   | 143        |
| 9.6.1 Applicable Scenarios for Using svt_PCIE_PIPE_if .....            | 143        |

|                                                                               |            |
|-------------------------------------------------------------------------------|------------|
| 9.6.2 Applicable Scenarios for Using svt_PCIE_pipe5_if .....                  | 143        |
| 9.6.3 Features Supported in svt_PCIE_pipe_if and svt_PCIE_pipe5_if .....      | 144        |
| <b>Chapter 10 PCIe Verification Topologies .....</b>                          | <b>145</b> |
| 10.1 Introduction .....                                                       | 145        |
| 10.2 Unified PCIe VIP Component .....                                         | 146        |
| 10.2.1 Introduction .....                                                     | 146        |
| 10.2.2 Existing VIP Structure .....                                           | 147        |
| 10.2.3 Unified PCIe VIP Component .....                                       | 147        |
| 10.2.4 Verilog HDL Module to SystemVerilog UVM Class Intercommunication ..... | 154        |
| 10.2.5 Using a Virtual Interface Handle .....                                 | 154        |
| 10.2.6 Backward Compatibility With Existing Testbench .....                   | 155        |
| 10.2.7 Installing the Unified VIP Example .....                               | 155        |
| 10.2.8 Testbench Structure .....                                              | 155        |
| 10.2.9 DUT Integration .....                                                  | 159        |
| 10.2.10 Known Limitations .....                                               | 164        |
| 10.3 Check 'x' or 'z' on Signal .....                                         | 164        |
| <b>Chapter 11 Using the PCIe Verification IP .....</b>                        | <b>167</b> |
| 11.1 SystemVerilog UVM Example Testbenches .....                              | 168        |
| 11.2 Installing and Running the Examples .....                                | 168        |
| 11.2.1 Running the Example with +incdir+ .....                                | 170        |
| 11.3 Error Message Usage .....                                                | 171        |
| 11.4 Setting VIP Configurations .....                                         | 172        |
| 11.5 UVM Reporting Levels .....                                               | 174        |
| 11.6 Controlling Verbosity From the Command Line .....                        | 174        |
| 11.7 Resetting the PCIe VIP .....                                             | 175        |
| 11.8 Creating and Using Custom Applications .....                             | 177        |
| 11.8.1 Setting Up Application ID Maps .....                                   | 177        |
| 11.8.2 Using Testbench Sequences to Emulate User Applications .....           | 178        |
| 11.8.3 Waiting for Completions .....                                          | 178        |
| 11.9 Backdoor Access to Completion Target Configuration Space .....           | 178        |
| 11.9.1 Setting up the Configuration Space for Backdoor Access .....           | 178        |
| 11.10 Setting VIP Lanes for Receiver Detect .....                             | 181        |
| 11.11 Using ASCII Signals .....                                               | 182        |
| 11.11.1 Transaction Layer ASCII Signals .....                                 | 182        |
| 11.11.2 Data Link Layer ASCII Signals .....                                   | 182        |
| 11.11.3 Physical Layer ASCII Signals .....                                    | 183        |
| 11.12 Using the Ordering Application .....                                    | 184        |
| 11.12.1 Steps to Use the Ordering Application: .....                          | 184        |
| 11.13 Customizing the Transaction Log Output .....                            | 185        |
| 11.14 Target Application .....                                                | 185        |
| 11.14.1 Target Application Callbacks .....                                    | 186        |
| 11.15 Requester Application .....                                             | 187        |
| 11.16 What Are Blocking and Non-blocking Reads in PCIe SVT? .....             | 188        |
| 11.17 Using Service Class Reset App .....                                     | 189        |
| 11.18 Using FLR .....                                                         | 193        |
| 11.19 Programming Hints and Tips .....                                        | 195        |
| 11.19.1 PIPE Polarity .....                                                   | 195        |
| 11.19.2 Calls For Analysis Port Set Up and Usage .....                        | 195        |

|                                                                             |            |
|-----------------------------------------------------------------------------|------------|
| 11.19.3 Sequences and the uvm_sequence::get_response Task .....             | 196        |
| 11.19.4 Setting the TH and PH Bits Using the Driver Application Class ..... | 197        |
| 11.19.5 Fast Link Training .....                                            | 197        |
| 11.19.6 When to Invoke Service Calls .....                                  | 197        |
| 11.19.7 Exceptions and Scrambler Control Bits .....                         | 197        |
| 11.19.8 User TS1 Ordered Set Notes .....                                    | 198        |
| 11.20 Up/Down Configure .....                                               | 198        |
| 11.21 Lane Reversal .....                                                   | 200        |
| 11.22 Lane Reversal with Different Link Width Configurations .....          | 200        |
| 11.23 User-Supplied Memory Model Interface .....                            | 203        |
| 11.24 External Clocking and Per Lane Clocking for Serial Interface .....    | 204        |
| 11.24.1 Enabling External Clocking and Per Lane Clocking Modes .....        | 204        |
| 11.25 Callbacks .....                                                       | 206        |
| 11.25.1 Rx Symbol Callback .....                                            | 207        |
| 11.25.2 Framing Token Callback .....                                        | 207        |
| 11.26 Generating MSI/MSIx with PCIe VIP .....                               | 208        |
| 11.26.1 Configuring EP VIP for MSI/MSIx Generation .....                    | 209        |
| 11.26.2 Configuring RC VIP for MSI/MSIx Generation .....                    | 209        |
| <b>Chapter 12 PCIe Device Agent .....</b>                                   | <b>211</b> |
| 12.1 Overview .....                                                         | 211        |
| 12.2 Configuration .....                                                    | 213        |
| 12.2.1 Initial Configuration .....                                          | 214        |
| 12.2.2 Dynamic Configuration .....                                          | 215        |
| 12.3 Status .....                                                           | 217        |
| 12.4 Sequencers .....                                                       | 218        |
| 12.4.1 Service Sequencers .....                                             | 219        |
| 12.4.2 Transaction Sequencers .....                                         | 220        |
| 12.4.3 Virtual Sequencer .....                                              | 221        |
| <b>Chapter 13 PCIe Agent .....</b>                                          | <b>225</b> |
| 13.1 Overview .....                                                         | 225        |
| 13.2 Configuration .....                                                    | 226        |
| 13.2.1 Initial Configuration .....                                          | 227        |
| 13.2.2 Dynamic Configuration (reconfiguration) .....                        | 227        |
| 13.3 Status .....                                                           | 227        |
| 13.4 Sequencers .....                                                       | 227        |
| 13.4.1 Service Sequencers .....                                             | 228        |
| 13.4.2 Transaction Sequencers .....                                         | 229        |
| 13.4.3 Virtual Sequencer .....                                              | 230        |
| <b>Chapter 14 Using the Transaction Layer .....</b>                         | <b>235</b> |
| 14.1 Transaction Layer .....                                                | 235        |
| 14.2 Transaction Layer Configuration .....                                  | 236        |
| 14.2.1 Verilog Configuration Parameters .....                               | 237        |
| 14.3 Transaction Layer Data Flow .....                                      | 238        |
| 14.3.1 Flow Diagram .....                                                   | 238        |
| 14.3.2 Transaction Layer Sequencer and Sequences .....                      | 238        |
| 14.3.3 Transaction Layer Callbacks and Exceptions .....                     | 241        |
| 14.3.4 Transaction Layer TLMs .....                                         | 241        |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| 14.4 Transaction Layer Status .....                                     | 242 |
| 14.5 Transaction Layer Verilog Interface .....                          | 242 |
| <br>                                                                    |     |
| Chapter 15 Data Link Layer Features and Classes .....                   | 245 |
| 15.1 Classes and Applications for Using the VIP's Data Link Layer ..... | 245 |
| 15.2 Additional Documentation on DL Programming Tasks .....             | 245 |
| 15.3 Class Elements of the Link Layer .....                             | 246 |
| 15.4 Datalink Layer Data Flow .....                                     | 246 |
| 15.4.1 Flow Diagram .....                                               | 246 |
| 15.4.2 Service Class svt_PCIE_DL_Service .....                          | 247 |
| 15.4.3 Datalink Layer TLMs .....                                        | 248 |
| 15.4.4 Datalink Layer Callbacks and Exceptions .....                    | 248 |
| 15.4.5 Datalink Layer Analysis Ports .....                              | 248 |
| 15.5 Component Class svt_PCIE_DL .....                                  | 248 |
| 15.6 Configuration class svt_PCIE_DL_Configuration .....                | 251 |
| 15.6.1 Members and Features .....                                       | 251 |
| 15.6.2 Calculating Ack/Nak Latency Values .....                         | 251 |
| 15.7 Status class svt_PCIE_DL_Status .....                              | 252 |
| <br>                                                                    |     |
| Chapter 16 Physical Layer Features and Classes .....                    | 253 |
| 16.1 Classes and Applications for Using the VIP's PHY Layer .....       | 253 |
| 16.2 Additional Documentation on PHY Programming Tasks .....            | 253 |
| 16.3 PHY Layer Data Flow .....                                          | 253 |
| 16.3.1 Flow Diagram .....                                               | 253 |
| 16.3.2 Service Class svt_PCIE_PL_Service .....                          | 254 |
| 16.3.3 Physical Layer Callbacks and Exceptions .....                    | 259 |
| 16.4 UVM Component Class svt_PCIE_PL .....                              | 259 |
| 16.5 PHY Layer Configuration Class .....                                | 260 |
| 16.6 External Tx Bit Clk Use Model .....                                | 260 |
| <br>                                                                    |     |
| Chapter 17 Using the Driver Application .....                           | 263 |
| 17.1 Introduction .....                                                 | 263 |
| 17.2 Driver Application Configuration .....                             | 264 |
| 17.2.1 Initial Configuration .....                                      | 265 |
| 17.2.2 Dynamic Configuration .....                                      | 265 |
| 17.3 Driver Application Data Flow .....                                 | 265 |
| 17.3.1 Flow Diagram .....                                               | 265 |
| 17.3.2 Sequencer Ports .....                                            | 266 |
| 17.3.3 Sequences .....                                                  | 266 |
| 17.3.4 Callbacks and Events .....                                       | 273 |
| 17.3.5 Exceptions .....                                                 | 280 |
| 17.4 Status .....                                                       | 294 |
| <br>                                                                    |     |
| Chapter 18 Functional Coverage .....                                    | 297 |
| 18.1 Introduction .....                                                 | 297 |
| 18.1.1 Key Features .....                                               | 297 |
| 18.1.2 Coverage Model Interpretation .....                              | 298 |
| 18.1.3 Covergroup Naming Conventions .....                              | 298 |
| 18.1.4 DUT Type and Coverage Applicability .....                        | 299 |
| 18.1.5 Coverage Hierarchical Verification Plans .....                   | 299 |
| 18.2 Usage Notes .....                                                  | 303 |

|                                                                        |            |
|------------------------------------------------------------------------|------------|
| 18.2.1 Enabling Function Coverage .....                                | 303        |
| 18.2.2 HVP Coverage Back Annotation with PCIe VIP RC DUT .....         | 304        |
| <b>Chapter 19 Using Callbacks .....</b>                                | <b>309</b> |
| 19.1 Introduction .....                                                | 309        |
| 19.2 How Callbacks Are Used .....                                      | 309        |
| 19.2.1 Other Uses for Callbacks .....                                  | 310        |
| 19.2.2 Callback Hints .....                                            | 310        |
| 19.2.3 When Not to Use a Callback .....                                | 310        |
| 19.3 Detailed Usage .....                                              | 311        |
| 19.3.1 A Basic Testcase .....                                          | 311        |
| 19.4 Advanced Topics in Callbacks .....                                | 313        |
| 19.4.1 Exceptions - a “Delayed” Transaction Modification Request ..... | 313        |
| 19.4.2 Creating an Exception .....                                     | 313        |
| 19.4.3 Creating a Factory Exception .....                              | 314        |
| 19.4.4 Error Injection Using Application Layer TX Callbacks .....      | 315        |
| 19.4.5 A More Comprehensive Example .....                              | 318        |
| 19.5 SVT VIP Callbacks Reference .....                                 | 322        |
| 19.6 Transaction Layer Callbacks and Exceptions .....                  | 325        |
| 19.6.1 Transaction Layer Exceptions .....                              | 326        |
| 19.7 Datalink Layer Callbacks and Exceptions .....                     | 326        |
| 19.7.1 Datalink Layer Exceptions .....                                 | 327        |
| 19.8 Physical Layer Callbacks and Exceptions .....                     | 327        |
| 19.8.1 Physical Layer Exceptions .....                                 | 332        |
| 19.9 Controlling Completion Timing and Size Using Callbacks .....      | 332        |
| 19.9.1 Controlling Delay for the Current Completion .....              | 332        |
| 19.9.2 Controlling Delay for the Next Completion .....                 | 333        |
| 19.9.3 Controlling Size for the Next Completion .....                  | 333        |
| <b>Chapter 20 Support for CCIX .....</b>                               | <b>335</b> |
| 20.1 Version Support .....                                             | 335        |
| 20.2 Supported Interfaces .....                                        | 335        |
| 20.2.1 Updates for PIPE interface .....                                | 335        |
| 20.3 Supported Features .....                                          | 336        |
| 20.4 Support for CCIX ESM Operation .....                              | 336        |
| 20.4.1 Enabling ESM Operation .....                                    | 336        |
| 20.4.2 Configuring ESM Operation .....                                 | 336        |
| 20.5 Support for CCIX Optimized TLP Format .....                       | 339        |
| 20.5.1 Enabling Optimized TLP Format .....                             | 339        |
| 20.5.2 Configuring VC for Optimized TLP Traffic .....                  | 339        |
| 20.5.3 Sending Optimized TLPs .....                                    | 339        |
| 20.5.4 Receiving Optimized TLPs .....                                  | 339        |
| 20.5.5 Transaction Logging of Optimized TLPs .....                     | 340        |
| 20.6 Limitations .....                                                 | 341        |
| <b>Appendix A PCIe PIPE Interface .....</b>                            | <b>342</b> |
| A.1 PIPE Interface Specifications .....                                | 342        |
| A.2 Configuring the PIPE Data Bus Width .....                          | 353        |
| A.2.1 PIPE 2.1/3 .....                                                 | 353        |
| A.2.2 PIPE4 and Above .....                                            | 353        |

|                                                                                       |     |
|---------------------------------------------------------------------------------------|-----|
| A.3 PIPE Coefficient Use . . . . .                                                    | 354 |
| A.3.1 PHY PIPE GetLocalPresetCoefficients Interface ASCII Signals . . . . .           | 356 |
| Appendix B Functional Coverage . . . . .                                              | 358 |
| B.1 Enabling Functional Coverage . . . . .                                            | 358 |
| B.2 Class Structure and Callbacks . . . . .                                           | 358 |
| B.3 Overriding the Default Coverage Class . . . . .                                   | 359 |
| B.3.1 Overriding With UVM . . . . .                                                   | 359 |
| B.3.2 Overriding for SystemVerilog Users . . . . .                                    | 359 |
| B.4 Transaction Layer . . . . .                                                       | 360 |
| B.4.1 Transaction Layer Functional Coverage . . . . .                                 | 360 |
| B.4.2 Transaction Layer Callbacks . . . . .                                           | 361 |
| B.5 Data Link Layer . . . . .                                                         | 362 |
| B.5.1 Data Link Layer Functional Coverage . . . . .                                   | 362 |
| B.5.2 Link Layer Callbacks . . . . .                                                  | 379 |
| B.6 Physical Layer . . . . .                                                          | 384 |
| B.6.1 Physical Layer Functional Coverage . . . . .                                    | 384 |
| B.6.2 Physical Layer Callbacks . . . . .                                              | 388 |
| B.7 PIPE Interface . . . . .                                                          | 390 |
| B.7.1 PIPE Functional Coverage . . . . .                                              | 390 |
| B.7.2 PIPE Interface Callbacks . . . . .                                              | 390 |
| B.8 Mapping Legacy Covergroups to Corresponding New Covergroups . . . . .             | 392 |
| Appendix C Partition Compile and Precompiled IP . . . . .                             | 403 |
| C.1 Implementing Partition Compile in Testbench . . . . .                             | 403 |
| C.1.1 High Level Architecture . . . . .                                               | 404 |
| C.1.2 Guidelines for Partition Compile Usages . . . . .                               | 404 |
| C.2 Use Model . . . . .                                                               | 405 |
| C.2.1 Parallel Partition Compile . . . . .                                            | 405 |
| C.3 The "vcspcvlog" Simulator Target in Makefiles . . . . .                           | 405 |
| C.4 The "vcsmpcvlog" Simulator Target in Makefiles . . . . .                          | 406 |
| C.5 The "vcsmpipvlog" Simulator Target in Makefiles . . . . .                         | 406 |
| C.6 Precompiled IP Implementation in Testbenches with Verification IPs . . . . .      | 406 |
| C.7 Example . . . . .                                                                 | 406 |
| Appendix D Protocol Checks . . . . .                                                  | 408 |
| Appendix E PCIe PIE-8 Interface . . . . .                                             | 409 |
| E.1 Supported Interface Signals . . . . .                                             | 409 |
| E.2 Configuration Parameters . . . . .                                                | 411 |
| E.3 Status Class PIE8 Members . . . . .                                               | 412 |
| E.4 PHY PIE-8 ASCII Signals . . . . .                                                 | 413 |
| E.5 PHY PIE-8 Internal Signals . . . . .                                              | 413 |
| E.6 PIE-8 Protocol Check "MSGCODEs" . . . . .                                         | 414 |
| Appendix F Verilog Task/Parameter to SVT Class Mapping . . . . .                      | 417 |
| F.1 Transaction Layer Verilog Tasks and Parameters to UVM Class Members Map . . . . . | 417 |
| F.1.1 Transaction Layer Verilog Task to UVM Class Member Map . . . . .                | 417 |
| F.1.2 Transaction Layer Verilog Parameters to UVM Class Members Map . . . . .         | 418 |
| F.2 Data Link Layer Verilog Tasks and Parameters to UVM Class Member Maps . . . . .   | 420 |
| F.2.1 Data Link Layer Verilog Task to UVM Class Member Map . . . . .                  | 420 |

|                                                                       |     |
|-----------------------------------------------------------------------|-----|
| F.2.2 Data Link Layer Verilog Parameter to UVM Class Member Map ..... | 422 |
| Appendix G Multi End Point Mode .....                                 | 425 |
| G.1 Feature Specifications .....                                      | 425 |
| G.2 Implementation .....                                              | 425 |
| G.3 Configurations .....                                              | 426 |
| Appendix H SolvNetPlus PCIe VIP Articles .....                        | 431 |
| H.1 Application Layer .....                                           | 431 |
| H.1.1 Driver App .....                                                | 431 |
| H.1.2 Target App .....                                                | 432 |
| H.1.3 Requester App .....                                             | 432 |
| H.2 Transaction Layer .....                                           | 432 |
| H.3 Data Link Layer .....                                             | 433 |
| H.4 PHY Layer .....                                                   | 434 |
| H.5 Methodology Testbench and Debug .....                             | 436 |
| H.6 Miscellaneous .....                                               | 439 |
| Appendix I Reporting Problems .....                                   | 441 |
| I.1 Introduction .....                                                | 441 |
| I.2 Debug Automation .....                                            | 441 |
| I.3 Enabling and Specifying Debug Automation Features .....           | 441 |
| I.4 Debug Automation Outputs .....                                    | 443 |
| I.5 FSDB File Generation .....                                        | 444 |
| I.5.1 VCS .....                                                       | 444 |
| I.5.2 Questa .....                                                    | 444 |
| I.5.3 Incisive .....                                                  | 444 |
| I.6 Initial Customer Information .....                                | 444 |
| I.7 Sending Debug Information to Synopsys .....                       | 444 |
| I.8 Limitations .....                                                 | 445 |

# Preface

---

## About This Manual

This manual contains installation, setup, and usage material for SystemVerilog UVM users of the VC PCIe, and is for design or verification engineers who want to verify PCIe operation using a UVM testbench written in SystemVerilog. Readers are assumed to be familiar with PCIe, object oriented programming (OOP), SystemVerilog, and Universal Verification Methodology (UVM) techniques.

## Manual Organization

The chapters of this databook are organized as follows:

- ❖ Chapter 1, “[Introduction](#)”, introduces the VC PCIe and its features.
- ❖ Chapter 2, “[Installation and Setup](#)”, describes system requirements and provides instructions on how to install, configure, and begin using the VC PCIe.
- ❖ Chapter 3, “[General Concepts](#)”, introduces the PCIe VIP within the UVM environment and describes the data objects and components that comprise the VIP.
- ❖ Chapter 4, “[Verification Features](#)”, describes the verification features supported by PCIe VIP such as, Verification Planner and Protocol Analyzer.
- ❖ Chapter 5, “[General VIP Protocol Features](#)”, describes the general VIP protocol features available with the Synopsys PCIe Verification IP.
- ❖ Chapter 6, “[Gen4 Features](#)”, describes the Gen4 features available with the Synopsys PCIe Verification IP.
- ❖ Chapter 7, “[Gen5 Features](#)”, describes the Gen5 features available with the Synopsys PCIe Verification IP.
- ❖ Chapter 8, “[PIPE Features](#)”, describes the PIPE feature support available with the Synopsys PCIe Verification IP.
- ❖ Chapter 9, “[PIPE5 Features](#)”, describes the PIPE5 feature support available with the Synopsys PCIe Verification IP.
- ❖ Chapter 10, “[PCIe Verification Topologies](#)”, describes various ways the PCIe VIP can be connected with other components.

- ❖ Chapter 11, “Using the PCIe Verification IP”, shows how to install and run a getting started example.
- ❖ Chapter 12, “PCIe Device Agent”, provides an overview on PCIe Device Agent and how to use them.
- ❖ Chapter 13, “PCIe Agent”, provides an overview on PCIe Agent and how to use them.
- ❖ Chapter 14, “Using the Transaction Layer”, describes features of the Transaction Layer and how to use them.
- ❖ Chapter 15, “Data Link Layer Features and Classes”, describes features of the Data Link Layer and how to use them.
- ❖ Chapter 16, “Physical Layer Features and Classes”, describes features of the PHY Layer and how to use them.
- ❖ Chapter 17, “Using the Driver Application”, describes the procedure for using the driver application.
- ❖ Chapter 18, “Functional Coverage”, provides the overview of PCIe functional coverage features, usage mechanism, coverage generation and coverage back annotation process.
- ❖ Chapter 19, “Using Callbacks”, describes the basic usage of Callbacks, provides some examples, and gives tips for debugging them.
- ❖ Chapter 20, “Support for CCIX”, describes the CCIX features available with the Synopsys PCIe SVT Verification IP.
- ❖ Appendix A, “PCIe PIPE Interface”, provides the detailed list of all the signal widths and associated macros present in PIPE and PIPE5 interface.
- ❖ Appendix B, “Functional Coverage”, describes how to enable and use the functional coverage features.
- ❖ Appendix C, “Partition Compile and Precompiled IP”, describes the PC and PIP features in Verification Compiler to optimize the compilation performance.
- ❖ Appendix D, “Protocol Checks”, outlines the process for working through and reporting VC PCIe issues.
- ❖ Appendix E, “PCIe PIE-8 Interface”, describes the PIE-8 specification in PCIe VIP.
- ❖ Appendix F, “PCIe Compile-Time Parameters”, contains a table of parameters that can only be set before compilation, not at runtime.
- ❖ Appendix F, “Verilog Task/Parameter to SVT Class Mapping”, contains tables that show the correspondence between SVT classes and Verilog tasks or parameters.
- ❖ Appendix G, “Multi End Point Mode”, contains information on the representation of multiple end-points supported by PCIe.
- ❖ Appendix H, “SolvNetPlus PCIe VIP Articles”, provides the lists and links to all the technical articles published on the PCIe VIP.
- ❖ Appendix I, “Reporting Problems”, outlines the process for working through and reporting VC PCIe issues.

## Web Resources

- ❖ Documentation through SolvNetPlus: <https://solvnetplus.synopsys.com> (Synopsys password required)

- ❖ Synopsys Common Licensing (SCL): <http://www.synopsys.com/keys>

## Customer Support

To obtain support for your product, choose one of the following:

- ❖ Go to <https://solvnetplus.synopsys.com> and open a case.
  - ◆ Enter the information according to your environment and your issue.
  - ◆ If applicable, provide the information noted in Appendix I, "Reporting Problems".
- ❖ Send an e-mail message to [support\\_center@synopsys.com](mailto:support_center@synopsys.com)
  - ◆ Include the Product name, Sub Product name, and Product version for which you want to register the problem.
  - ◆ If applicable, provide the information noted in Appendix I, "Reporting Problems".
- ❖ Telephone your local support center.
  - ◆ North America:  
Call 1-800-245-8005 from 7 AM to 5:30 PM Pacific time, Monday through Friday.
  - ◆ All other countries:  
<https://www.synopsys.com/support/global-support-centers.html>

## Synopsys Statement on Inclusivity and Diversity

Synopsys is committed to creating an inclusive environment where every employee, customer, and partner feels welcomed. We are reviewing and removing exclusionary language from our products and supporting customer-facing collateral. Our effort also includes internal initiatives to remove biased language from our engineering and working environment, including terms that are embedded in our software and IPs. At the same time, we are working to ensure that our web content and software applications are usable to people of varying abilities. You may still find examples of non-inclusive language in our software or documentation as our IPs implement industry-standard specifications that are currently under review to remove exclusionary language.



# 1 Introduction

---

This chapter gives a basic introduction, overview and features of the PCIe UVM Verification IP.

This chapter discusses the following topics:

- ❖ [Introduction](#)
- ❖ [Prerequisites](#)
- ❖ [Online Class Reference HTML Help](#)
- ❖ [Product Overview](#)
- ❖ [Other Supported Features](#)
- ❖ [Related Documentation](#)

## 1.1 Introduction

The VC PCIe Verification IP supports verification of SoC designs that include interfaces implementing the PCIe Specification. This document describes the use of this VIP in testbenches that comply with the SystemVerilog Universal Verification Methodology (UVM). This approach leverages advanced verification technologies and tools that provide:

- ❖ Protocol functionality and abstraction
- ❖ Constrained random verification
- ❖ Functional coverage
- ❖ Rapid creation of complex tests
- ❖ Modular testbench architecture that provides maximum reuse, scalability and modularity
- ❖ Proven verification approach and methodology
- ❖ Transaction-level models
- ❖ Self-checking tests
- ❖ Object oriented interface that allows OOP techniques

## 1.2 Prerequisites

Familiarity with PCIe, object oriented programming, SystemVerilog, and the current version of UVM.

## 1.3 Online Class Reference HTML Help

For more information on PCIe Verification IP, refer to the Class Reference for Synopsys Verification IP for PCIe, which you can access by opening the following file in a browser:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/index.html`

Please note that the search available in the PCIe Class Reference does not support multiple words, Boolean expressions, or wild card searches. Use only single word searches.

## 1.4 Product Overview

The PCIe UVM VIP is a suite of UVM-based verification components that are compatible for use with SystemVerilog-Compliant testbenches. The Synopsys PCIe VIP suite simulates PCIe transactions using an active agent as defined by the PCIe specification.

The VIP provides a system environment that contains an active device and MAC agent. The agent supports all the functionality normally associated with active UVM components, including the creation of transactions, checking and reporting the protocol correctness, transaction logging and functional coverage.

## 1.5 Key Features

Following are the main key architectural features of the PCIe VIP.

- ❖ Emulates Root Complex and Endpoint
- ❖ Full protocol stack:
  - Application, Transaction, Link, and Phy layers
- ❖ Checkers verify handshakes and functional accuracy at each layer
- ❖ Interfaces to capture sent and received packets for external scoreboard
- ❖ Error Injection at all levels
- ❖ Protocol checks integrated w/ UVM report object
- ❖ Extensive debug Aids
  - ◆ All states and Primitives available as ascii strings in waveform viewer
  - ◆ All signals named as close to the standard as possible
  - ◆ Log file similar to common trace formats from Bus Analyzers
  - ◆ Integrated with Protocol Analyzer
  - ◆ Symbol logger
- ❖ Verilog and UVM APIs
- ❖ Pre-configured instances
- ❖ Few parameters required to initiate transactions
- ❖ Full controllability for complex configurations
- ❖ Software Applications
  - ◆ Built-in Scoreboard

- ◆ Shadow Memory for self-checking
- ◆ Driver
- ◆ Standard PCIe Bus Transactions
- ◆ Requester
- ◆ Background traffic to various memory ranges
- ◆ Completer
  - ✧ Automatically handles completions to mem/cfg/io writes & read
- ❖ Error Injections
  - ◆ Built in, Exceptions provide automated injection, checking, and recovery
  - ◆ User defined injections
    - ✧ Per transaction
    - ✧ Per symbol
- ❖ Debug
  - ◆ Grey box SystemVerilog Model
  - ◆ Key internal signals can be viewed in waveform viewer
  - ◆ ASCII string values for internal states
  - ◆ Multiple log options
  - ◆ UVM reporter
  - ◆ Transaction log
  - ◆ MBI log
  - ◆ SKP OS log
  - ◆ Symbol log

For information related to verification centric features on Gen5, see [Gen5 Symbol Logging](#).

## 1.6 Other Supported Features

### 1.6.1 Requester, Driver, and Completer Applications

PCIe VIP currently supports the following verification functions:

- ❖ Functional coverage
- ❖ Protocol checking
- ❖ Control on delays and timeouts
- ❖ Built-in completer memory
- ❖ Verification Planner
- ❖ Protocol Analyzer
- ❖ Shadow memory with application-level scoreboard.

Note: Shadow memory is limited to default behavior; settings are not changeable.

- ❖ Requester and driver applications

For details on CCIX support, see [Support for CCIX](#). For details on PIE-8 interfaces, see [PCIe PIE-8 Interface](#).

### 1.6.2 Methodology Features

PCIe VIP currently supports the following methodology functions:

- ❖ VIP organized as a set of agents and applications
- ❖ Analysis ports for connecting the agent to the scoreboard, or any other component
- ❖ Error injections via Factory, callback, or transaction item

### 1.6.3 ECN Support

Engineering Change Notices (ECNs) that have been implemented in the PCIe VIP are listed in [Table 1-1](#).

**Table 1-1 ECNs implemented in the PCIe VIP**

| ECN                      | Spec Version | Comments     |
|--------------------------|--------------|--------------|
| L1 sub-states            | 3            | Supported    |
| OBFF                     | 3            | Supported    |
| LTR                      | 3            | Supported    |
| SR-IOV                   | 2.1          | Supported    |
| ARI Capability           | 2.1          | Supported    |
| DPC                      | 3            | Supported    |
| TLP Prefixes             | 2.1          | Supported    |
| FLR                      | 2.1          | Supported EP |
| ASPM Optionality         | 2.1          | Supported    |
| TLP Processing Hints     | 2.1          | Supported    |
| Extended Tag Enable      | 2.1          | Supported    |
| ID Based Ordering        | 2.1          | Supported    |
| Atomic Operations        | 2.1          | Supported    |
| ARI Capability           | 2.1          | Supported    |
| Address Translation Serv | 2.1          | Supported    |

## 1.7 Related Documentation

After the VIP is downloaded and installed, product documentation resides at the following location:

`$DESIGNWARE_HOME/vip/pcie_svt/latest/doc/`

For more information on the product documentation, see *PCIe SVT Release Notes*, which is installed at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_release_notes.pdf`

# 2 Installation and Setup

---

This section leads you through installing and setting up the VC PCIe. When you complete this checklist, the provided example testbench will be operational and the VC PCIe will be ready to use.

The checklist consists of the following major steps:

1. [Verifying the Hardware Requirements](#)
2. [Verifying Software Requirements](#)
3. [Preparing for Installation](#)
4. [Downloading and Installing](#)
5. [What's Next?](#)

This chapter contains the following additional topics:

- ❖ [Licensing Information](#)
- ❖ [Environment Variable and Path Settings](#)
- ❖ [Determining Your Model Version](#)
- ❖ [Integrating a VC VIP into Your Testbench](#)



If you encounter any problems with installing the VC PCIe, see *Customer Support*.

## 2.1 Verifying the Hardware Requirements

The PCIe Verification IP requires a Solaris or Linux workstation configured as follows:

- ❖ 1200 MB available disk space for installation
- ❖ 16 GB Virtual memory (recommended)
- ❖ FTP anonymous access to [ftp.synopsys.com](http://ftp.synopsys.com) (optional)

## 2.2 Verifying Software Requirements

The VC PCIe is qualified for use with certain versions of platforms and simulators. This section lists software that the VC PCIe requires.

### 2.2.1 Platform/OS and Simulator Software

- ❖ **Platform/OS and VCS:** You need versions of your platform/OS and simulator that have been qualified for use. To see which platform/OS and simulator versions are qualified for use with the PCIe VIP, check the support matrix for "SVT-based" VIP in the following document:

**Support Matrix for SVT-Based Synopsys PCIe VIP is in:**

*Synopsys PCIe Release Notes*

### 2.2.2 Synopsys Common Licensing (SCL) Software

- ❖ The SCL software provides the licensing function for the VC PCIe. Acquiring the SCL software is covered here in the installation instructions in [Licensing Information](#).

### 2.2.3 Other Third Party Software

- ❖ **Adobe Acrobat:** VC PCIe documents are available in Acrobat PDF files. You can get Adobe Acrobat Reader for free from <http://www.adobe.com>.
- ❖ **HTML browser:** VC PCIe includes class reference documentation in HTML. The following browser/platform combinations are supported:
  - ◆ Microsoft Internet Explorer 6.0 or later (Windows)
  - ◆ Firefox 1.0 or later (Windows and Linux)
  - ◆ Netscape 7.x (Windows and Linux)

## 2.3 Preparing for Installation

1. Set DESIGNWARE\_HOME to the absolute path where Synopsys PCIe VIP is to be installed:

```
setenv DESIGNWARE_HOME absolute_path_to_designware_home
```

2. Ensure that your environment and PATH variables are set correctly, including:

- ◆ DESIGNWARE\_HOME/bin - The absolute path as described in the previous step.
- ◆ LM\_LICENSE\_FILE - The absolute path to a file that contains the license keys for your third-party tools. Also, include the absolute path to the third party executable in your PATH variable.  

```
% setenv LM_LICENSE_FILE <my_license_file | port@host>
```
- ◆ SNPSLMD\_LICENSE\_FILE - The absolute path to a file that contains the license keys for Vera and Synopsys Common Licensing software or the *port@host* reference to this file.  

```
% setenv SNPSLMD_LICENSE_FILE $LM_LICENSE_FILE
```

## 2.4 Downloading and Installing



The Electronic Software Transfer (EST) system only displays products your site is entitled to download. If the product you are looking for is not available, contact [est-ext@synopsys.com](mailto:est-ext@synopsys.com).

Follow the instructions below for downloading the software from Synopsys. You can download from the Download Center using either HTTPS or FTP, or with a command-line FTP session. If your Synopsys SolvNet password is unknown or forgotten, go to <https://solvnetplus.synopsys.com>.

Passive mode FTP is required. The passive command toggles between passive and active mode. If your FTP utility does not support passive mode, use http. For additional information, refer to the following web page: [https://www.synopsys.com/apps/protected/support/EST-FTP\\_Accelerator\\_Help\\_Page.html](https://www.synopsys.com/apps/protected/support/EST-FTP_Accelerator_Help_Page.html)

### 2.4.1 Downloading From the Electronic Software Transfer (EST) System (Download Center)

1. Point your web browser to "<https://solvnet.synopsys.com/DownloadCenter>".
2. Enter your Synopsys SolvNetPlus Username and Password.
3. Click "Sign In" button.
4. Choose "Verification Compiler Verification IP" from the list of available products under "My Product Releases"
5. Select the Product Version from the list of available versions.
6. Click the "Download Here" button for HTTPS download.
7. After reading the legal page, click on "Yes, I agree to the above terms".
8. Click the download button(s) next to the file name(s) of the file(s) you wish to download.
9. Follow browser prompts to select a destination location.
10. You may download multiple files simultaneously.



The Protocol Analyzer is not included in the PCIe VIP download. It is a separate download, which you can get using the procedure above and selecting the Protocol Analyzer file, `vip_pa_version_run`, in step 8.

### 2.4.2 Downloading Using FTP with a Web Browser

1. Follow the above instructions through the product version selection step.
2. Click the "Download via FTP" link instead of the "Download Here" button.
3. Click the "Click Here To Download" button.
4. Select the file(s) that you want to download.
5. Follow browser prompts to select a destination location.

If you are unable to download the Verification IP using above instructions, see *Customer Support* section to obtain support for download and installation.

## 2.5 What's Next?

The remainder of this chapter describes the details of the different steps you performed during installation and setup, and consists of the following sections:

- ❖ [Licensing Information](#)
- ❖ [Environment Variable and Path Settings](#)
- ❖ [Determining Your Model Version](#)
- ❖ [Integrating a VC VIP into Your Testbench](#)

## 2.6 Licensing Information

The PCIe uses the Synopsys Common Licensing (SCL) software to control its usage. You can find general SCL information at:

<http://www.synopsys.com/keys>



The Synopsys PCIe VIP uses a licensing mechanism that is enabled by the following license features which includes Gen3, Gen4 and Gen5.

- ❖ Gen1-Gen2: VIP-PCIE-SVT, VIP-SOC-LIBRARY-SVT
- ❖ Gen1-Gen3: VIP-PCIE-SVT + VIP-PCIE-G3-OPT-SVT, VIP-SOC-LIBRARY-SVT
- ❖ Gen1-Gen4: VIP-PCIE-G4-SVT, Gen1-Gen5: VIP-PCIE-G5-SVT, VIP-PCIE-G5-BETA-SVT

Only one license is consumed per simulation, regardless of how many PCIe VIP models are instantiated in the design. Each of the above features can also be enabled by VIP Library license. For more details, see *VC VIP Library Release Notes*

Note the following:

- ❖ When G3 is being used, the VIP will consume the VIP-PCIE-G3-OPT-SVT license key in addition to VIP-PCIE-SVT or VIP-LIBRARY-SVT + DesignWare-Regression
- ❖ When G4 is being used, the VIP will consume VIP-PCIE-G4-SVT key or VIP-LIBRARY-SVT + DesignWare-Regression
- ❖ When G5 is being used, the VIP will consume the VIP-PCIE-G5-SVT or VIP-LIBRARY-SVT + DesignWare-Regression + VIP-PCIE-G5-BETA-SVT

The licensing key must reside in files that are indicated by specific environment variables. For information about setting these licensing environment variables, refer to [Environment Variable and Path Settings](#).

### 2.6.1 Controlling License Usage

Using the DW\_LICENSE\_OVERRIDE environment variable, you can control which license is used as follows.

To use only DesignWare-Regression and VIP-LIBRARY-SVT licenses, set DW\_LICENSE\_OVERRIDE to:

DesignWare-Regression VIP-LIBRARY-SVT

To use only a VIP-PCIE-SVT license, set DW\_LICENSE\_OVERRIDE to:

VIP-PCIE-SVT

If DW\_LICENSE\_OVERRIDE is set to any value and the corresponding feature is not available, a license

error message is issued.

### 2.6.1.1 License Polling

If you request a license and none are available, license polling allows your request to exist until a license becomes available instead of exiting immediately. To control license polling, you use the DW\_WAIT\_LICENSE environment variable as follows:

- ❖ To enable license polling, set the DW\_WAIT\_LICENSE environment variable to 1.
- ❖ To disable license polling, unset the DW\_WAIT\_LICENSE environment variable. By default, license polling is disabled.

### 2.6.1.2 Simulation License Suspension

All Synopsys Verification IP products support license suspension. Simulators that support license suspension allow a model to check in its license token while the simulator is suspended, then check the license token back out when the simulation is resumed.

**Note**

This capability is simulator-specific; not all simulators support license check-in during suspension.

## 2.7 Environment Variable and Path Settings

The following are environment variables and path settings required by the PCIe verification models:

- ❖ DESIGNWARE\_HOME – The absolute path to where the VIP is installed.
- ❖ SNPSLMD\_LICENSE\_FILE – The absolute path to a file that contains the license keys for Synopsys Common Licensing software or the *port@host* reference to this file.
- ❖ LM\_LICENSE\_FILE – The absolute path to a file that contains the license keys for your third-party tools. Also, include the absolute path to the third party executable in your PATH variable.

### 2.7.1 Simulator-Specific Settings

Your simulation environment and PATH variables must be set as required to support your simulator.

## 2.8 Determining Your Model Version

The following steps tell you how to check the version of the models you are using.

Note: Verification IP products are released and versioned by the suite and not by individual model. The version number of a model indicates the suite version.

- ❖ To determine the versions of VIP models installed in your \$DESIGNWARE\_HOME tree, use the setup utility as follows:  

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -i home
```
- ❖ To determine the versions of VIP models in your design directory, use the setup utility as follows:  

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -p design_dir_path -i design
```

## 2.9 Integrating a VC VIP into Your Testbench

After you have installed the VIP, you must set up the VIP for project and testbench use. All Verification Compiler VIP suites contain various components such as transceivers, masters, slaves, and monitors

depending on the protocol. The setup process gathers together all the required component files you need to incorporate into your testbench and simulation runs.

For more information, see the [PCIe EP/RC DUT Integration Guide](#), which is installed at the following location:  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_ep_rc_integration_guide.pdf`

## 2.9.1 Setting Up Project Directory

All VIPs for a particular project must be set up in a single common directory once you execute the \*.run file. You may have different projects. In this case, the projects can use their own VIP setup directory. However, all the VIPs used by that specific project must reside in a common directory.

The examples in this chapter call that directory `design_dir` but you can use any name. In this example, assume you will use the `pcie_svt` and AXI VIP suites in the design. Your `$DESIGNWARE_HOME` contains both `pcie_svt` and AXI VIPs.

First, install a `pcie_svt` example into the `design_dir` directory. After the `pcie_svt` example has been installed, the VIP suite must be set up in and located in the same `design_dir` directory as the `pcie_svt` VIP. Use the following commands to perform those steps:

```
// First install the pcie_svt unified UVM example:  
% $DESIGNWARE_HOME/bin/dw_vip_setup -path design_dir -e  
    pcie_svt/tb_pcie_svt_uvm_unified_vip_sys -svtb  
  
// Add AXI to the same design_dir as the pcie_svt:  
% $DESIGNWARE_HOME/bin/dw_vip_setup -path design_dir -add axi_system_env_svt -svlog
```

By default, all of the VIPs use the latest installed version of SVT. Synopsys maintains backward compatibility with previous versions of SVT. As a result, you may mix and match models using previous versions of SVT.

The following command adds the full model to the `design_dir` directory.

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -path /installation/design_dir -add  
    pcie_device_agent_svt
```

This command sets up all the required files in `/tmp/design_dir`. The `dw_vip_setup` utility creates three directories under `design_dir` which contain all the necessary model files. Files for every VIP are included in these three directories.

- ❖ **examples.** Each VIP includes example testbenches. The `dw_vip_setup` utility adds them in this directory, along with a script for simulation. If an example testbench is specified on the command line, this directory contains all files required for model, suite, and system testbenches.
- ❖ **include.** Language-specific include files that contain critical information for VC models. This directory "include/sverilog" is specified in simulator commands to locate model files.
- ❖ **src.** Synopsys-specific include files. This directory "src/sverilog/vcs" must be included in the simulator command to locate model files.

Note that some components are “top level” and will setup the entire suite. You have the choice to set up the entire suite, or just one component such as a monitor.



There **must** be only one `design_dir` installation per simulation, regardless of the number of Synopsys Verification and Implementation VIPs you have in your project. Create this directory in `$DESIGNWARE_HOME`.

### 2.9.1.1 Getting Help on Example Run/make Scripts

You can get help on the generated make/run scripts in the following ways:

1. Invoke the run script with no switches, as in:

```
run_PCIE_SVT_UVM_Unified_VIP_Sys
usage: run_PCIE_SVT_UVM_Unified_VIP_Sys [-32] [-verbose] [-debug] [-waves] [-clean] [-nobuild] [-norun] [-pa] <scenario> <simulator>
where <scenario> is one of: address_transformation_test base_multi_link_test
base_pie8_eq_test base_pipe5_in_serdes_arch_mode_test base_pipe5_test base_pipe_test
base_pma_test base_serdes5_test base_serdes_test basic_ptm_test
<simulator> is one of: vcsvlog vcsmxvlog mtivlog vcsmxpcvlog vcsmxpipvlog ncvlog
vcspcvlog
-32      forces 32-bit mode on 64-bit machines
-verbose enable verbose mode during compilation
-debug    enable debug mode for SVT simulations
-waves   [fsdb|verdi|dump] enables waves dump and optionally opens viewer
(VCS only)
-clean   clean simulator generated files
-nobuild skip simulator compilation
-norun   exit after simulator compilation
-pa      invoke PA after execution
```

2. Invoke the make file with help switch as in:

```
gmake help
Usage: gmake USE_SIMULATOR=<simulator> [VERBOSE=1] [DEBUG=1] [FORCE_32BIT=1]
[WAVES=fsdb|verdi|dump] [NOBUILD=1] [PA=1] [<scenario> ...]
Valid simulators are: vcsvlog vcsmxvlog mtivlog vcsmxpcvlog vcsmxpipvlog ncvlog
vcspcvlog
Valid scenarios are: address_transformation_test base_multi_link_test base_pie8_eq_test
base_pipe5_in_serdes_arch_mode_test base_pipe5_test base_pipe_test base_pma_test
base_serdes5_test base_serdes_test basic_ptm_test
```

**Note:** You must have PA installed if you use the -pa or PA=1 switches.

### 2.9.1.2 Compile-time and Runtime Options

Every Synopsys provided example has ASCII files containing compile and run time options. The examples for the model are located in:

```
$DESIGNWARE_HOME/vip/svt/pcie/latest/examples/sverilog/<test_name>
```

The files containing the options are:

- ❖ sim\_build\_options (also vcs\_build\_options)
- ❖ sim\_run\_options (also vcs\_run\_options)

These files contain both optional and required switches.

## 2.9.2 Updating an Existing Model

To add an update to an existing model, perform the following steps:

1. Set the \$DESIGNWARE\_HOME environment variable to the latest version.
2. Navigate to the directory where the existing *design\_dir* is present (and not into the *design\_dir*).

3. Update the directory with the latest release by passing the model name, "pcie\_device\_agent\_svt" to -add option while running the dw\_vip\_setup application.

Example:

```
$DESIGNWARE_HOME/bin/dw_vip_setup -path <existing_design_dir_name> -add  
pcie_device_agent_svt
```



**Note** In case of any backward incompatible changes in the VIP, you need to update the *design\_dir* by reinstalling the example in same location and/or update the testbench files accordingly by referring to the backward incompatible changes listed in the *Release Notes*.

# 3 General Concepts

---

This chapter describes the usage of the PCIe VIP in a UVM environment, and its user interface. This chapter discusses the following topics:

- ❖ [Introduction to UVM](#)
- ❖ [PCIe UVM Interface](#)
- ❖ [SVT Service Sequence/Sequencer](#)

## 3.1 Introduction to UVM

UVM is an object-oriented approach. It provides a blueprint for building testbenches using constrained random verification. The resulting structure also supports directed testing.

This chapter describes the usage of the PCIe VIP in UVM environment, and its user interface. Refer to the Class Reference HTML for a description of attributes and properties of the objects mentioned in this chapter.

This chapter assumes that you are familiar with SystemVerilog and UVM. For more information:

- ❖ For the IEEE SystemVerilog standard, see:
  - ◆ IEEE Standard for SystemVerilog – Unified Hardware Design, Specification, and Verification Language
- ❖ For essential guides describing UVM as it is represented in SystemVerilog, along with a Class Reference, see [www.accellera.org](http://www.accellera.org).

## 3.2 PCIe UVM Interface

The Verification Compiler UVM VIP for PCIe is a suite of advanced verification components and data objects based on SystemVerilog UVM-compliant technology. The Verification Compiler UVM PCIe VIP is based on the following UVM agent architecture and data objects.

### **svt\_PCIE\_device\_agent**

The **svt\_PCIE\_device\_agent** object defines a UVM agent that contains the following uvm\_components for PCIe applications:

- ❖ Driver

- ❖ Target
- ❖ Requester
- ❖ IO target
- ❖ Memory target
- ❖ Configuration database
- ❖ Global shadow

The **svt\_PCIE\_device\_agent** object contains a UVM agent named **svt\_PCIE\_agent**. The PCIe UVM subenvironment contains active PCIe applications to send and receive PCIe packets as well as UVM sequencers and sequences. Your testbench will interact mainly with UVM sequencers, which can use either Verification Compiler-provided sequences or your own sequences.

### **svt\_PCIE\_agent**

The **svt\_PCIE\_agent** object defines a UVM agent that contain a layered stack of **uvm\_components** for the Physical, Link, and Transaction layers of the PCIe protocol. The PCIe UVM agent contains active PCIe Physical, Link, and Transaction **uvm\_components**, as well as UVM sequencers and sequences. Your testbench will interact mainly with UVM sequencers which can use either Verification Compiler-provided sequences, or your own sequences.

#### **3.2.1 UVM Components of the PCIe Device Subenvironment**

- ❖ **svt\_PCIE\_driver\_app** - A **uvm\_component** object that implements the PCIe Driver application, which transmits PCIe packets to PCIe transaction layer.
- ❖ **svt\_PCIE\_requester\_app** - A **uvm\_component** object that implements the PCIe Requester application, which supports generating Memory reads and writes towards the programmed Memory segment.
- ❖ **svt\_PCIE\_target\_app** - A **uvm\_component** object that implements the PCIe Target application, which is responsible for responding to received requests by generating completion packets.
- ❖ **svt\_PCIE\_io\_target** - A **uvm\_component** object that supports the IO segment of the PCIe system.
- ❖ **svt\_PCIE\_mem\_target** - A **uvm\_component** object that supports the Memory segment of the PCIe system.
- ❖ **svt\_PCIE\_cfg\_database** - A **uvm\_component** object that supports the Configuration space of the PCIe system.
- ❖ **svt\_PCIE\_global\_shadow** - A **uvm\_component** object that implements the PCIe Device system IO, Memory and Configuration spaces.

#### **3.2.2 UVM Components of the PCIe MAC Agent**

- ❖ **svt\_PCIE\_tl** - A **uvm\_component** object that implements the PCIe Transaction Layer.
- ❖ **svt\_PCIE\_dl** - A **uvm\_component** object that implements the PCIe Link Layer.
- ❖ **svt\_PCIE\_pl\_phy** - A **uvm\_component** object that implements the PCIe Physical Layer.

#### **3.2.3 Configuration Data Objects**

Configuration data objects are abstracted data objects that represent the content of PCIe VIP configuration data and protocol transactions. The top-level configuration data objects are:

- ❖ svt\_PCIE\_Device\_Configuration
  - ◆ svt\_PCIE\_Driver\_App\_Configuration
  - ◆ svt\_PCIE\_Requester\_App\_Status
  - ◆ svt\_PCIE\_Target\_App\_Configuration
  - ◆ svt\_PCIE\_Configuration
    - ❖ svt\_PCIE\_TL\_Configuration
    - ❖ svt\_PCIE\_DL\_Configuration
    - ❖ svt\_PCIE\_PL\_Configuration

The following illustration shows the inheritance diagram for all the configuration objects.

**Figure 3-1 Inheritance Diagram for All Configuration Objects**



In your environment you can access these variables from `pcie_env_cfg env_cfg` as shown below:  
`env_cfg.m_PCIE_VIP_Cfg.pcie_cfg.tl_cfg <=> >;`  
`env_cfg.m_PCIE_VIP_Cfg.pcie_cfg.dl_cfg <=> >;`  
`env_cfg.m_PCIE_VIP_Cfg.pcie_cfg.pl_cfg <=> >;`  
  
`env_cfg.m_PCIE_VIP_Cfg.driver_cfg[0] <=> >;`  
`env_cfg.m_PCIE_VIP_Cfg.requester_cfg <=> >;`  
`env_cfg.m_PCIE_VIP_Cfg.target_cfg[0] <=> >;`

### 3.2.4 Status Data Objects

Status data objects are abstracted data objects that represent the content of PCIe VIP statistics. Registered status objects are updated in realtime. Separate statistics are kept per layer/application. Status objects are useful for:

- ❖ functional coverage
- ❖ reporting testcase progress
- ❖ debug

The top-level status data objects are:

- ❖ svt\_PCIE\_Device\_Status
  - ◆ svt\_PCIE\_Requester\_App\_Status
  - ◆ svt\_PCIE\_Target\_App\_Status
  - ◆ svt\_PCIE\_IO\_Target\_Status
  - ◆ svt\_PCIE\_Mem\_Target\_Status

- ◆ svt\_PCIE\_Status
  - ✧ svt\_PCIE\_TL\_Status
  - ✧ svt\_PCIE\_DL\_Status
  - ✧ svt\_PCIE\_PL\_Status

Following are some examples of the type of status data you can obtain.

- ❖ Target Application
  - # bytes received
  - # bytes sent
  - # msg CPL sent
  - # num TLPS received
- ❖ Phy Layer
  - #LTSSM state
  - # hot resets initialized
- ❖ Link Layer
  - # ack received
  - # bad tlp sent
  - # EI RX TLP withhold ack / nack
- ❖ Transaction Layer
  - # bad TLPS received
  - # TC5 TLPS sent

An example of waiting for link activation:

```
svt_PCIE_Device_Status stat;
stat = svt_PCIE_Device_Status::type_id::create("stat");

// wait for link activation
wait(stat.port_status.pl_status.link_up == 1'b1);
```

### 3.2.5 Sequence Item Data Objects

The VIP supports extending UVM sequence item data classes for customizing randomization constraints. This allows you to disable some reasonable\_\* constraints and replace them with constraints appropriate to your system. Individual reasonable\_\* constraints map to independent fields, each of which can be disabled. The following are the sequence data item classes:

- ❖ svt\_PCIE\_Driver\_App\_Transaction
- ❖ svt\_PCIE\_Io\_Target\_Service
- ❖ svt\_PCIE\_Mem\_Target\_Service
- ❖ svt\_PCIE\_Cfg\_Database\_Service
- ❖ svt\_PCIE\_Global\_Shadow\_Service
- ❖ svt\_PCIE\_Driver\_App\_Service

- ❖ svt\_PCIE\_requester\_app\_service
- ❖ svt\_PCIE\_target\_app\_service
- ❖ svt\_PCIE\_tl\_service
- ❖ svt\_PCIE\_dl\_service
- ❖ svt\_PCIE\_pl\_service

### 3.3 SVT Service Sequence/Sequencer

Each component in the agent has its own service sequencer. All SVT sequences are derived from uvm\_sequence. Sequences or individual sequence items are executed on the appropriate sequencer.

A *p\_sequencer* is instantiated with a macro in the top sequence as shown below:

```
`uvm_declare_p_sequencer  
(svt_PCIE_device_system_virtual_sequencer)
```

The following figure shows the elements of the *p\_sequencer*:





# 4 Verification Features

This chapter describes the various verification features available with the Synopsys PCIe Verification IP. This chapter discusses the following topics:

- ❖ [The Transaction Logger](#)
- ❖ [The Symbol Logger](#)
- ❖ [The MBI Logger](#)
- ❖ [The CTRL SKP Logger](#)
- ❖ [Using Native Protocol Analyzer for Debugging](#)
- ❖ [Verification Planner](#)
- ❖ [Global Shadow Memory](#)
- ❖ [Target Memory](#)
- ❖ [Data Link Monitor](#)

## 4.1 The Transaction Logger

All inbound and outbound transactions to or from the VIP (both TLPs and DLLPs) are sent to the transaction logger. These transactions are distilled and written (one transaction per line) to the transaction log file.

By default, the transaction logger is disabled. To enable it, and cause it to start writing transactions to a file, use the `enable_transaction_logging` member of the `svt_PCIE_configuration` class, as shown in the following example:

```
class example extends uvm_test;
  .
  .
  .
  virtual function void task build_phase(uvm_phase phase);
    super.build_phase(phase);
  .
  .
  .
  endpoint_cfg.port_cfg.enable_transaction_logging = 1;
  endpoint_cfg.port_cfg.transaction_log_filename = "pcie_trans.log";
  .
  .
endfunction
endclass
```

The transaction log filename will be appended to the full hierarchical name of the port0 instance generating it.

#### 4.1.1 Printing TLP Payload Data to a Transaction Log File

The Synopsys provided unified example shows how to print TLP payload data to the Transaction log. You must first enable transaction logging. By default it is off. Also, set the filename of the transaction log.

```
class pcie_shared_cfg extends uvm_object;
...
/** Setup the PCIE device system default values */
function void setup_PCIE_device_system_defaults();
begin
...
root_cfg.pcie_cfg.enable_transaction_logging = 1'b1;
root_cfg.pcie_cfg.transaction_log_filename = "transaction.log";
root_cfg.pcie_cfg.enable_symbol_logging = 1'b1;
root_cfg.pcie_cfg.symbol_log_filename = "symbol.log";
```

Next, set how many dwords of the payload you want the model to write into the transaction log file.

```
class pcie_device_base_test extends uvm_test;
...
virtual function void build_phase(uvm_phase phase);
`uvm_info("build_phase", "Entered...", UVM_LOW)
super.build_phase(phase);
...
/** Set the payload display limit */
svt_PCIE_DL_DISP_PATTERN::default_max_payload_print_dwords = 1024;
```

Note the default is zero. In the example, it has been set to 1024.

#### 4.1.2 Fields of the Transaction Log Header

The fields of the transaction log header are described in this section. These fields are listed from left to right as they appear on the header.

**Field:** Reporter

**Description:**

This field represents an instance of the VIP in the test environment. The transaction log information is reported for this VIP instance.

**Field:** Start Time (ns)

**Description:**

This field represents the simulation time in ns when the transaction starts.

**Field:** End Time (ns)

**Description:**

This field represents the simulation time in ns when the transaction ends.

**Field:** Dir**Description:**

This field represents the direction of the transaction from the VIP instance. "T" represents a transmit transaction. "R" represents a receive transaction.

**Field:** TLP Type

DLLP Type

**Description:**

This field represents the type of TLP (Transaction Layer Packet) or DLLP (Data Link Layer Packet) as defined in Table 2-3 and Table 3-1 of the PCIe Specification respectively. For TLP memory read (MRd) and memory write (MWr) packets, a "32" or "64" is appended to the type. This number represents a 32-bit or 64-bit memory addressing.

For example:

MRd32

MWr64

**Field:** R\_ID / Tag | ST**Description:**

This field has 2 different representations for a TLP transaction. The Requester ID and Tag are displayed, or the Steering Tag is displayed. This field is blank for DLLP transactions.

| TLP Field | Description      |
|-----------|------------------|
| R_ID/Tag  | Requester ID/Tag |
| ST        | Steering tag     |

For example:

*TLP*

| Reporter | Start Time<br>(ns) | End Time<br>(ns) | Dir | TLP Type<br>DLLP Type | R_ID/Tag  <br>ST |
|----------|--------------------|------------------|-----|-----------------------|------------------|
| vip0     | 133328.00          | 133340.00        | T   | <b>CfgRd0</b>         | <b>0x0001/13</b> |
| vip0     | 159140.00          | 159160.00        | T   | <b>MRd32</b>          | <b>0x0001/1f</b> |

*DLLP*

| Reporter | Start Time<br>(ns) | End Time<br>(ns) | Dir | TLP Type<br>DLLP Type | R_ID/Tag  <br>ST |
|----------|--------------------|------------------|-----|-----------------------|------------------|
|----------|--------------------|------------------|-----|-----------------------|------------------|

```

vip0      133328.00 133328.00 R INITFC2_P_VCO
vip0      133772.00 133772.00 R ACK

```

**Field:** Seq Num**Description:**

This field represents the sequence number of the transaction.

**Field:** TC VC**Description:**

This field represents the value of the Traffic Class field of the TLP.

**Field:** TH**Description:**

This field represents the 1-bit TH field of the common TLP packet header. The TH field is an indication of the TLP Processing Hints (TPH) and the Optional TPH TLP Prefix when applicable presented in the TLP header.

**Field:** PH**Description:**

This field represents processing hint.

**Field:** IDO RO**Description:**

These 2 fields represent the Ordering Attribute Bits as defined in Table 2-10 of the PCIe Specification. The table is shown below.

| <b>Attribute Bit [2]<br/>(IDO)</b> | <b>Attribute Bit [1]<br/>(RO)</b> | <b>Ordering Type</b>                    | <b>Ordering Model</b>                                |
|------------------------------------|-----------------------------------|-----------------------------------------|------------------------------------------------------|
| 0                                  | 0                                 | Default Ordering                        | PCI Strongly Ordered Model                           |
| 0                                  | 1                                 | Relaxed Ordering                        | PCI-X Relaxed Ordering Model                         |
| 1                                  | 0                                 | ID-Based Ordering                       | Independent ordering based on Requester/Completer ID |
| 1                                  | 1                                 | Relaxed Ordering plus ID-Based Ordering | Logical "OR" of Relaxed Ordering and IDO             |

**Field:** NS**Description:**

This field represents the No Snoop bit value of the TLP.

**Field:** Address

Reg#/MsgRt/Cpl

HdrFC DataFC

**Description:**

This field has multiple representations. For a TLP transaction, the value(s) displayed depends on the TLP type as shown in the following table. For a DLLP transaction, the Flow Control header and data are displayed.

| TLP Field                                | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| < address >                              | <b>Memory request:</b><br>This field represents the memory address.                                                                                                                                                                                                                                                                                                                                                       |
| < address >                              | <b>IO request:</b><br>This field represents the IO address.                                                                                                                                                                                                                                                                                                                                                               |
| BDF: < > R: < ><br>or<br>BDF: < > O: < > | <b>Configuration request:</b><br>"BDF" represents the bus device function.<br>"R" represents the register number.<br>"O" represents the register byte offset. This offset is not displayed by default. To enable the display, you must set the dl_trace_options[1] attribute of the PCIe configuration class (svt_PCIE_configuration).<br>For example:<br><code>&lt;agent cfg&gt;.pcie_cfg.dl_trace_options[1] = 1</code> |
| < message >                              | <b>Message request:</b><br>This field represent the message routing as defined in Table 2-18 of the PCIe Specification.                                                                                                                                                                                                                                                                                                   |
| ID: < > Stat: < >                        | <b>Completion request:</b><br>"ID" represents the Completion ID.<br>"Stat" represents the Completion status as defined in Table 2-29 of the PCIe Specification. The status are SC, UR, CRS and CA.                                                                                                                                                                                                                        |
| DLLP Field                               | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
| < header > < data >                      | Flow Control header and data                                                                                                                                                                                                                                                                                                                                                                                              |

For example:

*TLP:*

| Reporter | Start Time<br>(ns) | End Time<br>(ns) | Dir | TLP Type<br>DLLP Type | R_ID/Tag<br>  ST | Seq<br>Num | TC<br>VC | T<br>H | P<br>H | I<br>D | R<br>O | N<br>S | Address<br>Reg#/MsgRt/Cpl<br>O<br>HdrFC<br>DataFC |
|----------|--------------------|------------------|-----|-----------------------|------------------|------------|----------|--------|--------|--------|--------|--------|---------------------------------------------------|
| vip0     | 159140.00          | 159160.00        | T   | MRd32                 | 0x0001/1f        | 139        | 0        | 0      | 0      | 0      | 0      | 0      | 0x00245a28                                        |

|      |           |           |   |        |           |     |   |   |   |   |   |   |                                   |
|------|-----------|-----------|---|--------|-----------|-----|---|---|---|---|---|---|-----------------------------------|
| vip0 | 133500.00 | 133520.00 | T | CfgWr0 | 0x0001/1c | 2   | 0 | 0 | 0 | 0 | 0 | 0 | BDF:0x0000 R:0x004                |
| vip0 | 133304.00 | 133324.00 | T | MsgD   | 0x0001/18 | 0   | 0 | 0 | 0 | 0 | 0 | 0 | Local Term Rcvr ID:0x0002 Stat:SC |
| vip0 | 158868.00 | 158872.00 | R | CplD   | 0x0001/1e | 136 | 0 | 0 | 0 | 0 | 0 | 0 | BC:0004                           |

**DLLP**

| Reporter | Start Time<br>(ns) | End Time<br>(ns) | Dir | TLP Type<br>DLLP Type | R_ID/Tag<br>  ST | Seq<br>Num | TC<br>VC | T<br>H | P<br>H | I | R | N | Address        |
|----------|--------------------|------------------|-----|-----------------------|------------------|------------|----------|--------|--------|---|---|---|----------------|
|          |                    |                  |     |                       |                  |            |          |        |        | D | O | S | Reg#/MsgRt/Cpl |
| vip0     | 133596             | 133596           | R   | ACK                   |                  | 2          |          |        |        |   |   |   | 116 230        |
| vip0     | 133124             | 133124           | T   | INITFC1_P_VCO         |                  |            |          |        |        |   |   |   | 102 1024       |

**Field:** BE | ST

BC

MCode

**Description:**

This field has multiple representations of a TLP transaction.

| TLP Field        | Description                                                                                                         |
|------------------|---------------------------------------------------------------------------------------------------------------------|
| < byte enable >  | <b>Memory request/IO request/Configuration request:</b><br>This field represents the byte enable.                   |
| < steering tag > | <b>Memory request:</b><br>When the TH field has a value of "1", this field represents the steering tag value.       |
| BC: < >          | <b>Completion request:</b><br>BC represents the byte count.                                                         |
| < message code > | <b>Message request:</b><br>This field represent the message code as defined in Table F-1 of the PCIe Specification. |

For example:

| Reporter | Start Time<br>(ns) | End Time<br>(ns) | Dir | TLP Type<br>DLLP Type | R_ID/Tag<br>  ST | Seq<br>Num | TC<br>VC | T<br>H | P<br>H | I | R | N | Address           | BE   ST |
|----------|--------------------|------------------|-----|-----------------------|------------------|------------|----------|--------|--------|---|---|---|-------------------|---------|
|          |                    |                  |     |                       |                  |            |          |        |        | D | O | S | Reg#/MsgRt/Cpl    | BC      |
| vip0     | 133304.00          | 133324.00        | T   | MsgD                  | 0x0001/18        | 0          | 0        | 0      | 0      | 0 | 0 | 0 | Local Term Rcvr   | 0x50    |
| vip0     | 158896.00          | 159124.00        | T   | MWr32                 | 0x0001/09        | 138        | 0        | 0      | 0      | 0 | 0 | 0 | 0x00245a28        | 1 c     |
| vip0     | 158868.00          | 158872.00        | R   | CplD                  | 0x0001/1e        | 136        | 0        | 0      | 0      | 0 | 0 | 0 | ID:0x0002 Stat:SC | BC:0004 |

**Field:** Len/Idx

DW

**Description:**

This field has 2 representations of a TLP transaction.

| TLP Field          | Description                                                                                                                 |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| < payload length > | For the TLP Header displayed on the first row of data, this field represents the length of the payload in double word (DW). |
| < data index >     | For the TLP payload displayed from the second row of data and on, this field represents the accumulative count of DW data.  |

For example:

*MWr32*

| Len/Idx |           | Prefix / Header / Data<br>(All values in Hex) |           |          |
|---------|-----------|-----------------------------------------------|-----------|----------|
| DW      |           |                                               |           |          |
| 221     | H400000dd | H0001091c                                     | H00245a28 | ---      |
| 0       | 250e4795  | e0b18822                                      | 9c1a2b30  | a6824000 |
| 4       | 48105945  | caf812dd                                      | 8ed6f96b  | df547dae |
| 8       | 17505659  | 31998267                                      | b37c242c  | cc4f5f10 |
|         |           | < data continues >                            |           |          |
| 216     | 0a3336db  | 36bb1e9b                                      | df73a4c9  | 43d8486b |
| 220     | 00693366  | ---                                           | ---       | ---      |

In the above example, the "221" on the first row is the TLP payload length. The "0" through "220" on the subsequent rows are the data index.

*CfgRd0*

| Len/Idx |           | Prefix / Header / Data<br>(All values in Hex) |           |     |
|---------|-----------|-----------------------------------------------|-----------|-----|
| DW      |           |                                               |           |     |
| 1       | H04000001 | H00011e0f                                     | H00020000 | --- |

*CplID*

| Len/Idx |           | Prefix / Header / Data<br>(All values in Hex) |           |     |
|---------|-----------|-----------------------------------------------|-----------|-----|
| DW      |           |                                               |           |     |
| 1       | H4a000001 | H00010004                                     | H00011500 | --- |
| 0       | 06001000  |                                               |           |     |

**Field:** Prefix / Header / Data  
(All values in Hex)

**Description:**

This field represents the raw dword values of a TLP transaction.

- ❖ Values with an "(H)" prefix represent header DWORDS.
- ❖ Values with a "(P)" prefix represent the PCIe Prefix DWORDS.
- ❖ When the model is configured to show transaction data, values with a "(D)" prefix represent payload DWORDS.

By default, only the TLP header data is displayed along with the header fields. You can enable the display of payload data by using one of the following methods:

- a. In the build phase of the simulation, set the static attribute "default\_max\_payload\_print\_dwords" of class "svt\_PCIE\_DL\_DISP\_PATTERN" to the default maximum number of payload DWORDs to be displayed.
- b. Set the "SVT\_PCIE\_XACT\_LOG\_MAX\_PAYLOAD\_DWORD\_DEFAULT" macro to the default maximum number of payload DWORDs to be displayed.

Payload data for CfgWr and CfgRd (corresponding CplID) are displayed with a single DWORD. By default, this DWORD value is displayed in the Big Endian format. Alternatively, you can enable the DWORD to be displayed in the Little Endian format by setting the "dl\_trace\_options[0]" attribute of the PCIe configuration class (svt\_PCIE\_configuration).

For example:

*Default Big Endian payload data*

0 06001000

*Enable Little Endian format*

<agent cfg>.pcie\_cfg.dl\_trace\_options[0] = 1;

*Little Endian payload data*

0 00100006 LittleEndian

#### **Field: EP**

#### **Description:**

This field represents the poison bit as defined in the PCIe Specification.

#### **Field: ECRC**

#### **Description:**

This field represents the ECRC value of a TLP as defined in the PCIe Specification.

#### **Field: LCRC**

CRC

#### **Description:**

This field has 2 representations. For a TLP transaction, the LCRC value as defined in the PCIe Specification is displayed. For a DLLP transaction, the CRC value as defined in the PCIe Specification is displayed.

**Field:** TX/RX

Error

**Description:**

This field represents the type of error injection when error injection is enabled in a transmit (tx) transaction. For a receive (rx) transaction, this field represents the detected error.

| Error Injection Type | Description                                     |
|----------------------|-------------------------------------------------|
| BadSeq               | Illegal Sequence Number                         |
| CodeViol             | TX Code Violation                               |
| CrcEr                | LCRC LCRC Error                                 |
| Disparty             | Disparity Error                                 |
| DupSeq               | Duplicate Sequence Number                       |
| EIErr                | Scenario injects error, then vip reported this. |
| HdrCRC               | PCIE 8G Header CRC Error                        |
| HdrPAR               | PCIE 8G Header Parity Error                     |
| LCRC                 | LCRC Error                                      |
| NAK                  | NAK Received for TLP                            |
| NoACK                | Missing ACK for Transaction                     |
| NoEND                | Missing END                                     |
| NoSTART              | Missing START                                   |
| NoSTP                | NoSTART Missing START"                          |
| NullLCRC             | Nullified TLP with corrupt CRC                  |
| NullTLP              | Nullified TLP                                   |
| ReplCnt              | Replay count of 4 exceeded                      |

## 4.2 The Symbol Logger

One log file is created per simulation. All agents share the log file. Each agent must be enabled independently as shown in [Example 4-1](#). If more than one symbol\_log\_filename is set, then the last one set within the simulation serves as the filename. It is recommended that you have only one agent set the filename.

**Example 4-1**

```
class example extends uvm_test;  
  . . .
```

```

virtual function void task build_phase(uvm_phase phase);
    super.build_phase(phase);
    . .
    root_cfg.pcie_cfg.enable_symbol_logging = 1;           // Enable for RC
    endpoint_cfg.prot_cfg.enable_symbol_logging = 1;       // Enable for EP
    root_cfg.pcie_cfg.symbol_log_filename = "symbol.log"; // Recommended to only set
the filename once
    . .
endfunction
endclass

```

The symbol log filename will be appended to the full hierarchical name of the port0 instance generating it.

#### 4.2.1 Fields of the Symbol Log Header

The fields of the symbol log header are described in this section. These fields are listed from left to right as they appear on the header.

**Field:** TIME

**Description:**

This field represents the simulation time in ns. Symbol logging is performed at the PIPE interface. If the PIPE interface is configured as multiple bytes, all bytes transferred at a time step are logged at the same time step.

**Field:** INSTANCE

**Description:**

This field represents an instance of the VIP in the test environment. The symbol log information is reported for this VIP instance.

**Field:** < lane symbols >

**Description:**

This field represents symbols on the active lane(s). The format of the field header is:

R00 [R01] [R02] ... [R<n>] | T00 [T01] [T02] ... [T<n>]

Where, "R" represents the receive symbol on the lane. "T" represents the transmit symbol on the lane. <n> is the number of the highest configured lane.

The encoding of the lane symbols are listed in the following tables.

**Table 4-1 Special Symbol Encodings for All Link Data Rates**

| Symbol | Description              |
|--------|--------------------------|
| z      | Electrical idle          |
| ?      | Invalid or unknown value |

**Table 4-1 Special Symbol Encodings for All Link Data Rates**

| Symbol | Description                                                                                                                                                                                    |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .      | No information available to log. This may occur at startup, at changes to link speed or link width, or if the Rx and Tx sides are operating at offset time steps at either 2.5 GT/s or 5 GT/s. |
| q      | Error injection pending: appended on each symbol that will have disparity inverted. Only applies on TX lanes.                                                                                  |
| j      | Error injection pending: appended on each symbol that will have a random bit flipped. Only applies on TX lanes.                                                                                |
| v      | Error injection pending: appended on each symbol that will have an invalid encoding. Only applies on TX lanes.                                                                                 |

For link operation at 8GT/s, symbols after the sync headers are prepended with encodings of the sync headers listed in <Xref>Table 4-2. Additional encodings for link operation at 8GT/s are listed in <Xref>Table 4-3.

**Table 4-2 Sync Header Encodings for Link Operation at 8GT/s**

| Symbol | Description         |
|--------|---------------------|
| @      | 2'b'00 (Reserved)   |
| *      | 2'b'01 (OS block)   |
| =      | 2'b'10 (Data block) |
| \$     | 2'b'11 (Reserved)   |

**Table 4-3 Special Character Encodings for Link Operation at 8GT/s**

| Symbol | Description                                                                                                         |
|--------|---------------------------------------------------------------------------------------------------------------------|
| ::     | Data skip cycle (no valid data)                                                                                     |
| +      | Start of TLP Token. Prepended on 1st symbol of token. Replaces = symbol at start of block. Only noted on TX lanes.  |
| ^      | Start of DLLP Token. Prepended on 1st symbol of token. Replaces = symbol at start of block. Only noted on TX lanes. |

**Field:** LTSSM State**Description:**

This field represents the state of the LTSSM state machine as defined in section 4.2.5 of the PCIe specification. For states such as L0 and L0s where the receive (rx) and transmit (tx) LTSSM states may diverge, the rx and tx states are displayed separately. Otherwise, only a single state is displayed for both rx and tx states.

For example:

| TIME                 | INSTANCE  | R00                                           |     | T00 | ->  | LTSSM State  |     |     |     |     |    |                  |
|----------------------|-----------|-----------------------------------------------|-----|-----|-----|--------------|-----|-----|-----|-----|----|------------------|
| 208:                 | root0     | z                                             |     | z   | ->  | initializing |     |     |     |     |    |                  |
| 208:                 | endpoint0 | z                                             |     | z   | ->  | initializing |     |     |     |     |    |                  |
| 212:                 | root0     | z                                             |     | z   | ->  | initializing |     |     |     |     |    |                  |
| 212:                 | endpoint0 | z                                             |     | z   | ->  | initializing |     |     |     |     |    |                  |
| root0                |           | -- Detected change in link width from 1 to 4. |     |     |     |              |     |     |     |     |    |                  |
| TIME                 | INSTANCE  | R00                                           | R01 | R02 | R03 |              | T00 | T01 | T02 | T03 | -> | LTSSM State      |
| 216:                 | root0     | z                                             | z   | z   | z   |              | z   | z   | z   | z   | -> | Det.Quiet        |
| endpoint0            |           | -- Detected change in link width from 1 to 4. |     |     |     |              |     |     |     |     |    |                  |
| TIME                 | INSTANCE  | R00                                           | R01 | R02 | R03 |              | T00 | T01 | T02 | T03 | -> | LTSSM State      |
| 216:                 | endpoint0 | z                                             | z   | z   | z   |              | z   | z   | z   | z   | -> | Det.Quiet        |
| 220:                 | root0     | z                                             | z   | z   | z   |              | z   | z   | z   | z   | -> | Det.Quiet        |
| 220:                 | endpoint0 | z                                             | z   | z   | z   |              | z   | z   | z   | z   | -> | Det.Quiet        |
| < symbol continues > |           |                                               |     |     |     |              |     |     |     |     |    |                  |
| 26840:               | endpoint0 | 00                                            | 00  | 00  | 00  |              | a1  | 75  | 47  | aa  | -> | tx = L0, rx = L0 |
| 26841:               | root0     | a1                                            | 75  | 47  | aa  |              | 00  | 00  | 00  | 00  | -> | tx = L0, rx = L0 |
| 26841:               | endpoint0 | 00                                            | 00  | 00  | 00  |              | 5b  | 2c  | cd  | 17  | -> | tx = L0, rx = L0 |

#### 4.2.1.1 Configuration Messages in the Symbol Log

In addition to lane symbols, messages that indicate link changes are displayed in the symbol log. These messages are prepended by "--".

For example:

```
endpoint0      -- Detected change in link width from 1 to 4.
root0          -- Detected change in data rate to 8 Gt/s. See file header for special encodings.
```

#### 4.2.1.2 Symbol Log with OS Information

The current symbol log format has been enhanced to include OS information. This enhanced format is enabled by setting the configuration attribute

`svt_PCIE_configuration::enable_enhanced_symbol_log_format` to 1. When the enhanced format is enabled, the symbol log will also contain information about when and what OS are terminated on individual lanes. The default value of `enable_enhanced_symbol_log_format` is 0.

For most OS's this would be on the last symbol of the OS, but for some OS's that have indeterminate length like SKP OS the completion information would be associated with the COM/sync header of the next OS/data block.

#### Example 4-2

```
12367: root0  COM  COM  COM  COM | 4a   4a   4a   4a   -> Poll.Active
12371: root0  PAD  PAD  PAD  PAD | 4a   4a   4a   4a   -> Poll.Active
12375: root0  PAD  PAD  PAD  PAD | 4a   4a   4a   4a   -> Poll.Active
12379: root0  ff   ff   ff   ff  | 4a   4a   4a   4a   -> Poll.Active >TX:TS1_OS on L0
```

```

12383: root0 0e 0e 0e 0e | COM 4a 4a 4a -> Poll.Active
12387: root0 00 00 00 00 | PAD 4a 4a 4a -> Poll.Active >TX:TS1_OS on L1,3
12391: root0 4a 4a 4a 4a | PAD COM 4a COM -> Poll.Active
12395: root0 4a 4a 4a 4a | ff PAD 4a PAD -> Poll.Active >TX:TS1_OS on L2
12399: root0 4a 4a 4a 4a | 0e PAD COM PAD -> Poll.Active
12403: root0 4a 4a 4a 4a | 00 ff PAD ff -> Poll.Active
12407: root0 4a 4a 4a 4a | 4a 0e PAD 0e -> Poll.Active
12411: root0 4a 4a 4a 4a | 4a 00 ff 00 -> Poll.Active
12415: root0 4a 4a 4a 4a | 4a 4a 0e 4a -> Poll.Active
12419: root0 4a 4a 4a 4a | 4a 4a 00 4a -> Poll.Active
12423: root0 4a 4a 4a 4a | 4a 4a 4a 4a -> Poll.Active
12427: root0 4a 4a 4a 4a | 4a 4a 4a 4a -> Poll.Active >RX:TS1_OS on L0-3
12431: root0 COM COM COM COM | 4a 4a 4a 4a -> Poll.Active
12435: root0 PAD PAD PAD PAD | 4a 4a 4a 4a -> Poll.Active
12439: root0 PAD PAD PAD PAD | 4a 4a 4a 4a -> Poll.Active
12443: root0 ff ff ff ff | 4a 4a 4a 4a -> Poll.Active >TX:TS1_OS on L0
12447: root0 0e 0e 0e 0e | COM 4a 4a 4a -> Poll.Active
12451: root0 00 00 00 00 | PAD 4a 4a 4a -> Poll.Active >TX:TS1_OS on L1,3
12455: root0 4a 4a 4a 4a | PAD COM 4a COM -> Poll.Active
12459: root0 4a 4a 4a 4a | ff PAD 4a PAD -> Poll.Active >TX:TS1_OS on L2
12463: root0 4a 4a 4a 4a | 0e PAD COM PAD -> Poll.Active
12467: root0 4a 4a 4a 4a | 00 ff PAD ff -> Poll.Active

```

## 4.2.2 Synchronization of Simulation Time Between Transaction Log and Symbol Log

Transaction logging times represent times at the periphery of the VIP. Symbol logging times are captured at the PIPE interface, which may be internal or external to the VIP depending on the interface type.

For Serial and PMA interface, there is no correlation between the time displayed in the transaction log and the symbol log. Due to delay through the PHY layer, symbols are logged at a different time than the transaction log for the same packet.

For PIPE interface, the simulation time displayed in the transaction log and symbol log are synchronized for the same packet. The "Start Time" of the transaction log corresponds to the time of a transaction with the "STP" or "SDP" symbol in the symbol log. The "End Time" of the transaction log corresponds to the time of a transaction with the "END" symbol in the symbol log.

| Transaction Log | Symbol Log                      |
|-----------------|---------------------------------|
| Start Time (ns) | TIME with "STP" or "SDP" symbol |
| End Time (ns)   | TIME with "END" symbol          |

Example 1:

*Transaction Log*

```
vip0 16332.00 16336.00 T INITFC2_P_VCO 101 1025 0xb467
```

*Symbol Log*

```
16332: vip0 00 00 00 00 | SDP c0 19 84 -> tx = L0, rx = L0
16336: vip0 00 00 00 00 | 00 b4 67 END -> tx = L0, rx = L0
```

Example 2:

*Transaction Log*

| vip0 | <b>16344.00</b> | <b>16476.00</b> | T | MW32 | 0x0001/10    | 0         | 0         | 0        | 0   | 0 | 0 | 0x797ffe94 | 7 f |  |
|------|-----------------|-----------------|---|------|--------------|-----------|-----------|----------|-----|---|---|------------|-----|--|
|      |                 |                 |   |      | 29 H4000001d | H0001107f | H797ffe94 | ---      | --- | 0 | 0 | 0x88146f08 |     |  |
|      |                 |                 |   |      | 0 ee4f36e1   | f7f2dc7e  | 2409961a  | 6a0e183a |     |   |   |            |     |  |
|      |                 |                 |   |      | 4 d39af0b3   | 7c9a4388  | 6143237c  | ec6e36a2 |     |   |   |            |     |  |
|      |                 |                 |   |      | 8 c56daf5b   | 05b6af19  | 49481dfc  | 036a8986 |     |   |   |            |     |  |
|      |                 |                 |   |      | 12 70425548  | b95aea17  | 91d4a8af  | 8d575fcc |     |   |   |            |     |  |
|      |                 |                 |   |      | 16 cbf0a790  | ca6403af  | 196ebb7a  | ff400faf |     |   |   |            |     |  |
|      |                 |                 |   |      | 20 67310374  | 6745f3f3  | 677e58c8  | 09bcfe06 |     |   |   |            |     |  |
|      |                 |                 |   |      | 24 03223d90  | ab52c830  | df33cf23  | 700a0f1f |     |   |   |            |     |  |
|      |                 |                 |   |      | 28 b40b4d71  | ---       | ---       | ---      |     |   |   |            |     |  |

*Symbol Log*

```

16344: vip0      00 00 00 00 | STP 00 00 40    -> tx=L0, rx=L0
16348: vip0      00 00 00 00 | 00 00 1d 00    -> tx=L0, rx=L0
16352: vip0      00 00 00 00 | 01 10 7f 79    -> tx=L0, rx=L0
16356: vip0      00 00 00 00 | 7f fe 94 ee    -> tx=L0, rx=L0
16360: vip0      00 00 00 00 | 4f 36 e1 f7    -> tx=L0, rx=L0
16364: vip0      00 00 00 00 | f2 dc 7e 24    -> tx=L0, rx=L0
                                < symbol continues >
16456: vip0      00 00 00 00 | 22 3d 90 ab    -> tx=L0, rx=L0
16460: vip0      00 00 00 00 | 52 c8 30 df    -> tx=L0, rx=L0
16464: vip0      00 00 00 00 | 33 cf 23 70    -> tx=L0, rx=L0
16468: vip0      00 00 00 00 | 0a 0f 1f b4    -> tx=L0, rx=L0
16472: vip0      00 00 00 00 | 0b 4d 71 88    -> tx=L0, rx=L0
16476: vip0      00 00 00 00 | 14 6f 08 END   -> tx=L0, rx=L0

```

For more details on Gen5 Symbol Logger, see [Gen5 Symbol Logging](#).

## 4.3 The MBI Logger

When PIPE spec. version is set to 4.4 or above, all MBI transactions to or from the VIP are sent to the MBI logger. These transactions are distilled and written (one transaction per line) to the MBI log file.

By default, the MBI logger is disabled. To enable it and to start writing transactions to a file, use the `enable_mbi_logging` member of the `svt_PCIE_configuration` class.

One log file is created per simulation. All agents share the log file. Each agent must be enabled independently as shown in [Example 4-3](#). If more than one `mbi_log_filename` is set, then the last one set within the simulation serves as the filename. It is recommended that you have only one agent set for the filename.

### Example 4-3

```

class example extends uvm_test;
  ...
  virtual function void task build_phase(uvm_phase phase);
    super.build_phase(phase);
  ...
    root_cfg.pcie_cfg.enable_mbi_logging = 1; //Enable for RC
    endpoint_cfg.pcie_cfg.enable_mbi_logging = 1; //Enable for EP
    root_cfg.pcie_cfg.mbi_log_filename = "mbi.log"; //Recommended to only set
    the filename once
  endtask
endclass

```

```

    . . .
endfunction
endclass

```

The mbi log filename will be appended to the full hierarchical name of the port0 instance generating it.

#### 4.3.1 Fields of the MBI Log Header

The fields of the MBI log header are described in this section. These fields are listed from left to right as they appear on the header.

**Table 4-4 Fields - MBI Log**

| Field           | Description                                                                                                                      |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------|
| Instance        | This field represents an instance of the VIP in the test environment. The mbi log information is reported for this VIP instance. |
| Start Time (ns) | This field represents the simulation time in ns when the MBI transaction starts.                                                 |
| End Time (ns)   | This field represents the simulation time in ns when the MBI transaction ends.                                                   |
| Dir             | This field represents the MBI command transmission on M2P message bus or P2M message bus direction.                              |
| Lane            | This field represents lane having the MBI transaction.                                                                           |
| MBI Cmd         | This field represents current active MBI command.                                                                                |
| Address         | This field represents current active MBI command's address.                                                                      |
| Data            | This field represents data associated with current active MBI transaction.                                                       |

MBI Log Illustration:

| Instance  | Start Time | End Time   | Dir | Lane | MBI Cmd           | Address | Data |
|-----------|------------|------------|-----|------|-------------------|---------|------|
| root_port | 222.000000 | 230.000000 | M2P | 0    | WRITE_UNCOMMITTED | 402     | 1    |
| root_port | 234.000000 | 242.000000 | P2M | 0    | WRITE_UNCOMMITTED | 403     | 30   |
| root_port | 234.000000 | 242.000000 | M2P | 0    | WRITE_UNCOMMITTED | 403     | 0    |
| root_port | 246.000000 | 254.000000 | P2M | 0    | WRITE_COMMITTED   | 404     | 18   |
| root_port | 246.000000 | 254.000000 | M2P | 0    | WRITE_COMMITTED   | 404     | 0    |
| root_port | 262.000000 | 262.000000 | M2P | 0    | WRITE_ACK         | 0       | 0    |

#### 4.4 The CTRL SKP Logger

When the VIP enables support for CTRL-SKP OS at 16G (Gen4 or above) or Rx Margining or Fault Isolation, the CTRL SKP OS transaction information is captured by the CTRL SKP Logger.

It indicates the logging of CTRL SKP command information handshake in L0 LTSSM state by the Downstream and Upstream port

- ❖ at 16GT/s and above for Active Component

By default, the CTRL SKP Logger is disabled. To enable it and to start writing transactions to a file, use the enable\_ctrl\_skp\_logging member of the svt\_PCIE\_configuration class. There are separate CTRL SKP log files for the different agents/components and every agent/component with CTRL SKP logging enabled

will log CTRL SKP command handshake information into a separate file. Each agent must be enabled independently as shown in Example 5-4. If more than one `ctrl_skp_log_filename` is set, then the last one set within the simulation serves as the filename.

#### Example 4-4

```
class example extends uvm_test;
  .
  .
  virtual function void task build_phase(uvm_phase phase);
    super.build_phase(phase);
  .
  .
  root_cfg.pcie_cfg.enable_ctrl_skp_logging = 1; // Enable for RC
  endpoint_cfg.pcie_cfg.enable_ctrl_skp_logging = 1; // Enable for EP
  root_cfg.pcie_cfg.ctrl_skp_log_filename = "ctrl_skp_log"; // Recommended to only set
  the filename once
  .
  .
  endfunction
endclass
```

The CTRL SKP log filename will be appended to the full hierarchical name of the port0 instance generating it.

#### 4.4.1 Fields of the Ctrl SKP Log Header

The fields of the MBI log header are described in this section. These fields are listed from left to right as they appear on the header.

**Table 4-5 Fields - CTRL SKP Log**

| Field           | Description                                                                                                                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start Time (ns) | This field represents the simulation time in ns when the Ctrl SKP OS transaction starts.                                                                                                                                                                                       |
| Reporter        | This field represents an instance of the VIP in the test environment. The Ctrl SKP log information is reported for this VIP instance.                                                                                                                                          |
| Dir             | This field represents the Ctrl SKP OS transaction transmission or reception direction for the Reporter. Where, "R" represents the receive Ctrl SKP OS transaction information on the lane. "T" represents the transmit Ctrl SKP OS transaction information symbol on the lane. |
| Lane            | This field represents lane having the Ctrl SKP OS transaction.                                                                                                                                                                                                                 |
| Receiver Number | This field represents current active Ctrl SKP OS Receiver Number field value per spec 4.2.13.1.                                                                                                                                                                                |
| Margin Type     | This field represents current active Ctrl SKP OS Margin Type field value per spec 4.2.13.1.                                                                                                                                                                                    |
| Margin Payload  | This field represents current active Ctrl SKP OS Margin Payload field value per spec 4.2.13.1.                                                                                                                                                                                 |
| Command Type    | This field represents current active Ctrl SKP OS Margin Command per spec 4.2.13.1.                                                                                                                                                                                             |

CTRL SKP Log Illustration:

```
-----|-----|-----|-----|-----|-----|-----|-----|-----|
| | EP Active Component Report of CTRL SKPs in L0 LTSSM state | |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Start Time | Reporter | DIR | Lane | Receiver | Margin | Margin | Command Type |
| | | | | Number | Type | Payload | |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|
```

| 130632.80170 ns | EP | T | Lane0 | 'h0 | 'h7 | 'h9c | NO_COMMAND                       |
|-----------------|----|---|-------|-----|-----|------|----------------------------------|
| 130649.30170 ns | EP | R | Lane0 | 'h3 | 'h1 | 'h88 | REPORT_MARGIN_CONTROL_CAPABILITY |
| 136742.80170 ns | EP | T | Lane0 | 'h3 | 'h1 | 'h1f |                                  |
| 136759.30170 ns | EP | R | Lane0 | 'h0 | 'h7 | 'h9c | NO_COMMAND                       |
| 142852.80170 ns | EP | T | Lane0 | 'h0 | 'h7 | 'h9c | NO_COMMAND                       |
| 142869.30170 ns | EP | R | Lane0 | 'h3 | 'h5 | 'h7  | VENDOR_DEFINED                   |

## 4.5 Using Native Protocol Analyzer for Debugging

### 4.5.1 Introduction

This feature enables you to invoke Protocol Analyzer from Verdi GUI. You can synchronize the Verdi wave window, smart log and the source code with the Protocol Analyzer transaction view. Protocol Analyzer can be enabled in an interactive and post-processing mode. The features available in Native Protocol Analyzer includes layer based grouping of the transactions, Quick filter, Call stack, horizontal zoom and reverse debug with the interactive support.

The VIP supports the Synopsys Protocol Analyzer (PA) tool, which is an interactive graphical application which provides protocol-oriented analysis and debugging capabilities allows. It allows users to view transactions, TLPs, DLLPs, ordered sets and the LTSSM state machine graphically. A transaction is made up of one request TLP and if necessary one or more completion TLPs required to complete that transaction.

The Protocol Analyzer tool supports the following PCIe features:

- ❖ TLPs
  - ◆ Request
  - ◆ One or more completions, as per protocol
- ❖ DLLPs
- ❖ Ordered Sets
- ❖ LTSSM state

### 4.5.2 Enabling the Protocol Analyzer

To enable protocol analyzer define the macro 'SVT\_PCIE\_INCLUDE\_AC\_PA' at compile time and set following configurations in svt\_PCIE\_configuration class:

- ❖ enable\_tl\_xml\_gen. Protocol file generation for the Transaction Layer
- ❖ enable\_pl\_xml\_gen. Protocol file generation for the Physical Layer
- ❖ enable\_dl\_xml\_gen. Protocol file generation for the Data Link Layer

The default value of each of these variable is 0, which means that protocol file generation is disabled by default.

To enable protocol file generation for a layer, set the value of the protocol generation enabling variable for that layer to 1 in the port configuration of each master or slave for which protocol file generation is desired.

The next time that the environment is simulated, protocol files will be generated according to the port configurations. The protocol files will be in XML format. Import these files into the Protocol Analyzer to view the protocol transactions.

### 4.5.3 Prerequisites

Protocol Analyzer uses transaction-level dump database. You can use the following settings to dump the transaction database:

#### 4.5.4 Compile-Time Options

The following compile-time options must be enabled:

- ❖ -lca
- ❖ -kdb // dumps the work.lib++ data for source coding view
- ❖ +define+SVT\_PCIE\_INCLUDE\_AC\_PA
- ❖ +define+SVT\_FSDB\_ENABLE // enables FSDB dumping
- ❖ -debug\_access

For more information on how to set the FSDB dumping libraries, see “Appendix B” section in *Linking Novas Files with Simulators and Enabling FSDB Dumping* guide available at \$VERDI\_HOME/doc/linking\_dumping.pdf.

#### 4.5.5 Run Time Options

You can set the format type for FSDB dump either through simulator command-line option or via a configuration setting.

##### 4.5.5.1 Configuration Setting

Set the svt\_PCIE\_configuration::pa\_format\_type variable to FSDB.

```
< svt_PCIE_configuration>.pa_format_type=svt_xml_writer::FSDB
```



The XML type is in the process of being deprecated.

##### 4.5.5.2 Command Line Option

The following svt\_enable\_pa runtime switch can be provided to your simulator:

```
+svt_enable_pa=FSDB
```

Enables FSDB output of transaction and memory information for display in Verdi.

#### 4.5.6 Invoking Protocol Analyzer

Perform the following steps to invoke Protocol Analyzer in interactive or post-processing mode.

##### 4.5.6.1 Post-Processing Mode

Load the transaction dump data and issue the following command to invoke the GUI:

```
verdi -ssf <dump.fsdb> -lib work.lib++
```

In Verdi, navigate to Tools -> Transaction Debug -> Transaction and Protocol Analyzer to invoke Protocol Analyzer.

##### 4.5.6.2 Interactive Mode

Issue the following command to invoke Protocol Analyzer in an interactive mode:

```
<simv> -gui=verdi
```

You can invoke the Protocol Analyzer as shown above through Verdi. The Protocol Analyzer transaction view gets updated during the simulation.

#### 4.5.7 Limitations

Interactive support is available only for VCS.

### 4.6 Verification Planner

The PCIe VIP provides verification plans which can be used for tracking verification progress of the PCIe protocol. A set of top-level plans and sub-plans are provided. The verification plans are available at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans`

For more information, refer to the README file, which is available at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/README`

### 4.7 Global Shadow Memory

The purpose of this global shadow memory is to provide a database of your DUT's PCI Express address space (memory and configuration space) for Write and Read transaction checking. The Global PCIe Address Space Shadow is an optional component which you can instantiate in your test environment. Returned data can be compared with the shadow copy to verify that the DUT did the original write and the read correctly.

The model captures the following data in Shadow Memory:

- ❖ Memory Writes
- ❖ Atomic Operations.
- ❖ Memory Reads The host memory must have the IN\_ORDER attribute set. When the completion for that read comes back, this saved snapshot (and not the current state of the memory) will be used in the shadow comparison. Note however, the PCIe generally does not guarantee In Order write/read behavior.
- ❖ Configuration Writes. With this data you can determine various behaviors of the DUT.

The model does *not* capture the following data in Shadow Memory:

- ❖ Error Injections - we assume that an EI will cause failure of the transaction to do what it intended.
- ❖ Poisoned (EP bit) Atomic Ops - these should fail (other poisoned transactions may or may not fail - this is implementation dependent.)
- ❖ Any TLP determined to be badly formed.
- ❖ Type 1 Cfg requests (these are destined for switches, not endpoints)

The VIP captures TLPs as they go on the wire and then are passed to the shadow's transaction handler which decodes all relevant transactions and updates the expected global shadow state. For example, outbound MemWrite TLPs are inspected and (if appropriate) written to the global shadow memory. This shadow memory can be used by any checkers to allow comparisons with actual completion data (from the CplD TLP) and the expected completion data (from the global shadow memory.)

If instantiated and enabled, the Global Shadow is used by both the driver and the requester to automatically verify the results of the memory and configuration accesses made to the DUT. Memory transactions are captured and recorded in the Memory Shadow; no initial configuration of the Global System Shadow is required in most cases.

The shadow also provides for "ignored" regions of the memory. Any ignored regions will return an attribute to this effect when an application queries the shadow for expected read results. This way a checker can determine if the transaction is expected to return a predictable result or not. Occasionally there will be

memory regions (e.g. registers) that you do not want to check for correctness – write-only registers, status or statistics registers that may change sporadically, etc. T

The memory shadow has two ordering modes, the normal *non-ordered* mode, as well as a mode for strict transaction ordering. Strict ordering is only for use with DUTs that will **not** reorder any inbound transactions. The default mode is to not assume any ordering (which is normal per the PCI Express rules).

The following illustration shows an usage example:



Global shadow needs to be explicitly declared and instantiated at the top when used:

```
`define EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH test_top.global_shadow0
pciesvc_global_shadow #( .DISPLAY_NAME( "global_shadow0." ) ) global_shadow0();
```

## 4.7.1 Global Shadow Memory Classes

There are two classes for using Global Shadow Memory:

1. **svt\_PCIE\_global\_shadow**. This class is UVM Driver that implements a PCIE application namely Global Shadow. It provides a SIPP [Sequence Item Pull Port] to cater to services of type **svt\_PCIE\_global\_shadow\_service**.
2. **svt\_PCIE\_global\_shadow\_service**. This class represents service transactions for a PCIE Global Shadow Memory Application. The **service\_type** attribute is the entry point to this object.

### 4.7.1.1 Class svt\_PCIE\_global\_shadow Members

The following table lists important members of the **svt\_PCIE\_global\_shadow**. It is derived as a **uvm\_component**.

**Table 4-6 Service Class Features for Global Shadow Memory**

| Member                                                                               | Feature/Usage               |
|--------------------------------------------------------------------------------------|-----------------------------|
| <code>ADD_MEM_RANGE(<br/>`SVT_PCIE_GLOBAL_SHADOW_SERVICE_ADD_MEM_<br/>RANGE )</code> | Add supported memory range. |

**Table 4-6 Service Class Features for Global Shadow Memory (Continued)**

| <b>Member</b>                                                               | <b>Feature/Usage</b>                                                                                                     |
|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| REMOVE_MEM_RANGE(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_REMOVE_MEM_RANGE )         | Remove supported memory range.                                                                                           |
| WRITE_MEM(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_WRITE_MEM )                       | Memory write.                                                                                                            |
| READ_MEM(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_READ_MEM )                         | Memory read.                                                                                                             |
| WRITE_CFG(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_WRITE_CFG )                       | Configuration write.                                                                                                     |
| READ_CFG(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_READ_CFG )                         | Configuration read.                                                                                                      |
| WRITE_CFG_CAP(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_WRITE_CFG_CAP )               | Cfg Cap write.                                                                                                           |
| READ_CFG_CAP(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_READ_CFG_CAP )                 | Cfg Cap read.                                                                                                            |
| TRANSACTION_COMPLETE(`SVT_PCIE_GLOBAL_SHADOW_SERVICE_TRANSACTION_COMPLETE ) | Transaction completed.                                                                                                   |
| rand bit [63:0] address                                                     | Address to be read from or to be written to Global Shadow Memory.                                                        |
| rand bit [31:0] attributes                                                  | Attributes for ADD/REMOVE_MEM_RANGE service types.                                                                       |
| rand bit [15:0] bdf                                                         | Bus-Device-Function for the device cfg reg in Global Shadow cfg.                                                         |
| rand bit [3:0] byte_enables                                                 | Byte Enables indicating enabled bytes during read/write of Global shadow memory.                                         |
| svt_PCIE_device_configuration cfg                                           | Configuration pointer used to improve methods and constraints                                                            |
| rand bit [7:0] cfg_cap                                                      | The specific configuration-capability being read.                                                                        |
| rand bit [31:0] cfg_reg                                                     | The specific configuration register being written in Global shadow cfg.                                                  |
| rand bit [31:0] data                                                        | Data to be written to Global Shadow Memory during WRITE service. When service_type is READ, it represents the data read. |

**Table 4-6 Service Class Features for Global Shadow Memory (Continued)**

| Member                                  | Feature/Usage                                                                                                                               |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| rand bit [31:0] data_mask               | Asserted bits indicate which bits of above data argument will be modified in the configuration-register (remaining bits will be unchanged.) |
| rand bit [31:0] dword_offset            | Dword Offset indicating offset to the pcie_start_address. Valid offsets are 0 - data_length_in_dwords - 1.                                  |
| bit error                               | Error indication if ADD/REMOVE_MEM_RANGE service types fail.                                                                                |
| max_range                               | Upper address of the address range for ADD_MEM_RANGE and REMOVE_MEM_RANGE service types.                                                    |
| min_range                               | Lower address of the address range for ADD_MEM_RANGE and REMOVE_MEM_RANGE service types.                                                    |
| service_type                            | Memory target services                                                                                                                      |
| svt_sequence_item :: status_enum status | Status information about the current processing state                                                                                       |
| bit [31:0] task_status                  | Returns the status of READ/WRITE services.                                                                                                  |
| rand bit [31:0] transaction_id          | The combination of RequesterID and Tag for the transaction to cleanup.                                                                      |

## 4.7.2 Global Memory Examples

### 4.7.2.1 Random Memory Read using Global Shadow

User instantiates the requisite global shadow sequence in his parent sequence and reads data.

```
task user_parent_seq :: body();
  ...
  svt_PCIE_global_shadow_service_rd_mem_sequence rd_mem_seq;
  ...
  `uvm_do_on_with(rd_mem_seq, p_sequencer.global_shadow_seqr, {rd_mem_seq.address == 32'h000F_FFFC;

    rd_mem_seq.dword_offset == 32'h0;
    rd_mem_seq.transaction_id == 32'h0;
    rd_mem_seq.byte_enables == 4'b1111;});
  ...
endtask: body
```

## 4.7.3 Multiple Global Shadows

Figure 4-1 shows a virtual hierarchy created by the physical connection of RC and EP and the virtual connection to the associated shadow. This feature is implemented in the model via the parameter HIERARCHY\_NUMBER in the shadow and all of the instantiation models.

**Figure 4-1 PCIe VIP Hierarchy Definition**

#### 4.7.3.1 Setting up Multiple Shadows

##### 4.7.3.1.1 Module Level Construction

Instantiate a desired number of shadows (one for each PCIe VIP hierarchy described earlier). Relative location of the `pciesvc_global_shadow` instances to the device VIP instances in the module hierarchy is not important. The value of the associated `HIERARCHY_NUMBER` setting between the root, global shadow, and downstream endpoints is crucial.



For setting up multiple shadows in a testbench, do not use the define `EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH`. Global shadow is a memory shared by one RC and all EP instances associated with it. The association is done using `HIERARCHY_NUMBER` parameters while creating the module instances. RC and EP VIP instances use the `SVT_PCIE_UI_HIERARCHY_NUMBER` parameter, whereas `pciesvc_global_shadow` uses the `HIERARCHY_NUMBER` parameter.

```
// Global Shadow Instances ( optional )
pciesvc_global_shadow#(.DISPLAY_NAME({DISPLAY_NAME, "global_shadow0." }),  
.HIERARCHY_NUMBER(0)) global_shadow0();  
pciesvc_global_shadow#(.DISPLAY_NAME({DISPLAY_NAME, "global_shadow1." }),  
.HIERARCHY_NUMBER(1)) global_shadow1(); ...  
  
// PCIE VIP Hierarchy 0  
<pcie RC module>#(.DISPLAY_NAME(...), .HIERARCHY_NUMBER(0),...) <inst name> ...  
<pcie EP module>#(.DISPLAY_NAME(...), .HIERARCHY_NUMBER(0),...) <inst name> ...  
// PCIE VIP Hierarchy 1  
<pcie RC module>#(.DISPLAY_NAME(...), .HIERARCHY_NUMBER(1),...) <inst name> ...  
<pcie EP module>#(.DISPLAY_NAME(...), .HIERARCHY_NUMBER(1),...) <inst name> ...
```

##### 4.7.3.1.2 SVT Global Shadow Component Instantiation

You must modify construction of the shadow agent within environments by replacing `svt_PCIE_global_shadow::type_id::create()` with the specialized method `svt_PCIE_global_shadow::create_shadow()` (see [Table 4-7](#)). This modification is required when you want to use multiple shadows. The `hierarchy_number` argument of `create_shadow()` must match the `HIERARCHY_NUMBER` parameter value of the corresponding `pciesvc_global_shadow` module instance.

Example instantiation of two svt\_PCIE\_global\_shadows linked to the corresponding global shadow modules 0 an 1 from the previous module instantiation:

```
global_shadow[0] = svt_PCIE_global_shadow::create_shadow(0, "global_shadow[0]", this);
global_shadow[1] = svt_PCIE_global_shadow::create_shadow(1, "global_shadow[1]", this);
```

**Table 4-7    Multiple Shadow Support Functions**

| New Method           | Arguments                                                                                                                                                                         | Description                                                                                                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_shadow        | int hierarchy_number, // Global Shadow Hierarchy Number<br>string name="svt_PCIE_global_shadow", // Name of returned component<br>uvm_component parent = null // Parent component | This is a function that will look up the specific shadow with the predetermined string format, then create and return the component. Similar to ::create() but will not concatenate parent and name as the lookup string. Accepts same arguments as create for "name" and "parent". |
| get_hierarchy_number |                                                                                                                                                                                   | Returns the hierarchy number of the global shadow agent                                                                                                                                                                                                                             |

#### 4.7.4    Disabling Global Shadows

Global shadow is a memory component used in PCIe SVT VIP to compare write data (MWr or IOWr payload) with read data (CplD payload in response of MRd or IORD).

Global shadow component is instantiated in the testbench as shown in the following code snippet:

```
pciesvc_global_shadow #( .DISPLAY_NAME( "global_shadow0." ) ) global_shadow0();
`define EXPERTIO_PCIE_GLOBAL_SHADOW_PATH test_top.global_shadow0
```

If you want to disable global shadow at run time, you must invoke the following function:

```
<device_cfg>.enable_all_global_shadow_vars(0);
```

Alternatively, you can set following configuration attributes per component to enable/disable shadow memory checking:

```
<device_cfg>.driver_cfg[0].enable_tx_tlp_reporting = 0;
<device_cfg>.driver_cfg[0].enable_shadow_memory_checking = 0;
<device_cfg>.requester_cfg.enable_tx_tlp_reporting = 0;
<device_cfg>.requester_cfg.enable_shadow_memory_checking = 0;
<device_cfg>.pcie_cfg.dl_cfg.enable_tx_tlp_reporting = 0;
<device_cfg>.pcie_cfg.tl_cfg.enable_shadow_cfg_lookup = 0;
```

## 4.8    Target Memory

All PCIe devices in the system may have memory that is accessible by writes and/or reads to/from particular memory addresses. The VIP memory is a *sparse* model, allowing a wide variety of addresses (32 and 64-bit) to be accessed by a requester. The memory is divided into pages to increase performance, match up to PCIe packets and take advantage of locality-of-reference.

The basic tasks are simply Write and Read, each providing dword-sized accesses via a supplied 32 or 64-bit PCIe address.

This memory is also used as the storage mechanism for the Global Shadow Memory (see [Global Shadow Memory](#) for details).

The service class `svt_PCIE_mem_target_service` class represents service transactions for a PCIe Memory Target Application. The `service_type` attribute is the entry point to this object. The following table shows the various memory target service types.

**Table 4-8    Memory Target Service Types**

| Service                                                                       | Description                                                                                                                        |
|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| <code>WRITE(`SVT_PCIE_MEM_TARGET_SERVICE_WRITE )</code>                       | Memory write of single DWORD to Memory space of Target application. NOTE: This service call will be obsoleted in a future release. |
| <code>READ(`SVT_PCIE_MEM_TARGET_SERVICE_READ )</code>                         | Memory read of single DWORD to Memory space of Target application. NOTE: This service call will be obsoleted in a future release.  |
| <code>PRE_WRITE_HINT(`SVT_PCIE_MEM_TARGET_SERVICE_PRE_WRITE_HINT )</code>     | Add Pre-write hint to the memory. NOTE: This service call will be obsoleted in a future release.                                   |
| <code>ADD_MEM_RANGE(`SVT_PCIE_MEM_TARGET_SERVICE_ADD_MEM_RANGE )</code>       | Add supported memory range.                                                                                                        |
| <code>REMOVE_MEM_RANGE(`SVT_PCIE_MEM_TARGET_SERVICE_REMOVE_MEM_RANGE )</code> | Remove supported memory range.                                                                                                     |
| <code>DISPLAY_STATS(`SVT_PCIE_MEM_TARGET_SERVICE_DISPLAY_STATS )</code>       | Display statistics variables.                                                                                                      |
| <code>CLEAR_STATS(`SVT_PCIE_MEM_TARGET_SERVICE_CLEAR_STATS )</code>           | Clear statistics variables.                                                                                                        |
| <code>RESET_APP(`SVT_PCIE_MEM_TARGET_SERVICE_RESET_APP )</code>               | Resets app back to its initial state. All will be lost.                                                                            |
| <code>WRITE_BUFFER(`SVT_PCIE_MEM_TARGET_SERVICE_WRITE_BUFFER )</code>         | Memory write of multiple DWORDs to Memory space of Target application.                                                             |
| <code>READ_BUFFER(`SVT_PCIE_MEM_TARGET_SERVICE_READ_BUFFER )</code>           | Memory read of multiple DWORDs to Memory space of Target application.                                                              |

A service call is used to mark a memory region as ignored. As such, the memory region will not have memory allocated for it. Read requests will be returned with random data. Write requests will have no affect.

```
/**< Add supported memory range.*/
ADD_MEM_RANGE = `SVT_PCIE_MEM_TARGET_SERVICE_ADD_MEM_RANGE,
               

/**< Remove supported memory range.*/
REMOVE_MEM_RANGE = `SVT_PCIE_MEM_TARGET_SERVICE_REMOVE_MEM_RANGE,
               

.....
//----- Variables for ADD_MEM_RANGE and REMOVE_MEM_RANGE services -----
```

```
/***
 * Lower address of the address range for ADD_MEM_RANGE and
 * REMOVE_MEM_RANGE service types.
 */
rand bit [63:0]      min_range = 'h0;

/***
 * Upper address of the address range for ADD_MEM_RANGE and
 * REMOVE_MEM_RANGE service types.
 */
rand bit [63:0]      max_range = 64'hFFFF_FFFF_FFFF_FFFC;

/***
 * Attributes for ADD/REMOVE_MEM_RANGE service types.
 * - attributes[0]: Ignore. Assert this bit in the attributes to
 * disallow checking against this address range.
 * - attributes[1]: In Order. Assumes transaction will be handled in the DUT the
 * order that they were received, this provides the potential for checking some
 * alternating read/write transactions.
 */
rand bit [31:0]      attributes = 32'h0;
```

#### 4.8.1 Ignoring Memory Ranges

The service call `svt_PCIE_mem_target_service::ADD_MEM_RANGE` (along with `REMOVE_MEM_RANGE`) are used to configure the memory range and ignored attribute. The sequence class `svt_PCIE_mem_target_service_mem_range_sequence` provides access to this mechanism.

The configuration in the class `svt_PCIE_target_app_configuration` for this is `uninit_mem_read_resp`, which can be set with various `UNINIT_MEM_READ_RESP_*` values.

The shadow also provides for ignored regions of the memory. Any ignored regions will return an attribute to this effect when an application queries the shadow for expected read results. In this way, a checker can determine if the transaction is expected to return a predictable result or not. Occasionally, there will be memory regions (for example, registers) that you do not want to check for correctness – write-only registers, status or statistics registers that may change sporadically, and so on. These regions in the shadow memory can be marked as `IGNORED` via the `AddMemRange()` task, which is identical as above, but is accessed via the `'EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH` define.

## 4.9 Data Link Monitor

The VIP has a Data Link Monitor which is used to indicate when TLPs and DLLP are sent and received. Figure 4-2 shows the various analysis ports for monitoring TLPs and DLLPs.

**Figure 4-2 Data Link Monitor and Monitor Ports and Classes**



The PCIe UVM VIP has the following TLM analysis ports in the DL to access sent/received TL packets.

- ❖ `svt_PCIE_DL::received_tlp_observed_port`: Analysis port for to sample TLPs being received by the VIP. This port is generally used for scoreboardng.
- ❖ `svt_PCIE_DL::sent_tlp_observed_port`: Analysis port for to sample TLPs being sent by the VIP. This port is generally used for scoreboardng.

The TLPs observed via these ports are controlled by a configuration variables in the DL namely:

- ❖ `svt_PCIE_DL_configuration::received_tlp_interface_mode`
- ❖ `svt_PCIE_DL_configuration::sent_tlp_interface_mode`.

For example:

```
endpoint_cfg.pcie_cfg.dl_cfg.received_tlp_interface_mode = 1;
endpoint_cfg.pcie_cfg.dl_cfg.sent_tlp_interface_mode = 1;
```

These configuration parameters are 2-bit variables. Bit 0 corresponds to the enabling of “good” packets and bit 1 corresponds to the enabling of “error” packets. Check the HTML class description for more details:

- ❖ [\\$DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/configuration/class\\_sv\\_t\\_PCIE\\_DL\\_configuration.html#item\\_received\\_tlp\\_interface\\_mode](#)
- ❖ [\\$DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/configuration/class\\_sv\\_t\\_PCIE\\_DL\\_configuration.html#item\\_sent\\_tlp\\_interface\\_mode](#)

Once enabled these ports can be used to subscribe to transaction being sent/received by the VIP model with the use of UVM subscribers. The code example below illustrates the same.

Use the following flow to setup the DL Monitor.

1. Identify the analysis port on the DL monitor
2. The sent\_tlp\_observed\_port will tell you when the TLP was sent, along with providing the TLP transaction class
3. Note the class name: svt\_PCIE\_dl\_monitor
4. Create a uvm\_subscriber extension
- Goal: uvm\_subscriber::write() will be called when the TLP is sent
5. Add a subscriber to your uvm\_test
  - a. Build phase : new your uvm\_subscriber class
  - b. Connect phase : connect to the uvm\_analysis, monitor port in the class identified above
6. Done, when the TLP is sent, the write() method will be called.

The example which follows is annotated to explain the use of the DL Monitor following the previous steps.

```
class dl_tlp_subscriber extends `SVT_XVM(subscriber) #( svt_PCIE_dl_tlp_monitor_transaction );
  event tlp_avail;
  svt_PCIE_dl_tlp_monitor_transaction tlp_info;

  function new( string name, `SVT_XVM(component) parent );
    super.new( name, parent );
  endfunction

  virtual function void write( svt_PCIE_dl_tlp_monitor_transaction t );
    tlp_info = t;
    // Check TLP here; coverage? Scoreboard?
    // trigger an event which can be used for external synchronizations
    ->tlp_avail;
    `uvm_info("pseudo_random_serdes_test", "dl_tlp_subscriber: A new sent TLP available");
  endfunction
endclass
```

User defined class extending from uvm\_subscriber

Data type of analysis port, monitor\_port within monitor

Write method called when analysis port has an 'event'

```
class pseudo_random_serdes_test extends pcie_device_base_test ;
```

```
    dl_tlp_subscriber sent_tlp_subscriber;
```

```
...
```

```
virtual function void build_phase(uvm_phase phase);
```

```
    `uvm_info("build_phase", "Entered...", UVM_LOW)
```

```
    super.build_phase(phase);
```

```
    sent_tlp_subscriber = new( "sent_tlp_subscriber", this );
```

```
    `uvm_info("build_phase", "Exiting...", UVM_LOW)
```

```
endfunction: build_phase
```

```
....
```

Add subscriber to your  
uvm\_test  
implementation

Within the build\_phase,  
create an instance of  
your subscriber

```
...
```

```
virtual function void connect_phase( uvm_phase phase );
```

```
super.connect_phase( phase );
```

```
env.endpoint.port.dl_monitor.sent_tlp_observed_port.connect( sent_tlp_subscriber.analysis_export );
```

```
endfunction
```

“connect” to the  
monitor within the  
connect\_phase

Use analysis\_export to  
make the connection

UVM\_INFO ./ts.pseudo\_random\_test.sv(76) @ 81793300.10 ps:  
uvm\_test\_top.tlp\_subscriber dl\_tlp\_subscriber: A new sent TLP available

from log....

# 5 General VIP Protocol Features

---

This chapter describes the general VIP protocol features available with the Synopsys PCIe Verification IP. This chapter discusses the following topics:

- ❖ [PCIe Gen3 Support](#)
- ❖ [Compliance Patterns](#)
- ❖ [Power Management](#)
- ❖ [Setting Coefficient and Preset for Gen3 Equalization](#)

## 5.1 PCIe Gen3 Support

To enable Gen3 features, the SVT\_PCIE\_ENABLE\_GEN3 macro must be defined on the command line for VCS invocation and the svt\_pcie\_device\_configuration::pcie\_spec\_ver must be set to svt\_pcie\_device\_configuration::PCIE\_SPEC\_VER\_3\_0.

The following is an example of how to define a macro on a command line for VCS invocation:

```
vcs +define+SVT_PCIE_ENABLE_GEN3 other_switches
```

## 5.2 Compliance Patterns

The compliance and modified compliance patterns defined in the PCIE specification contain sequences of data that would be considered an error during normal operation. For example, at 2.5G and 5G part of the compliance pattern is to send a COM followed by data symbols that do not make a legal ordered set.

At 8G there are ordered set blocks filled with symbols that do not make up a valid ordered set. Additionally SKP ordered sets at 8G contain data associated with compliance rather than the contents of the LFSR. Because there is no way to know exactly when the DUT starts transmitting the compliance pattern vs normal link training, the VIP can and will likely flag some ordered set violations until it recognizes the compliance pattern.

This means that when the vip initially receives the compliance pattern or modified compliance pattern, the user will be required to suppress or demote some error messages until the VIP obtains lock on the pattern in order to obtain a passing test. In PIPE simulations, the VIP should recognize a compliance or modified compliance pattern by the time the pattern has completed its first cycle.

In serial simulations it will take longer for the VIP to recognize compliance, because if a speed change occurs in polling.compliance, then the VIP must acquire bit lock and symbol/block alignment first. The modified compliance pattern at 8G in serial mode will take an especially long time, because the EIEOS required for block alignment occurs only once every 65792 blocks.

## 5.3 Power Management

The Data Link Layer in the SVT PCIE VIP provides support for PM/ASPM functionality similar to the specification. As defined by the specification, the VIP can be directed into and out of particular power states. The VIP can also be configured to automatically enter states as specified by the protocol. Exit from low power states can be initiated by the VIP as well if it needs to transmit a TLP or DLLP.

NOTE: ASMP L1 entry must be enabled by the Data Link configuration, but PM L1 does not (due to specification controls).

The VIP has built in checkers to make sure the handshake process occurs per specification. Timeouts are used to make sure handshakes occur within a reasonable time frame.

### 5.3.1 ASPM

#### 5.3.2 L0s Entry

For L0s entry, the VIP can be configured to automatically transition to Tx L0s when an idle period is reached. Or it can be directed to Tx L0s. The idle timer, when set to a non-zero value, enables the VIP's automatic entry to L0s. The DL can also be sent immediately to Tx L0s via a service request.

For exit from L0s to L0, the VIP can be directed or autonomously transition. User directed exit from Tx L0s is initiated via DL INITIATE\_ASPM\_EXIT service request. Autonomous exit occurs when any DLLP or TLP needs to be transmitted.

:

**Table 5-1 DL L0s Configuration**

| Member                  | Description                                                                                                                                                                                                                  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l0s_idle_timer_limit_ns | When set to non-zero value, VIP will automatically enter ASPM L0s when transmitter is idle for * this time. If set to 0, automatic ASPM L0s entry is disabled. For directed entry into L0s, use * InitiateASPMl0sEntry task. |

**Table 5-2 DL Service Requests**

| Member                  | Description                                                       |
|-------------------------|-------------------------------------------------------------------|
| INITIATE_ASPM_L0S_ENTRY | Initiates VIP to enter ASPM Tx L0s low power state.               |
| NITIATE_ASPM_EXIT       | Initiates VIP to transition back to L0 from ASPM low power state. |

#### 5.3.2.1 L1 Entry

ASPM L1 entry must be enabled by DL configuration variables listed below. The entry/exit to/from ASPM L1 is initiated by DL service requests INITIATE\_ASPM\_L1\_ENTRY/ INITIATE\_ASPM\_EXIT.

For exit from L1 to L0, the VIP can be directed or autonomously transition. User directed exit from L1 is initiated via a DL INITIATE\_ASMP\_EXIT service request. Autonomous exit occurs when any DLLP or TLP needs to be transmitted.

:

**Table 5-3 DL Service Requests**

|                        |                                                                   |
|------------------------|-------------------------------------------------------------------|
| enable_aspm_l1_entry   | Enable ASPM L1 entry                                              |
| INITIATE_ASMP_L1_ENTRY | Initiates VIP to enter PM L1 low power state                      |
| INITIATE_ASMP_EXIT     | Initiates VIP to transition back to L0 from ASMP low power state. |

### 5.3.2.2 L1 Substate Entry

The VIP supports entry into L1 substates. Entry must be enabled via DL configuration variables listed below. These vars must be set in addition to the vars listed in the L1 section. If L1\_1 and L1\_2 are both enabled, the VIP will transition to the highest power savings state, which is L1\_2. Entry/exit to/from L1 substates is initiated just like L1 entry/exit.

**Table 5-4 DL Configuration Members for L1 Substrate Entry**

| Member                 | Description                                                                                                                             |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| enable_aspm_l1_2_entry | The variable enables ASPM L1.2 entry. Must be used in conjunction with enable_aspm_l1_entry and INITIATE_ASMP_L1_ENTRY service request  |
| enable_aspm_l1_1_entry | The variable enables ASPM L1.1 entry. Must be used in conjunction with enable_aspm_l1_entry and INITIATE_ASMP_L1_ENTRY service request. |

### 5.3.2.3 Active State NAK

Active state NAK TLP msgs must be initiated by the test case. Active State NAK TLPs received from the DUT can be forwarded to the test case via

## 5.3.3 PM

The VIP assumes the test case has performed the proper PM handshake in order for the VIP to transition to low power states. The VIP does not respond to PM TLP messages nor will it initiate any PM TLP messages. In order for the test case to complete the handshake with the VIP, the received PM TLP messages must be forwarded to the test case by the VIP. This is accomplished by routing PM TLPs to the testcase via the TLs mapping tables using ADD RID MSG CODE APPL ID MAP ENTRY service request.

Once the test case has determined the functions in the DUT are ready for transition to low power states, the test case can initiate VIP transition per sections below. If the DUT is initiating the transition, the VIP will respond as if its functions are ready for PM low power transition.

### 5.3.3.1 L1

PM L1 does NOT have to be enabled by DL configuration. This behavior is enabled by default, similar to the specification. The entry/exit to/from PM L1 is initiated by DL service requests INITIATE\_PM\_L1\_ENTRY/INITIATE\_PM\_EXIT.

For exit from L1 to L0, the VIP can be directed or autonomously transition. User directed exit from L1 is initiated via the DL INITIATE\_PM\_EXIT service request. Autonomous exit occurs when any DLLP or TLP needs to be transmitted.

No configuration members exist for DL D1 configuration.

**Table 5-5 L1 DL Service Requests**

| Member               | Description                                                     |
|----------------------|-----------------------------------------------------------------|
| INITIATE_PM_L1_ENTRY | Initiates VIP to enter PM L1 low power state                    |
| INITIATE_PM_EXIT     | Initiates VIP to transition back to L0 from PM low power state. |

### 5.3.3.2 L1 Substate Entry

The VIP supports entry into L1 substates. Entry to L1 substates must be enabled via DL configuration variables listed below. If L1\_1 and L1\_2 are both enabled, then the VIP will transition to the highest power savings state, which is L1\_2. Entry/exit to/from L1 substates is initiated just like L1 entry/exit

**Table 5-6 L1 Substrate Entry Members**

| Member               | Description                                                                                                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| enable_pm_l1_2_entry | The variable enables PM L1.2 entry. Must be used in conjunction with enable_pm_l1_entry and INITIATE_PM_L1_ENTRY service request  |
| enable_pm_l1_1_entry | The variable enables PM L1.1 entry. Must be used in conjunction with enable_pm_l1_entry and INITIATE_PM_L1_ENTRY service request. |

### 5.3.3.3 L2/3 Entry

PM L2/3 entry does NOT need to be enabled by DL configuration. This behavior is enabled by default, similar to the specification. The entry/exit to/from PM L2/3 is initiated by DL service requests INITIATE\_PM\_L23\_ENTRY/INITIATE\_PM\_EXIT.

For exit from L2/3 to L0, the VIP can be directed or autonomously transition. User directed exit from L2/3 is initiated via DL INITIATE\_PM\_EXIT service request. Autonomous exit occurs when any DLLP or TLP needs to be transmitted

There is no configuration member for D1 L1.

**Table 5-7 DL Service Requests**

| Member                | Description                                                     |
|-----------------------|-----------------------------------------------------------------|
| INITIATE_PM_L23_ENTRY | Initiates VIP to enter PM L2/L3 low power state.                |
| INITIATE_PM_EXIT      | Initiates VIP to transition back to L0 from PM low power state. |

### 5.3.4 VIP PM/ASPM Checks

The VIP has automatic checking for PM/ASPM functionality. The checks can be demoted if the behavior is expected. The timeouts are configurable via DL configuration. By default, any PM request is expected to complete successfully. In the event that an ASPM active state NAK TLP is received, the VIP will flag this as a UVM\_WARNING.

**Table 5-8 Pm/ASPM Checks**

| Member                                           | Description                                                                                                                                                                                                                                                                        |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSGCODE_PCIE_SVC_DL_ASpm_L1_HANDSHAKE_TIMEOUT    | <ul style="list-style-type: none"> <li>If DUT fails to respond to ASpm request handshake for this:</li> <li># symbols, NOTICE will be issued</li> <li>and ASpm entry will be aborted.<br/>aspm_timeout_cnt_limit = `SVT_PCIE_ASpm_TIMEOUT_CNT_LIMIT_DEFAULT;</li> </ul>            |
| MSGCODE_PCIE_SVC_DL_PM_L1_HANDSHAKE_TIMEOUT      | <ul style="list-style-type: none"> <li>If DUT fails to respond to PM request handshake for this:</li> <li># symbols, NOTICE will be issued and</li> <li>* PM entry will be aborted. */ rand int unsigned pm_timeout_cnt_limit = `SVT_PCIE_PM_TIMEOUT_CNT_LIMIT_DEFAULT;</li> </ul> |
| MSGCODE_PCIE_SVC_DL_PM_L1_1_HANDSHAKE_TIMEOUT    |                                                                                                                                                                                                                                                                                    |
| MSGCODE_PCIE_SVC_DL_PM_L1_2_HANDSHAKE_TIMEOUT    |                                                                                                                                                                                                                                                                                    |
| MSGCODE_PCIE_SVC_DL_PM_L23_HANDSHAKE_TIMEOUT     |                                                                                                                                                                                                                                                                                    |
| MSGCODE_PCIE_SVC_DL_ASpm_L1_RX_ACTIVE_STATE_NAK  | ASpm L1 Handshake terminated by receiving ACTIVE_STATE_NAK                                                                                                                                                                                                                         |
| MSGCODE_PCIE_SVC_DL_RECEIVED_UNEXPECTED_PM_ACK   | Received PM_REQUEST_ACK DLLP when PM was not requested                                                                                                                                                                                                                             |
| MSGCODE_PCIE_SVC_DL_RECEIVED_TLP_ASpm_L1_STARTED | Received TLP when ASpm L1 entry is in progress. Dut should hold TLP until L1 handshake is complete. Spec 5.4.1.2.1                                                                                                                                                                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_TLP_PM_L1_STARTED   | Received TLP when PM L1 entry is in progress. Dut should hold TLP until L1 handshake is complete. Spec 5.3.2.1                                                                                                                                                                     |
| MSGCODE_PCIE_SVC_DL_RECEIVED_TLP_PM_L23_STARTED  | Received TLP when PM L2/L3 entry is in progress. Dut should hold TLP until L2/L3 handshake is complete. Spec 5.3.2.3                                                                                                                                                               |

## 5.4 Setting Coefficient and Preset for Gen3 Equalization

Transmitter equalization is adopted in Gen 3 to compensate for an increased signal distortion from operating at a higher data rate. On entry to the 8.0 GT/s data rate, the link partners exchange equalization presets and coefficients to determine the transmitter and receiver settings that yield an optimal signal-to-noise ratio on each lane. This trainable equalization process consists of 4 phases. The phase information is specified in the Equalization Control (EC) field in the TS1 Ordered Sets.

In phase 0, in Recovery.RcvrCfg before transitioning to 8.0 GT/s, the Downstream port transmits the recommended preset and coefficient values to the Upstream Port. The Upstream Port uses these recommended values in phase 0 and phase1.

In phase 1, the Downstream and Upstream Ports transmit with their respective coefficients. Both ports advertise the preset and post cursor values of their transmitters, the LF and FS values. Equalization is complete in phase 1 if a finer adjustment to the preset and coefficient values is not required. If the Downstream Port requests a finer adjustment to the presets and coefficients, then the ports proceed to phase 2.

In phase 2, the transmitter coefficients of the Downstream Port are optimized. The Upstream Port can request the Downstream Port to adjust its transmitter by setting the preset and coefficient fields in the transmitted TS OS. The Downstream Port either accepts or rejects these new values. Once an optimal preset and coefficient values are determined by the Upstream Port, the Upstream Port transitions to phase 3.

In phase 3, the transmitter coefficients of the Upstream Port are optimized. The Downstream Port can request the Upstream Port to adjust its transmitter by setting preset and coefficient fields in the transmitted TS OS. The Upstream Port either accepts or rejects these new values. Once an optimal preset and coefficient values are determined by the Downstream Port, the Downstream Port transitions to Recovery.RcvrLock. For FAQs, see “Equalization” section in [PCIe SVT FAQ](#).

#### 5.4.1 Enabling Equalization

To configure the highest supported speed and link equalization behavior collectively in the VIP, use following functions:

- ❖ `svt_PCIE_Pl_Configuration::set_link_speed_values(bit [31:0] supported_link_speeds_value, bit [31:0] target_link_speed_value = 32'h0, bit [31:0] expected_link_speed_value = 32'h0);`
- ❖ `svt_PCIE_Pl_Configuration::set_link_eq_attribute_values(link_eq_mode_enum link_eq_mode_value = LINK_EQ_MODE_FULL_EQUALIZATION_REQUIRED, bit enable_direct_speed_up_from_2_5g_to_16g_value = 0, int unsigned highest_enabled_eq_phase_value = 3);`
- ❖ Gen1 → Gen3 (With Equalization)
 

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values();
```
- ❖ Gen1 → Gen3 (Without Equalization)
 

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(, , 0 /*highest_enabled_eq_phase*/);
```
- ❖ Gen1 → Gen3 → Gen4 (With Equalization)
 

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values();
```
- ❖ Gen1 → Gen3 → Gen4 (Without Equalization)
 

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(, , 0 /*highest_enabled_eq_phase*/);
```
- ❖ Gen1 → Gen4 (With Equalization)
 

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
```

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(,1
/*enable_direct_speed_up_from_2_5g_to_16g*/);

❖ Gen1 → Gen4 (Without Equalization)

cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_16_0G |
`SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(,1
/*enable_direct_speed_up_from_2_5g_to_16g*/, 0 /*highest_enabled_eq_phase*/)

❖ Gen1 → Gen3 → Gen4 → Gen5 (With Equalization)

cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_32_0G |
`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G |
`SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_FULL_EQUALIZATION_REQUIRED);

❖ Gen1 → Gen5 (With Equalization)

cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_32_0G |
`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G |
`SVT_PCIE_SPEED_2_5G);

cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_EQ_BYPASS_TO_HIGHEST_RATE);

❖ Gen1 → Gen5 (Without Equalization)

cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_32_0G |
`SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G |
`SVT_PCIE_SPEED_2_5G);
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_NO_EQUALIZATION_NEEDED);
```

Equalization checking is disabled by default In the PCIe VIP. You can use the following attributes in the PHY layer configuration class (`svt_PCIE_pl_configuration`) to enable equalization checking.

**Table 5-9     Equalization Modes**

| Attribute                                            | Description                                                                                                                                                                   |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>enable_equalization_verification_mode</code>   | Enables equalization verification mode                                                                                                                                        |
| <code>enable_equalization_coefficients_checks</code> | Enables equalization coefficient check                                                                                                                                        |
| <code>highest_enabled_equalization_phase</code>      | Specifies the highest equalization phase to be enabled.<br>A value of 1 enables equalization phase 0 and phase 1.<br>A value of 3 enables equalization phases 0, 1, 2, and 3. |

For example:

```
root_cfg.pcie_cfg.pl_cfg.enable_equalization_verification_mode = 1;
root_cfg.pcie_cfg.pl_cfg.enable_equalization_coefficients_checks = 1;
root_cfg.pcie_cfg.pl_cfg.highest_enabled_equalization_phase = 3;

endpoint_cfg.pcie_cfg.pl_cfg.enable_equalization_verification_mode = 1;
endpoint_cfg.pcie_cfg.pl_cfg.enable_equalization_coefficients_checks = 1;
endpoint_cfg.pcie_cfg.pl_cfg.highest_enabled_equalization_phase = 3;
```

## 5.4.2 Specifying Coefficients, Presets, LF and FS Values

### 5.4.2.1 Initializing Presets with EQ TS OS

As a Downstream Port, the VIP transmits EQ TS OS with recommended preset values. The preset values are specified by the "upstream\_preset\_value" attribute in the PHY layer configuration class (svt\_PCIE\_pl\_configuration). If the recommended preset values are mapped to the valid coefficients in the DUT (Upstream Port), then the DUT transmits TS OS with the recommended preset values in equalization phases 0, 1, and 3. The TS OS coefficient fields of the DUT are specified with the corresponding coefficients from the preset mapping table of the DUT. The VIP compares the preset field of the received TS OS with the "upstream\_preset\_value" attribute. For more information on the mapping table, refer to the "Preset to Coefficient Mapping" section.

As an Upstream port, the VIP receives EQ TS OS with preset values recommended by the DUT. The VIP transmits TS1 OS with the recommended preset values in equalization phases 0, 1, and 3. The coefficient fields of the VIP are specified with the corresponding coefficients from the preset mapping table of the VIP in phases 0 and 3. The post cursor value is specified in phase 1.

You can use the following attributes in the PHY layer configuration class (svt\_PCIE\_pl\_configuration) to specify the coefficients, LF and FS values.

**Table 5-10 Attributes of PHY Layer Configuration Class**

| Attribute                            | Description                                                                                                                                                                                                                                                                                      |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| upstream_preset_value                | Specifies the Upstream Port preset value.                                                                                                                                                                                                                                                        |
| preset_to_coefficients_mapping_table | Maps received preset requests to coefficients for use in local transmitter settings. This table is indexed by a preset value. The coefficients are packed in the following format: { postcursor_coeff, cursor_coeff, precursor_coeff } The default value is { 6'h01, 6'h56, 6'h01} or 18'h01b81. |
| lf_value                             | Specifies the LF value advertised by the VIP in TS1s during equalization phase 1.                                                                                                                                                                                                                |
| fs_value                             | Specifies the FS value advertised by the VIP in TS1s during equalization phase 1.                                                                                                                                                                                                                |

For example:

```
//Specify mapping table values to change default coefficients
root_cfg_PCIE_pl_cfg.preset_to_coefficients_mapping_table[0] = '{16{18'h00543}};

root_cfg_PCIE_pl_cfg.lf_value = '{32{'d9}};
root_cfg_PCIE_pl_cfg.fs_value = '{32{'d24}};
```

### 5.4.2.2 Preset to Coefficient Mapping

The VIP includes two preset mapping tables in the PHY layer configuration class (svt\_PCIE\_pl\_configuration).

**Table 5-11 Preset PHY Mapping**

| Attribute                                     | Description                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| preset_to_coefficients_mapping_table          | Maps received preset requests to coefficients for use in local transmitter settings. This table is indexed by a preset value. The coefficients are packed in the following format: { postcursor_coeff, cursor_coeff, precursor_coeff } The default value is { 6'h01, 6'h56, 6'h01} or 18'h01b81.                                                        |
| expected_preset_to_coefficients_mapping_table | Verifies the preset to coefficient mappings in the DUT. This table should be programmed with the same value as the preset table in the DUT. This table is indexed by a preset value. The coefficients are packed in the following format: { postcursor_coeff, cursor_coeff, precursor_coeff } The default value is { 6'h0c, 6'h24, 6'h00} or 18'h0c900. |

As a Downstream Port, the VIP verifies the DUT preset mapping in Phase 0 and again in Phase 3. As an Upstream Port, the VIP verifies the DUT preset mapping in Phase 2. If the preset maps to an invalid entry, the VIP disables mapping check, transmits with the recommended coefficients specified by the DUT, and set the reject preset bit. For more information, see “*How to configure VIP to check received coefficients are same as DUT transmitted coefficients in response to preset request in Phase2 of EP/Phase3 of RC?*” in “Equalization” section in [PCIe SVT FAQ](#).

#### 5.4.2.3 LF and FS Values

The LF and FS values are advertised in phase 1. The VIP uses the values advertised by the DUT to determine the DUT's acceptance or rejection of its recommended presets and coefficients. If the DUT does not accept or reject the presets and coefficients, the VIP issues a warning message.

For the LF and FS values advertised by the VIP, the VIP verifies that the presets and coefficients recommended by the DUT does not violate its LF and FS values. For more information, see “*How do I set lf and fs values?*” in “Equalization” section in [PCIe SVT FAQ](#).

#### 5.4.2.4 Rejecting Presets or Coefficients

The VIP has built-in checks for preset or coefficient requests from the DUT as defined in the PCIe specification. In addition, the VIP includes a mode to manually force a rejection on a per lane basis regardless of the results of the built-in check.

The VIP issues a notice message when the DUT rejects a coefficient.

#### 5.4.2.5 Automatic Rejection

For each preset or coefficient request, the VIP verifies that the mapped coefficients in the preset case or received coefficients does not violate the LF and FS rules as defined in section 4.2.3.1 of the PCIE Specification. If a violation occurs, the VIP asserts the "reject coefficient values" bit in the transmitted TS OS on that particular lane. This bit is also asserted for preset requests that do not map to valid coefficients. When a new set of presets and coefficients are received, the VIP performs a new check. For more information, see “*How to reject preset or coefficient values requested by the DUT?*” in “Equalization” section in [PCIe SVT FAQ](#).

#### 5.4.2.6 Manual Rejection

Manual rejection can be specified for any preset or coefficient request from the DUT on any lane. The VIP asserts the reject bit in the TS OS in the appropriate phase.

You can use the following attribute in the PHY layer configuration class (`svt_PCIE_pl_configuration`) to reject preset or coefficient values requested by the DUT.

| Attribute                                      | Description                                                                                                                                                                                                                                                   |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>reject_preset_coefficient_request</code> | Each bit maps to a corresponding lane. When a bit is set to 1'b1, the corresponding lane rejects the new preset and coefficient values. This bit is applicable only in equalization phase 2 for Downstream Ports and equalization phase 3 for Upstream Ports. |

For example:

```
root_cfg.pcie_cfg.pl_cfg.reject_preset_coefficient_request = 32'h0
```

For more information, see “*Is there any provision in VIP to reject incoming new Preset/coefficient requests sent by EP DUT in Phase2/RC DUT in Phase3?*” in “Equalization” section in [PCIe SVT FAQ](#).

#### 5.4.3 Preset and Coefficient Tuning Through Windowed Filtering

During Recovery . Equalization phases 2 and 3, the preset and coefficient of PHY transmitter are tuned for optimal signal integrity at receiver. PCIe specification describes the equalization process but does not specify the actual algorithm involving the preset and coefficient tuning. This section describes the supported optional algorithm to tune preset and coefficient through a library sequence.



Currently, only the sequence operating on Endpoint VIP with master PIPE at Gen 3 is part of sequence library.

This section describes the preset and coefficient tuning algorithm from the perspective of VIP acting as upstream port with master PIPE interface, during Recovery . Equalization phase 2.

Figure of Merit (FOM) feedback mechanism is used for the process of fine tuning link partners PHY TX presets and Direction Change (DIR) feedback is used for fine tuning link partner's PHY TX coefficients. Both preset and coefficient tuning are options, MAC may choose to not to do any tuning or either one or both. If both preset and coefficient are to be tuned, preset tuning is done first followed by coefficient tuning.

##### Figure of Merit (FOM)

For preset selection through FOM feedback, MAC will send a set of user-programmed presets to link partners PHY one at a time and will instruct its own PHY to evaluate incoming RX signal integrity. After PHY is done with evaluation of incoming signal, it will respond with a relative score for the preset sent, ranging from 0 to 255 through `LinkEvaluationFeedbackFigureMerit[7:0]` PIPE signal. Higher the FOM feedback value, better is the incoming RX signal integrity. Once MAC has evaluated all the programmed presets, it will select the preset with the highest FOM feedback value.

##### Direction Change (DIR)

For coefficient tuning through DIR feedback, MAC sends coefficients (precursor, cursor and postcursor) for link partner PHY transmitter, then request its own PHY to evaluate the incoming RX signal integrity. After

PHY is done with evaluating the incoming signal integrity, it will provide the feedback on `LinkEvaluationFeedbackDirectionChange[5:0]` PIPE signal and 2-bit feedback per coefficient. A value of 2'b00 indicates no further change is required for coefficient, a value of 2'b01 means increment the coefficient value by 1 and a value of 2'b10 means decrement value of coefficient by 1. Value of 2'b11 is reserved. Coefficient tuning is considered done if DIR feedback of zero (no change) is received on all lanes at the same time, this approach might take a long time, something may result in oscillatory behavior with settling down and DIR feedback does not converge on zero for all lanes at the same time. An alternate approach will be to use Windowed Filtering for DIR convergence.

### DIR Convergence Criteria of Windowed Filtering

The simple convergence of DIR feedback is to get 2'b00 corresponding to precursor and postcursor coefficients on all relevant lanes, at times this can result in a scenario where the feedback oscillates between increment by 1 (2'b01) and decrement by 1 (2'b10) without settling down no change (2'b00) or DIR feedback of 2'b00 is not achieved for all lanes simultaneously. To overcome these issues, an alternate option of Windowed Filtering for DIR Convergence Criteria can be used.

Windowed Filtering for DIR Convergence Criteria involve requesting at least  $D$  number of coefficients, such that the maximum difference between the coefficients values in last  $D$  attempts are less than equal to a value  $A$ . The parameter  $D$  is Convergence Window Depth and  $A$  is Convergence Window Aperture.

#### 5.4.3.1 Equalization Windowing Endpoint (Upstream Port) Sequence

The `svt_pcie_device_virtual_endpoint_mpipe_8g_equalization_seq` sequence will respond to equalization process initiated by downstream port. If the equalization process involves phase 2 and phase 3, in phase 2 it will provide means to fine tune downstream port PHY transmitter preset/coefficient and in Phase 3, it responds to downstream port's attempts to fine tune upstream port PHY's transmitter preset/coefficients.

This sequence performs equalization through Endpoint with MPIPE at Gen3 speed. The sequence takes control during equalization phase 2 when Endpoint (upstream port) is the equalization master. Sequence can be programmed to tune preset, coefficients or both. Endpoint in MPIPE mode in equalization phase 2 sends presets and coefficients to link partner PHY and after getting acknowledgment from link partner, instructs Endpoint PHY to do evaluation of preset/coefficients (by asserting `rx_eq_eval`). Endpoint in MPIPE mode in equalization phase 3 receives the preset/coefficients from link partner and passes it on to Endpoint PHY through MPIPE signals (`TxDemph`).

For preset tuning in phase 2, sequence can be programmed to send multiple presets, sequence keeps track of all the preset and FOM feedback they received. After sending all the presets, sequence picks the preset with highest FOM.

For coefficients tuning, sequence can be programmed through `dir_convergence_mode_8g`, either use Windowed Filtering method or feedback of zero on all lanes.

Coefficients tuning with feedback of zero on all lanes, sequence will calculate next set of coefficients based on DIR feedback, sends the new coefficients until DIR feedback precursor and postcursor coefficients are zero.

In Windowed Filtering convergence mode, sequence must be programmed with `dir_convergence_window_depth_8g` and `dir_convergence_window_aperture_8g`.

- ❖ `dir_convergence_window_depth_8g` is the minimum number of coefficient sets to be tried.
- ❖ `dir_convergence_window_aperture_8g` is the acceptable difference between the minimum and maximum value of coefficient in last  $D$  tries, where  $D$  is `dir_convergence_window_depth_8g`.

Coefficient tuning during Windowed Filtering is considered done if the delta between the minimum and maximum coefficient is equal to or less than `dir_convergence_window_aperture_8g` for `dir_convergence_window_depth_8g`.



**Note** This sequence will run only on upstream port (Endpoint) agent with MPIPE interface, otherwise results in fatal error.

**Table 5-12 Controls**

| Control                                                                        | Description                                                                                                                                                                                                                                                           |
|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>rand bit<br/>tune_remote_tx_preset_8g</code>                             | If set, Endpoint will request preset in <code>preset_vector_8g</code> and find the best one through FOM feedback process.                                                                                                                                             |
| <code>rand bit [15:0]<br/>preset_vector_8g</code>                              | List of presets to try. Each bit corresponds to a respective preset encoding, —that is, if <code>preset_vector_8g [0]</code> is set transmitter preset encoding "0000" will be requested.<br>Same preset will be tried on all lanes as per the implemented algorithm. |
| <code>rand bit<br/>tune_remote_tx_coefficient_8g</code>                        | If set, sequence will do coefficient tuning in equalization phase 2.                                                                                                                                                                                                  |
| <code>rand int unsigned<br/>max_iteration_for_coeff_conver<br/>gence_8g</code> | Maximum number of iteration sequence will try for coefficient tuning process to converge. If coefficient tuning process does not converge even after reaching the maximum number of iterations, sequence will exit coefficient tuning with a warning.                 |
| <code>rand bit<br/>dir_convergence_mode_8g</code>                              | Coefficient tuning convergence mode <ul style="list-style-type: none"> <li>• 0 - Feedback of zero on all lanes</li> <li>• 1 - Windowed filtering.</li> </ul>                                                                                                          |
| <code>rand int unsigned<br/>dir_convergence_window_depth_8<br/>g</code>        | The minimum number of coefficient sets iteration to be tried before checking if convergence criteria is met. Only used if <code>dir_convergence_mode_8g</code> is windowed filtering.                                                                                 |
| <code>rand int unsigned<br/>dir_convergence_window_apertur<br/>e_8g</code>     | The acceptable difference between the minimum and maximum value of coefficient in last $N$ iteration, when $N$ is <code>dir_convergence_window_depth_8g</code> . Only used if <code>dir_convergence_mode_8g</code> is windowed filtering.                             |

# 6 Gen4 Features

---

This chapter describes the Gen4 features available with the Synopsys PCIe Verification IP. This chapter discusses the following topics:

- ❖ [Gen4 Protocol Features](#)
- ❖ [Using SKP Ordered Sets](#)
- ❖ [Address Translation Services](#)
- ❖ [PCIe VIP Bare COM Support](#)
- ❖ [OBFF Feature Support](#)
- ❖ [Replay Timer](#)
- ❖ [SRIS/SRNS](#)

## 6.1 Gen4 Protocol Features

This section describes the Gen4 protocol features supported by PCIe SVT VIP and the usage notes to use in UVM environment. The VIP currently supports the 0.7 (November '16) version of the PCIe Gen4 specification. Implementation of Gen4 features is based on a draft specification and thus is subject to change as new versions of the specification are released. Gen4 feature can be enabled with either a library (VIP-LIBRARY-SVT + DesignWare-Regression) or suite (VIP-PCIE-G4-SVT) license. For more details, see [Licensing Information](#).

## 6.1.1 Enabling Gen4

To enable Gen4 features, use the `SVT_PCIE_ENABLE_GEN4` define. The license manager checks for a Gen4 license when this define is set.



**Note** To enable Gen4 protocol checks, set the specification version to 4.0.

```
svt_PCIE_device_configuration::pcie_spec_ver==svt_PCIE_device_configuration::PCIE_SPEC_VER_4_0;
```

Also, set the appropriate PIPE version with

```
svt_PCIE_device_configuration::pipe_spec_ver.
```

Currently, the following PIPE versions are supported:

- `PIPE_SPEC_VER_4`
- `PIPE_SPEC_VER_4_2`
- `PIPE_SPEC_VER_4_3`
- `PIPE_SPEC_VER_4_4`

## 6.1.2 Gen4 Feature Set

The following Gen4 features are supported:

### 6.1.2.1 Gen4 Speed Change

Gen4 speed is supported with the same command as other speeds. See `svt_PCIE_pl_configuration::set_link_speed_values()`, for example the following will allow Gen1-Gen4 speeds.

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_16_0G |
`SVT_PCIE_SPEED_8_0G |
`SVT_PCIE_SPEED_5_0G |
`SVT_PCIE_SPEED_2_5G);
```

### 6.1.2.2 Gen4 Equalization

The PCIe VIP supports the Gen4 changes to Equalization. Equalization is requested by using `svt_PCIE_pl_service_request_equalization_sequence` PL service request.

Different FS/LF values are configured via `lf_value_16g[32]` and `fs_value_16g[32]` attributes declared in `svt_PCIE_pl_configuration` class and these values advertised by VIP in TS1s during 16G Equalization phase 1.

VIP transmits a new preset/coefficient requests in Phase2 EP DUT/Phase3 RC DUT by using `svt_PCIE_pl_service_queue_eq_tx_request_preset_coeff` PL service request.

### 6.1.2.2.1 Configuration Variables

There are a series of configuration variables in the `svt_PCIE_pl_configuration` class and you can use these configuration variables as per your requirement to test a particular portion of the specification.

For more information on configuration variables, see “Class Listing” in the HTML class reference documentation.

The relevant controls are as follows:

- ❖ `enable_get_local_preset_coefficients`
- ❖ `enable_get_local_preset_coefficients_checking`

- ❖ enable\_local\_lane\_lf\_checking
- ❖ enable\_equalization\_verification\_mode
- ❖ enable\_equalization\_coefficients\_checks
- ❖ highest\_enabled\_equalization\_phase
- ❖ num\_additional\_ts\_eq\_before\_trans\_eq0
- ❖ num\_additional\_ts\_eq\_before\_trans\_eq1
- ❖ num\_additional\_ts\_eq\_before\_trans\_eq2
- ❖ num\_additional\_ts\_eq\_before\_trans\_eq3
- ❖ upstream\_lanes\_recovery\_eq\_phase0\_timeout\_ns
- ❖ upstream\_lanes\_recovery\_eq\_phase1\_timeout\_ns
- ❖ upstream\_lanes\_recovery\_eq\_phase2\_timeout\_ns
- ❖ upstream\_lanes\_recovery\_eq\_phase3\_timeout\_ns
- ❖ downstream\_lanes\_recovery\_eq\_phase1\_timeout\_ns
- ❖ downstream\_lanes\_recovery\_eq\_phase2\_timeout\_ns
- ❖ downstream\_lanes\_recovery\_eq\_phase3\_timeout\_ns
- ❖ reject\_preset\_coefficient\_request
- ❖ tx\_ts1\_reset\_eieos\_interval\_count\_bit
- ❖ eq\_rx\_reset\_eieos\_interval
- ❖ min\_spipe\_preset\_coefficients\_delay
- ❖ max\_spipe\_preset\_coefficients\_delay
- ❖ enable\_upconfigure\_support = 1;
- ❖ attached\_lf\_16g[32]
- ❖ local\_lf\_16g[32]
- ❖ attached\_fs\_16g[32]
- ❖ local\_fs\_16g[32]
- ❖ lf\_value\_16g[32]
- ❖ fs\_value\_16g[32]
- ❖ min\_eq\_evaluation\_delay[32]
- ❖ max\_eq\_evaluation\_delay[32]
- ❖ max\_eq\_evaluation\_delay[32]
- ❖ min\_rx\_eq\_eval\_delay[32]
- ❖ max\_rx\_eq\_eval\_delay[32]
- ❖ min\_eq\_preset\_coeff\_validation\_delay[32]
- ❖ max\_eq\_preset\_coeff\_validation\_delay[32]
- ❖ min\_eq\_eval\_cycle\_duration\_in\_ns
- ❖ max\_eq\_eval\_cycle\_duration\_in\_ns
- ❖ preset\_to\_coefficients\_mapping\_entry\_valid\_16g
- ❖ preset\_to\_coefficients\_mapping\_table\_16g[16]
- ❖ expected\_preset\_to\_coefficients\_mapping\_entry\_enable\_16g
- ❖ expected\_preset\_to\_coefficients\_mapping\_table\_16g[16]

- ❖ upstream\_receiver\_preset\_hint\_16g[32]
- ❖ downstream\_receiver\_preset\_hint\_16g[32]
- ❖ upstream\_preset\_value\_16g[32]
- ❖ downstream\_preset\_value\_16g[32]
- ❖ quiesce\_guarantee
- ❖ enable\_rxeqeval\_default\_settings\_vector

### Example 6-1

```
cust_cfg.root_cfg.pcie_cfg.pl_cfg.highest_enabled_equalization_phase      = 3;
cust_cfg.endpoint_cfg.pcie_cfg.pl_cfg.highest_enabled_equalization_phase  = 3;
cust_cfg.root_cfg.pcie_cfg.pl_cfg.enable_equalization_verification_mode = 1;
cust_cfg.endpoint_cfg.pcie_cfg.pl_cfg.enable_equalization_verification_mode = 1;
cust_cfg.root_cfg.pcie_cfg.pl_cfg.enable_equalization_coefficients_checks = 1;
cust_cfg.endpoint_cfg.pcie_cfg.pl_cfg.enable_equalization_coefficients_checks = 1;
```

#### 6.1.2.2.2 Status Variables

There are a series of status variables in `svt_PCIE_pl_Status` class to know the status of Equalization execution. You can use these status variables to know the status of the Equalization in different Phases, Phase0, Phase1, Phase2 and Phase3.

For more information on status variables, see “Class Listing” in the HTML class reference documentation.

The relevant controls are as follows:

- ❖ num\_of\_eq\_phase1\_successful
- ❖ num\_of\_eq\_phase2\_successful
- ❖ num\_of\_eq\_phase3\_successful
- ❖ num\_of\_tx\_eq\_preset\_requests[32]
- ❖ num\_of\_tx\_eq\_coefficients\_requests[32]
- ❖ num\_of\_rx\_eq\_preset\_requests[32]
- ❖ num\_of\_rx\_eq\_coefficients\_requests[32]
- ❖ num\_of\_rx\_eq\_preset\_requests\_rejected[32]
- ❖ num\_of\_rx\_eq\_coefficients\_requests\_rejected[32]
- ❖ perform\_equalization
- ❖ request\_equalization
- ❖ equalization\_complete
- ❖ equalization\_16g\_complete
- ❖ equalization\_16g\_phase\_1\_successful
- ❖ equalization\_16g\_phase\_2\_successful
- ❖ equalization\_16g\_phase\_3\_successful
- ❖ eq\_rx\_requested\_preset\_coefficients\_valid
- ❖ eq\_rx\_use\_preset\_bit[32]
- ❖ eq\_rx\_preset[32]
- ❖ eq\_rx\_precursor\_coeff[32]
- ❖ eq\_rx\_cursor\_coeff[32]
- ❖ eq\_rx\_postcursor\_coeff[32]

- ❖ eq\_rx\_reject\_coefficients[32]
- ❖ eq\_rx\_reset\_eieos\_interval\_count[32]
- ❖ eq\_rx\_request\_equalization[32]
- ❖ eq\_rx\_quiesce\_guarantee[32]
- ❖ rcvd\_fs\_lf\_value\_valid\_16g
- ❖ rcvd\_fs\_value\_16g[32]
- ❖ rcvd\_lf\_value\_16g[32]
- ❖ rcvd\_lf\_value\_16g[32]
- ❖ rcvd\_upstream\_receiver\_preset\_hint\_16g[32]
- ❖ rcvd\_downstream\_receiver\_preset\_hint\_16g[32]
- ❖ rcvd\_upstream\_preset\_value\_16g[32]
- ❖ rcvd\_downstream\_preset\_value\_16g[32]
- ❖ retimer\_presence\_detected

### Example 6-2

```
wait(endpoint_device.pcie_agent.pl.status.lane_status[1].eq_rx_precursor_coeff == 5);  
wait(root_device.pcie_agent.pl.status.lane_status[1].eq_rx_precursor_coeff == 5);
```

#### 6.1.2.2.3 Sequences

There are a series of service requests in the `svt_PCIE_Pl_Service` class. Also, many of these are mapped to service sequences in `svt_PCIE_Pl_Service_Sequence_Collection` class you can run directly.

For more information on sequences, see “Class Listing” in the HTML class reference documentation.

- ❖ `svt_PCIE_Pl_Service_Request_Equalization_Sequence`: Useful to request equalization process.
- ❖ `svt_PCIE_Pl_Service_Perform_Equalization_Sequence`: Useful in redo equalization case.
- ❖ `svt_PCIE_Pl_Service_Queue_EQ_Tx_Request_Preset_Coeff`: Useful for queuing preset/coefficient requests in Phase2 EP DUT/Phase3 RC DUT.
- ❖ `svt_PCIE_Pl_Service_Queue_EQ_Direction_Change_Response`: Useful for queuing direction change response in PIPE mode.
- ❖ `svt_PCIE_Pl_Service_Queue_EQ_Figure_Merit_Response`: Useful for queuing figure of merit response in PIPE mode
- ❖ `svt_PCIE_Pl_Service_Initiate_Retrain_Link_Sequence`: Useful for requesting the LTSSM to go to Recovery.

### Example 6-3

```
svt_PCIE_Pl_Service_Request_Equalization_Sequence request_equalization;  
request_equalization =  
    svt_PCIE_Pl_Service_Request_Equalization_Sequence::type_id::create("request_equalization");  
    request_equalization.start(p_sequencer.root_virt_seqr.pcie_virt_seqr.pl_seqr);
```

#### Statistics

- ❖ `svt_PCIE_EQ_Eval_Cycle`
- ❖ `svt_PCIE_EQ_Status`

Refer to the following tests at `/pcie_svt/test/sverilog/tb_PCIE_16g_Device_System_UVM/tests:`

- ❖ *ts.eq\_16g\_ph0\_ph1.sv*
- ❖ *ts.eq\_16g\_ph2\_ph3.sv*
- ❖ *ts.equalization.sv*
- ❖ *ts.redo\_eq\_ep\_requests\_redo\_eq\_at\_2\_5g\_rc\_is\_directed\_link\_reaches\_8g\_w\_eq.sv*
- ❖ *ts.redo\_eq\_ep\_requests\_redo\_eq\_at\_8g\_rc\_follows\_w\_eq.sv*
- ❖ *ts.redo\_eq\_rc\_requests\_redo\_eq\_at\_2\_5g\_ep\_follows\_to\_8g\_w\_eq.sv*

Also, see Gen4 TS tests at `/pcie_test_suite_svt/test/sverilog/env/tests:`

- ❖ *ts.gen4\_pl\_recovery\_equalization\_phase0\_to\_phase1\_case2\_error.sv* ...

### 6.1.3 EIEOS Format Change

The VIP supports the Electrical Idle Exit Ordered Set for Gen4. By default, it is on. It can be disabled with `svt_PCIE_pl_configuration::enable_eieos_16g_0000_ffff`.

### 6.1.4 10-Bit Tag

The model supports the Gen4 10-bit tag feature. To enable 10-bit tag, set the `SVT_PCIE_ENABLE_10_BIT_TAGS` define. Also, the `svt_PCIE_t1_configuration::remote_extend_tag_field_enabled` bit must be set to 1 for 10-bit and 8-bit tags. The PCIe specification version must be set to 4.0 or higher in the device configuration (SVT users) or in all of the various protocol layers (SVC users).

```
svt_PCIE_device_configuration::pcie_spec_ver==svt_PCIE_device_configuration::PCIE_SPEC_VER_4_0;
```

In order for the driver and requester application to generate 10-bit tags, the `max_num_tags` control must be set to 1024 to generate tags up to 3ff. A value of 256 means 8-bit tags. If this value is not set, then the model will consider it as 8-bit tag.

#### 6.1.4.1 Setting Tag Properties for Requester ID

To allow 10-bit tag control on Requester ID (RID) basis, configure the driver before queuing any requests. A function named `set_req_id_tag_properties` needs to be called. There must be one call per Requester ID that the test intends to use. To preserve backwards compatibility, if a request is queued using an unconfigured Requester ID, then the driver will use the existing `max_num_tags` item in the configuration class. The `set_req_id_tag_properties` function will also define which portion of the tag pool is reserved for 8-bit tags and 10-bit tags.

When the driver is automatically managing the tag pool (that is, when user tags are disabled), it must know which kind of tag to issue when 8-bit tags and 10-bit tags are being used concurrently. To address this, the following function is added to the driver configuration:

```
set_req_id_tag_properties (bit [15:0] req_id, bit [31:0] max_num_tags, bit [31:0] num_bits_for_concurrent_8bit_tags = 0)
```

where,

- ❖ `req_id` - The Requester ID that is being configured.
- ❖ `max_num_tags` - The maximum number of tags in the tag pool for a given Requester ID. If set to a value greater than 256, then 10-bit tags will be used. If set to a value less than or equal to 256, then 8-bit tags will be used. This variable must be set to 1024 to utilize the maximum 768 available tag from an RID. 10-bit tags will be utilized for NPR only.

- ❖ `num_bits_for_concurrent_8bit_tags` – This argument controls how many bits are available for 8-bit tag use if 8-bit and 10-bit tags are used concurrently. For example, if the number is set to 3, then the bottom 3 bits of the tag field will be reserved for 8-bit tags. Because 8-bit tags cannot be aliased for 10-bit tags, which implies that  $8 \times 3 = 24$  tags will be removed from the 10-bit tag pool.

For example, if `set_req_id_tag_properties(1234, 1024, 1)` is called, then the Requester ID 1234 will be enabled for 10-bit tags, with bit 0 reserved for 8 bit request. This means that a maximum of 2 requests can be outstanding to functions that support 8-bit tags ('b0000000000 and 'b0000000001). Additionally, 6 eligible tags have been removed from the 10-bit tag pool (tags 'b010000000000, 'b010000000001, 'b100000000000, 'b100000000001, 1100000000, and 110000000001). Set the `num_bits_for_concurrent_8bit_tags` argument to 0 if you do not want to use concurrent 8-bit and 10-bit tags.

If a request is queued with an RID that has not been configured through `set_req_id_tag_properties()`, then the VIP will apply the default settings from `max_num_tags` in the configuration class and if 10-bit tags are enabled, no bits will be allocated for a 8-bit tag use. Concurrent tags are disabled by default unless explicitly enabled by the `set_req_id_properties` task. This maintains backwards compatibility for all the existing tests.

#### 6.1.4.2 Limitation

- ❖ Tag properties should not be changed unless the driver is idle.
- ❖ Currently, VIP does not support the concurrent mode. Hence, the variable `num_bits_for_concurrent_8bit_tags` must be set to 0.

#### 6.1.5 Retimer

The VIP will work in a system which supports one or two Retimers by adjusting the LTSSM behavior. The VIP does not provide a model of a Retimer, but instead model a system that contains one component (RC or EP) and one or two Retimers. When a Retimer is included, the interface changes to model the corresponding Pseudo port of the Retimer, therefore for an RC with a Retimer it is the Downstream Pseudo port of the Retimer that is the interface to the VIP, and for an EP with a Retimer it is the Upstream Pseudo port that is the interface.

### 6.1.5.1 Enabling Retimers

Retimers are enabled by configuring the VIP to include either one or two Retimers. This is done via the `set_retimer_present` configuration attribute.

**Table 6-1 Enabling Retimers**

| Attribute                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>set_retimer_present</code> | <p>Indicates the presence of Retimer.</p> <ul style="list-style-type: none"> <li>When bit0 is set, the VIP will model a sub-system that includes at least one Retimer. This includes setting the Retimer present bit in the outgoing training sets.</li> <li>When bit1 is set, the VIP will model a sub-system that includes two Retimers. This includes setting the two Retimers present bit in the outgoing training sets.</li> <li>In addition to modifying the training sets, this attribute also impacts how the VIP will respond to RX Margin commands. This attribute will be used to decide when RX margin addresses the model will respond to with respect to requests for remote PHY Rx Margining. This feature is only enabled when <code>enable_ctrl_skp_support</code> is also enabled.</li> <li>When bit0 is set, the VIP will respond to commands targeted to Retimer 1 including margin commands to receiver ports B (<code>receiver_number</code> 3'b010) and C (<code>receiver_number</code> 3'b011).</li> <li>When bit1 is set, the VIP will respond to commands targeted to Retimer 2 including margin commands to receiver ports D (<code>receiver_number</code> 3'b100) and E (<code>receiver_number</code> 3'b101).</li> </ul> |

### 6.1.5.2 Retimer Presence Detect

In order to test a DUT's retimer presence detect capability, the VIP can set the retimer present bit in an outgoing TS at Gen1 with the `svt_PCIE_pl_configuration::set_retimer_present` bit. Set to 1'b1 to enable.

In order for the VIP to detect a retimer, the bit `svt_PCIE_pl_configuration::retimer_presence_detect_supported` bit in the PHY layer configuration class must be set to 1. If a retimer is detected, then the LTSSM will behave according to the rules in the Rev 0.7 draft.

You can check the PL status class, `svt_PCIE_pl_status::retimer_presence_detected` to determine if the VIP detected a retimer during link training. Note that bit0 refers to the first retimer being present while bit1 refers to the second retimer being present.

### 6.1.6 Retimer Equalization

When the VIP is used as a component plus a Retimer, the equalization is modified to reflect that the interface is now one of the pseudo ports on the Retimer and so that this equalization now depends on internal events happening on the internal port in-between the Retimer and the component. There are seven new configuration attributes used to schedule these internal events. These attributes are only used if the

`svt_pcie_pl_configuration::set_retimer_present` is set to a non-zero value indicating that the VIP includes at least one Retimer.

**Table 6-2 Retimer Equalization**

| Attribute                                                                    | Applicable | Default value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>retimer_internal_recovery_eq_phase2_active_timeout_ns</code>           | RC         | 10000         | Specifies the timeout in NS for the internal upstream lanes from the Retimer to upstream device in Recovery.Equalization.Phase2. This value is used to control the Retimer Equalization Extend bit of the TS1 transmitted on the downstream lanes from the Retimer in Recovery.Equalization.Phase2. Only used in 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer.                                                |
| <code>retimer_internal_recovery_eq_phase3_exit_timeout_ns</code>             | RC         | 12000         | Specifies the timeout in NS for the internal upstream lanes from the Retimer to upstream device to exit Phase3 in Recovery.Equalization.Phase3. This value is used to control the exit of Phase3 in the downstream lanes from the Retimer in Recovery.Equalization.Phase3. Used in both 8GT/s and 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer.                                                               |
| <code>retimer_internal_recovery_eq_phase3_started_timeout_ns</code>          | EP         | 12000         | Specifies the timeout in NS for the internal downstream lanes from the Retimer to downstream device from start of Recovery.Equalization.Phase2 until it enters Recovery.Equalization.Phase3. This value is used to control when the upstream lanes from the Retimer change to Recovery.Equalization.Phase3. Only used in 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer.                                        |
| <code>retimer_internal_recovery_eq_phase3_active_timeout_ns</code>           | EP         | 10000         | Specifies the timeout in NS for the internal downstream lanes from the Retimer to downstream device in Recovery.Equalization.Phase3. This value is used to control the Retimer Equalization Extend bit of the TS1 transmitted on the upstream lanes from the Retimer in Recovery.Equalization.Phase3. Only used in 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer.                                              |
| <code>retimer_internal_recovery_eq_phase3_active_completed_timeout_ns</code> | EP         | 12000         | Specifies the timeout in NS for the internal downstream lanes from the Retimer to downstream device to exit Phase3 active in Recovery.Equalization.Phase3. The value is given from start of Recovery.Equalization.Phase2. This value is used to control the entry of Phase3 in the upstream lanes from the Retimer in Recovery.Equalization.Phase2. Only used in 8GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer. |

**Table 6-2 Retimer Equalization**

| <b>Attribute</b>                                                    | <b>Applicable</b> | <b>Default value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------|-------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| retimer_internal_recovery_eq_force_timeout_eios_detected_timeout_ns | EP                | 1000                 | Specifies the timeout in NS for the Retimer internal ports to detect EIOS during Force.Timeout. This value is used to control as part of the exit condition from Force.Timeout to the entry of Recovery.Speed. Used in both 8GT/s and 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer. |
| retimer_recovery_eq_force_timeout_timeout_ns                        | EP                | 48000                | Specifies the timeout in NS for the Retimer Force.Timeout state timeout. Used in both 8GT/s and 16GT/s when VIP is modeling a system that includes a component (RC or EP) and at least one Retimer.                                                                                                                                       |

The following figures shows the relationship between events on the externally visible ports and the internally configuration driven events.

- ❖ VIP is RC and Retimer



❖ VIP is EP and Retimer



### 6.1.7 Retimer Latency

**Table 6-3 Remiter Latency**

| Attribute                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_retimer_latency_2_5g_ns | Programmable latency used to mimic the presence of a retimer on the Rx data path. Setting this value in ns will result in the VIP adding an internal latency to the PIPE interface to the value specified rounded down to the nearest PIPE clock when running at 2.5G. This should be left at 0 unless a retimer is present and you want to intentionally add latency. Setting this to a large value may impact simulation speed. |
| rx_retimer_latency_5g_ns   | Programmable latency used to mimic the presence of a retimer on the Rx data path. Setting this value in ns will result in the VIP adding an internal latency to the PIPE interface to the value specified rounded down to the nearest PIPE clock when running at 5G. This should be left at 0 unless a retimer is present and you want to intentionally add latency. Setting this to a large value may impact simulation speed.   |
| rx_retimer_latency_8g_ns   | Programmable latency used to mimic the presence of a retimer on the Rx data path. Setting this value in ns will result in the VIP adding an internal latency to the PIPE interface to the value specified rounded down to the nearest PIPE clock when running at 8G. This should be left at 0 unless a retimer is present and you want to intentionally add latency. Setting this to a large value may impact simulation speed.   |
| rx_retimer_latency_16g_ns  | Programmable latency used to mimic the presence of a retimer on the Rx data path. Setting this value in ns will result in the VIP adding an internal latency to the PIPE interface to the value specified rounded down to the nearest PIPE clock when running at 16G. This should be left at 0 unless a retimer is present and you want to intentionally add latency. Setting this to a large value may impact simulation speed.  |

### 6.1.8 Flow Control Credit Scaling

Flow Control Credit Scaling is enabled by the

`svt_PCIE_DL_Configuration::enable_DL_feature_handshake` member. The scale values for each VC/type are configured via the `init_[p|np|cpl]_[data|hdr]_tx_credit_fc_scale[8]` attributes in TL configuration (`svt_PCIE_TL_Configuration`) to enable different scaling factors. For more details about controls, see the HTML class reference documentation.

The relevant controls are as follows:

- ❖ `svt_PCIE_Device_Configuration::PCIe_Spec_Ver`
- ❖ `svt_PCIE_TL_Configuration`
  - ◆ `init_[p|np|cpl]_[data|hdr]_tx_credit_fc_scale[8]`
- ❖ `svt_PCIE_TL_Status`
  - ◆ `local_fc_scale_mode[48]`
  - ◆ `remote_fc_scale_mode[48]`
- ❖ `svt_PCIE_DL_Configuration`
  - ◆ `enable_DL_feature_handshake`
  - ◆ `local_DL_feature_supported`
- ❖ `svt_PCIE_DL_Status`
  - ◆ `local_DL_feature_supported`
  - ◆ `remote_DL_feature_supported`

- ◆ d1\_feature\_status

Additional checks in Transaction layer and Data Link layer are as follows:

- ❖ Transaction layer
  - ◆ MSGCODE\_PCIE\_SVC\_TL\_FC\_HDR\_SCALE\_CHANGED
  - ◆ MSGCODE\_PCIE\_SVC\_TL\_FC\_DATA\_SCALE\_CHANGED
  - ◆ MSGCODE\_PCIE\_SVC\_TL\_FC\_DATA\_HDR\_SCALE\_ZERO
  - ◆ MSGCODE\_PCIE\_SVC\_TL\_FC\_DATA\_HDR\_SCALE\_NON\_ZERO
- ❖ Data Link layer
  - ◆ MSGCODE\_PCIE\_SVC\_DL\_FEATURE\_ACK\_DEASSERTED
  - ◆ MSGCODE\_PCIE\_SVC\_DL\_FEATURE\_ACK\_TIMEOUT
  - ◆ MSGCODE\_PCIE\_SVC\_DL\_FEATURE\_RSVD\_NON\_ZERO

Code snippet:

```
cfg.rc_cfg.pcie_cfg.dl_cfg.enable_dl_feature_handshake=1;  
  
//Configure hdr and data Scale value.  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_p_hdr_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;  
;  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_p_data_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_np_data_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_np_hdr_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_cpl_hdr_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;  
  
cfg.rc_cfg.pcie_cfg.tl_cfg.init_cpl_data_tx_credit_fc_scale[0]=`SVT_PCIE_FC_SCALE_FACTOR_X1;
```

The default value is zero, therefore you must select at least one of scaling factor as indicated in the above Scale factor (01).

```
01(`SVT_PCIE_FC_SCALE_FACTOR_X1),  
10(`SVT_PCIE_FC_SCALE_FACTOR_X4),  
11(`SVT_PCIE_FC_SCALE_FACTOR_X16)
```

The VIP will issue an error if the above TL configuration variables are not set after enabling enable\_dl\_feature\_handshake.

## 6.1.9 Rx Margining

### 6.1.9.1 Initiating Remote PHY Rx Margining by Upstream Component (RC) Using CTRL-SKP OS

#### 6.1.9.1.1 Control SKP OS

The Control SKP OS is used for the Upstream component to request parity and margining information from other components/ports. This OS is transmitted in Configuration.Idle and Recovery.Idle just prior to

the SDS in 16GT/s and is used for parity initialization. It is also used in L0, where every other SKP transmitted is a CRTL-SKP OS.

### 6.1.9.1.2 Enabling CTRL-SKP OS and Rx Margining Features

CTRL-SKP OS and Rx Margining is enabled by the

`svt_PCIE_pl_configuration::enable_ctrl_skp_support` attribute in PHY layer configuration class. The default value of this attribute is '1' and VIP will generate every other SKP OS during L0 as a CRTL-SKP instead of a regular SKP OS. This feature must be enabled to support Rx Margining because it uses the CTRL-SKP OS to transmit information.

In addition to enabling CTRL-SKP OS, you can also select the response mode when the VIP is acting as EP and Retimer. In this mode, the VIP will respond to CTRL-SKP OS's that are sending Rx Margin commands to a Retimer model by the VIP based on the configuration of the

`svt_PCIE_pl_configuration::set_retimer_present` attribute. The two response modes supported is manual mode and automatic mode configured using

`svt_PCIE_pl_configuration::rx_margin_automatic_response_mode`. In automatic mode, the VIP will generate response to the Rx Margin commands based on configured attributes and internal state of margin operations, while in manual mode the response is provided by the testbench via the

`svt_PCIE_pl_service::RX_MARGIN_RESPONSE`.

### 6.1.9.1.3 Using Rx Margin Command

Rx Margining commands can be transmitted through service channel request

`svt_PCIE_pl_service::CTRL_SKP_CMD`. This service request loads up from an enum of Rx Margining commands with lane number, indicating which lane the CTRL-SKP OS is going to be transmitted on, receiver number, receiver address, margin type and step direction (in case of Step Margin commands). This is only applicable when the model is at 16GT/s and in L0. The commands which can be transmitted through this service request are listed in [Table 6-4](#). The CRTL-SKP service request is only applicable to the RC while the `INCREMENT_MARGIN_ERROR_COUNT` is applicable to both RC and EP.

**Table 6-4 Rx Margining Commands**

| Command Name                       | Applicable | Command Attributes               | Description                                                                                                                                                 |
|------------------------------------|------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACCESS_RETIMER_REGISTER (Optional) | RC         | retimer[2:0],register_a ddr[7:0] |                                                                                                                                                             |
| REPORT_MARGIN_CONTROL_CAPABILITIES | RC         | receiver_number[2:0]             | Initiate a Margin command to return configuration attribute<br><code>MARGIN_CONTROL_CAPABILITIES</code> in Margin Payload response for associated receiver. |
| REPORT_M_NUM_VOLTAGE_STEPS         | RC         | receiver_number[2:0]             | Initiate a Margin command to return configuration attribute<br><code>M_NUM_VOLTAGE_STEPS</code> in Margin Payload response for associated receiver.         |
| REPORT_M_NUM_TIMING_STEPS          | RC         | receiver_number[2:0]             | Initiate a Margin command to return configuration attribute<br><code>M_NUM_TIMING_STEPS</code> in Margin Payload response for associated receiver.          |

**Table 6-4 Rx Margining Commands**

| <b>Command Name</b>          | <b>Applicable</b> | <b>Command Attributes</b>                        | <b>Description</b>                                                                                                                    |
|------------------------------|-------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| REPORT_M_MAX_TIMING_OFFSET   | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute M_MAX_TIMING_OFFSET in Margin Payload response for associated receiver.   |
| REPORT_M_MAX_VOLTAGE_OFFSET  | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute M_MAX_VOLTAGE_OFFSET in Margin Payload response for associated receiver.  |
| REPORT_SAMPLING_RATE_VOLTAGE | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute SAMPLING_RATE_VOLTAGE in Margin Payload response for associated receiver. |
| REPORT_SAMPLING_RATE_TIMING  | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute SAMPLING_RATE_TIMING in Margin Payload response for associated receiver.  |
| REPORT_M_SAMPLE_COUNT        | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute M_SAMPLE_COUNT in Margin Payload response for associated receiver.        |
| REPORT_M_MAX_LANES           | RC                | receiver_number[2:0]                             | Initiate a Margin command to return configuration attribute M_MAX_LANES in Margin Payload response for associated receiver.           |
| SET_ERROR_COUNT_LIMIT        | RC                | receiver_number[2:0]; error_count_limit[5:0]     | Initiate a Margin command to set the error_count_limit for the associated receiver.                                                   |
| GO_TO_NORMAL_SETTINGS        | RC                | receiver_number[2:0]                             | Initiate a Margin command to return the associated receiver to its normal setting and terminate margin command.                       |
| CLEAR_ERROR_LOG              | RC                | receiver_number[2:0]                             | Initiate a Margin command to clear the error_count for the associated receiver.                                                       |
| STEP_MARGIN_TO_TIMING_OFFSET | RC                | receiver_number[2:0]; step_direction; steps[5:0] | Initiate a Margin command to start a timing step margin operation for the associated receiver.                                        |

**Table 6-4 Rx Margining Commands**

| Command Name                   | Applicable | Command Attributes                               | Description                                                                                                                                    |
|--------------------------------|------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| STEP_MARGIN_TO_VOLTAGE_OF_FSET | RC         | receiver_number[2:0]; step_direction; steps[5:0] | Initiate a Margin command to start a voltage step margin operation for the associated receiver.                                                |
| LOAD_REGISTER                  | RC/EP      | bit[7:0] value[3]                                | CTRL_SKP sub command to load up any value into the next CTRL-SKP OS using internal registers. This can also be used to send error CTRL-SKP OS. |
| CRTL_SKP_CMD                   | RC         | sub command; lane                                |                                                                                                                                                |
| INCREMENT_MARGIN_ERROR_COUNT   | RC/EP      | count (default 1); lane                          | Increment the current error count of the associated receiver lane.                                                                             |

#### 6.1.9.1.4 Rx Margin Command Generation From RC

RC (Upstream component) lane margin of remote PHY in Retimer using CTRL-SKP (VIP acting as MAC).

- ❖ Wait for RC to reach 16G speeds and then enter L0 with data stream turned on.
- ❖ Issue the service request to send REPORT\_MARGIN\_CONTROL\_CAPABILITIES command using CTRL\_SKP\_CMD.
- ❖ Wait for RC to receive a CTRL-SKP with margin\_type set to 3'b001 and receiver\_number matching requested address using attributes in the svt\_PCIE\_ctrl\_skp\_receiver\_status class.
- ❖ Then wait for the reception of a reflected No Command. There is no need to issue this command using the service request since the VIP will automatically send a No Command if no other command is issued.
- ❖ If required, issue additional REPORT commands one at a time and wait for their reply using the method above to request additional configuration values from port that is going to be margined.
- ❖ Issue the service request to send SET\_ERROR\_COUNT\_LIMIT command using CTRL\_SKP\_CMD.
- ❖ Wait for RC to receive a CTRL-SKP with margin\_type set to 3'b010 and receiver\_number matching requested address and expected returned error count limit using attributes in the svt\_PCIE\_ctrl\_skp\_receiver\_status class.
- ❖ Wait for the reception of a reflected No Command. There is no need to issue this command using the service request since the VIP will automatically send a No Command if no other command is issued.
- ❖ Issue the service request to send STEP\_MARGIN\_TO\_TIMING\_OFFSET or STEP\_MARGIN\_TO\_VOLTAGE\_OFFSET command with appropriate Payload values using CTRL\_SKP\_CMD.
- ❖ Keep monitoring the status of the received CTRL-SKP OS's for margin status and error count and take appropriate action based on the received status. The svt\_PCIE\_ctrl\_skp\_receiver\_status gets updated every time the VIP receives a new CTRL-SKP OS and the testbench can monitor the reception by waiting for changes to the num\_ctrl\_skp\_received.

#### 6.1.9.1.5 Rx Margin Response Generation From EP (Automatic Response Mode)

EP (Downstream component) lane margin of remote PHY in Retimer using CTRL-SKP (VIP acting as Retimer PHY).

- ❖ Configure CTRL-SKP response attributes for each Retimer device, the VIP is modeling in addition to configuring the CTRL-SKP delay (`margin_response_time`).
- ❖ Wait for receiver CTRL-SKP to indicate start of margin operation.
- ❖ Issue the service request to `INCREMENT_RX_MARGIN_BIT_ERROR_COUNT` whenever the testbench wants to pretend it detected a bit error. This would make the VIP update the status returned through the CTRL-SKP.

#### 6.1.9.1.6 Rx Margin Response Generation From EP (Manual Mode)

Response has to be manually loaded through the service channel request `svt_PCIE_PL_SERVICE::RX_MARGIN_RESPONSE`. The response can be loaded with `ctrl_ski_lane_num` (which lane to transmit CTRL-SKP OS), `receiver_number`, `margin_type` and `margin_payload`.

##### Example 6-4 Usage Example

```
//Load REPORT_M_NUM_VOLTAGE_STEPS using the service call for random number range.  
  
for (int i=min_ctrl_ski_lane_no; i<=max_ctrl_ski_lane_no; i++) begin  
    `svt_xvm_do_on_with(ctrl_ski_cmd_req, vip_seqr.pcie_virt_seqr.pl_seqr, {  
        command == svt_PCIE_PL_SERVICE::REPORT_M_NUM_VOLTAGE_STEPS;  
        ctrl_ski_lane_num == i;  
        receiver_number == 3'b010;  
    });  
end  
//preparing response for REPORT_M_NUM_VOLTAGE_STEPS  
@(dut_status.pcie_status.pl_status.ctrl_ski_receiver_status.num_ctrl_ski_received[max_ctrl_ski_lane_no]); // Wait for DUT to receive the rx margin command  
for (int i=min_ctrl_ski_lane_no; i<=max_ctrl_ski_lane_no; i++) begin  
    `svt_xvm_do_on_with(ctrl_ski_response_req, dut_seqr.pcie_virt_seqr.pl_seqr, {  
        ctrl_ski_lane_num == i;  
        margin_type == 3'b001;  
        receiver_number == 3'b010;  
        rx_margin_response_persistent == 1'b1; //Enable continuous response  
        margin_payload == {{1'b0}, MNumVoltageSteps};  
    });  
end
```

#### 6.1.9.2 Initiating Local PHY Rx Margining by Either Upstream Component (RC) or Downstream Component (EP) Using MBI

##### 6.1.9.2.1 Local PHY Rx Margining VIP Acting as MAC (MPIPE Mode)

RC (Upstream component) or EP (Downstream component) lane margin of local PHY using MBI (VIP acting as MAC). There are two different methods for generating MBI requests when the VIP is modeling the MAC side of the MBI (Message Bus Interface).

The `MBI_CMD` method uses a fine-grained command specific to the MBI using a new service request type `svt_PCIE_PL_SERVICE::MBI_CMD`. This service request can be used to send `NOP`, `WRITE_UNCOMMITTED`, `WRITE_COMMITTED` and `WRITE_ACK` commands.

The `CTRL-SKP` method uses the same service requests as the remote PHY CTRL-SKP service requests by mapping RC CTRL-SKP requests of type (`CLEAR_ERROR_LOG`, `STEP_MARGIN_TO_VOLTAGE_OFFSET`, `STEP_MARGIN_TO_TIMING_OFFSET` and `GO_TO_NORMAL_SETTINGS`) with the `receiver_number` set to `3'b010`, or EP with `receiver_number` set to `3'b110` to corresponding MBI requests. The CTRL\_SKP will not be updated and the device will continue to send CTRL-SKP with `No Command`.

- ❖ MBI\_CMD
  - ◆ Wait for RC to reach 16G speeds and then enter L0 with data stream turned on.
  - ◆ Issue the service request to send `WRITE_UNCOMMITTED` and/or `WRITE_COMMITTED` commands with appropriate `MBI_REGISTER` and `MBI_DATA` values using `MBI_CMD`.
  - ◆ Keep monitoring the status of the internal `Rx_Margin_Status` registers to detect changes to execution status, sample count and error count and take appropriate action based on the received status changes. The internal registers get updated every time a `WRITE_COMMITTED` to the status register is detected on the MBI from the PHY.
- ❖ CTRL-SKP
  - ◆ Wait for RC to reach 16G speeds and then enter L0 with data stream turned on.
  - ◆ Issue the service request to send `STEP_MARGIN_TO_TIMING_OFFSET` or `STEP_MARGIN_TO_VOLTAGE_OFFSET` command with appropriate Payload values using `CTRL_SKP_CMD`.
  - ◆ Keep monitoring the status of the internal `Rx_Margin_Status` registers to detect changes to execution status, sample count and error count and take appropriate action based on the received status changes. The internal registers get updated every time a `WRITE_COMMITTED` to the status register is detected on the MBI from the PHY.

**Table 6-5 MBI Commands**

| Command Name                 | Applicable | Command Attributes                                                                                                   | Description                                                               |
|------------------------------|------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| MBI_CMD                      | RC/EP      | <code>mbi_cmd</code> ;<br><code>mbi_lane_num</code> ;<br><code>mbi_addr[11:0]</code> ;<br><code>mbi_data[7:0]</code> | Initiate a transmit of a MBI command on the MBI PIPE signals.             |
| INCREMENT_MARGIN_ERROR_COUNT | RC/EP      | count (default is 1)                                                                                                 | Lane increment the current sample count of the associated receiver lane.  |
| NOP                          | RC/EP      | <code>bit[3:0]</code>                                                                                                |                                                                           |
| WRITE_UNcommitted            | RC/EP      | <code>bit[3:0]</code>                                                                                                | The <code>WRITE_UNcommitted</code> command performs an uncommitted write. |
| WRITE_COMMITTED              | RC/EP      | <code>bit[3:0]</code>                                                                                                | The <code>WRITE_COMMITTED</code> command performs a committed write.      |
| WRITE_ACK                    | RC/EP      | <code>bit[3:0]</code>                                                                                                | The <code>WRITE_ACK</code> command transmits a write ACK.                 |

### 6.1.9.2.2 Local PHY Rx Margining VIP Acting as PHY (SPIPE Mode)

RC (Upstream component) or EP (Downstream component) lane margin of local PHY using MBI (VIP acting as PHY).

- ❖ Configure MBI response delay (`write_ack_delay`).
- ❖ Wait for receiver MBI to indicate start of margin operation.

- ❖ Issue the service request to `INCREMENT_RX_MARGIN_SAMPLE_COUNT` and `INCREMENT_RX_MARGIN_BIT_ERROR_COUNT` whenever the testbench wants to pretend it detected a change in this internal counter. This would make the VIP generate MBI writes to status registers in MAC.

### 6.1.10 Limitations

The PCIe VIP does not support the following Gen4 features:

- ❖ Retimer specific compliance rules
- ❖ CompLoadBoard rules

## 6.2 Using SKP Ordered Sets

The SKP interval transmission and reception can be controlled in the PCIe VIP through the following attributes in the `svt_PCIE_pl_configuration` class.

The VIP will transmit a SKP OS based on these settings:

- ❖ Gen1 and Gen2
  - ◆ `min_tx_skp_interval_in_symbol_times`
  - ◆ `max_tx_skp_interval_in_symbol_times`
- ❖ Gen3
  - ◆ `min_tx_skp_interval_in_blocks`
  - ◆ `max_tx_skp_interval_in_blocks`

The VIP will check the reception of the SKP OS from the DUT based on these settings:

- ❖ Gen1 and Gen2
  - ◆ `min_rx_skp_interval_in_symbol_times`
  - ◆ `max_rx_skp_interval_in_symbol_times`
- ❖ Gen3
  - ◆ `min_rx_skp_interval_in_blocks`
  - ◆ `max_rx_skp_interval_in_blocks`

This table shows the allowed ranges and the default setting for the SKP interval attributes.

**Table 6-6 SKP Ordered Set Configuration Members**

| Type                                | Range            | Default | Description                                                                                                               |
|-------------------------------------|------------------|---------|---------------------------------------------------------------------------------------------------------------------------|
| max_tx_skp_interval_in_symbol_times |                  |         |                                                                                                                           |
| Integer                             | 32 - large value | 1538    | Maximum number of symbol times before the upper phy will schedule the insertion of a SKP ordered set (2.5GT/s and 5 GT/s) |
| min_tx_skp_interval_in_blocks       |                  |         |                                                                                                                           |
| Integer                             | 2 - large value  | 375     | Minimum number of blocks before the upper phy must schedule the insertion of a SKP ordered set (8GT/s)                    |

**Table 6-6 SKP Ordered Set Configuration Members (Continued)**

| Type                                 | Range            | Default | Description                                                                                                                      |
|--------------------------------------|------------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| max_tx_skp_interval_in_blocks        |                  |         |                                                                                                                                  |
| Integer                              | 2 - large value  | 375     | Maximum number of blocks before the upper phy must schedule the insertion of a SKP ordered set (8GT/s)                           |
| min_rx_skp_interval_in_symbol_times  |                  |         |                                                                                                                                  |
| Integer                              | 32 - large value | 1180    | Minimum number of symbol times before the upper phy flag an error due to the lack of a SKP ordered set (2.5GT/s and 5 GT/s)      |
| max_rx_skp_interval_in_symbol_times  |                  |         |                                                                                                                                  |
| Integer                              | 32 - large value | 1538    | Maximum number of symbol times before the upper phy will flag an error due to the lack of a SKP ordered set (2.5GT/s and 5 GT/s) |
| min_rx_skp_interval_in_blocks        |                  |         |                                                                                                                                  |
| Integer                              | 2 - large value  | 375     | Minimum number of blocks before the upper phy flags an error due to the lack of a SKP ordered set (8GT/s)                        |
| max_rx_skp_interval_in_blocks        |                  |         |                                                                                                                                  |
| Integer                              | 2 - large value  | 375     | Maximum number of blocks before the upper phy flags an error due to lack of a SKP ordered set (8GT/s)                            |
| min_tx_skp_symbols_in_ordered_set    |                  |         |                                                                                                                                  |
| Integer                              | 1-5              | 3       | Minimum number of SKP symbols in an ordered set at 2.5GT/s and 5GT/s.                                                            |
| max_tx_skp_symbols_in_ordered_set    |                  |         |                                                                                                                                  |
| Integer                              | 1-5              | 3       | Maximum number of SKP symbols in an ordered set at 2.5GT/s and 5GT/s.                                                            |
| min_tx_skp_symbols_in_ordered_set_8g |                  |         |                                                                                                                                  |
| Integer                              | 1-5              | 3       | Minimum number of SKP symbols in an ordered set at 8GT/s. Acceptable values: 1 - 5.                                              |
| max_tx_skp_symbols_in_ordered_set_8g |                  |         |                                                                                                                                  |
| Integer                              | 1-5              | 3       | Maximum number of SKP symbols in an ordered set at 8GT/s. Acceptable values: 1 - 5.                                              |

The min/max\_tx\_skp\_interval\_in\_<xxx> settings are randomized in the VIP to the min and max settings of the attributes. For example, the default setting for min\_tx\_skp\_interval\_in\_symbol\_times is 1180 symbol times. The default setting for max\_tx\_skp\_interval\_in\_symbol\_times is 1538 symbol times. The PCIe VIP will transmit the SKP OS based on these 2 settings. The SKP interval transmission will be randomized between the min and max values.

If the SKP OS interval needs to be set to a specific value, then set the min and max values to the same number. For example, to have the PCIe VIP transmit the SKP interval at 1275, the following setting needs to be done.

```
//Configure min/max skip interval to a set value.  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_symbol_times = 1275;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_symbol_times = 1275;
```

Similarly, for the SKP interval in blocks for gen3, you need to do the same settings.

```
//Configure min/max skip interval to a set block value.  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_blocks = 372;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_blocks = 372;
```

For the min/max\_rx\_skp\_interval\_in\_symbol\_times and min/max\_rx\_skp\_interval\_in\_blocks, the PCIe VIP will check for the reception of the SKP OS from the DUT. Again, the SKP interval will be checked based on the randomized min and max values. If the VIP is required to check the SKP interval reception for a particular value, then set the min and max values to be the value that is needed.

The PCIe VIP also allows for the number of SKP symbols to be included in the SKP OS. The default setting for both min and max is 3, so 3 SKP symbols will be sent in the SKP OS. The SKP OS can be adjusted to send a random number of SKP symbols and set to another value such as 5 by setting the min and max numbers to be different or the same number.

## 6.3 Address Translation Services

The PCIe VIP supports Address Translation Services (ATS). In particular, the model supports access to the AT field within the Memory Read and Memory Write TLPs. If the bit is set, then the provided request gets translated through the ATS protocol.

### 6.3.1 VIP Services to Map Translation inside RC VIP for ATS

The following services are present for ATS at svt\_PCIE\_mem\_target level:

- ❖ **WRITE\_ATPT:** Populate ATPT table within RC VIP instance to support enhanced ATS implementation.
- ❖ **READ\_ATPT:** Read ATPT table within RC VIP instance to support enhanced ATS implementation.
- ❖ **INVALIDATE\_ATPT:** Backdoor deletion of entry in ATPT table within RC VIP instance to support enhanced ATS implementation.

### 6.3.2 VIP Service Sequences with ATS Services

The following VIP service sequences are available with the ATS services:

- ❖ `svt_PCIE_mem_target_service_write_atpt_sequence`: This sequence implements WRITE\_ATPT service.
- ❖ `svt_PCIE_mem_target_service_read_atpt_sequence`: This sequence implements READ\_ATPT service.

### 6.3.3 Knobs to Control RC VIP ATS Operation

The RC VIP ATS operation is controlled by the following VIP configurations:

- ❖ `svt_PCIE_driver_app_configuration`
  - ◆ `enable_enhanced_address_translation`

- ◆ stu: Smallest translation unit size that is used for address translation requests
- ◆ completion\_timeout\_nsvariable used for Non-Posted requests initiated by RC
- ◆ read\_completion\_boundary\_in\_bytes
- ❖ svt\_PCIE\_target\_app\_configuration
  - ◆ stu: smallest translation unit size that is used for address translation requests
  - ◆ enable\_enhanced\_address\_translation
  - ◆ one\_transformation\_completion\_response\_wt
  - ◆ two\_transformation\_completion\_response\_wt
  - ◆ enable\_truncated\_transformation\_completion
  - ◆ page\_response\_code\_invalid\_wt
  - ◆ page\_response\_code\_unused\_wt
  - ◆ page\_response\_code\_failure\_wt
  - ◆ read\_completion\_boundary\_in\_bytes

#### 6.3.4 TL Status Class Events to Track Translation

See [Table 6-7](#) for TL status class events that are used by VIP to track translation.

**Table 6-7 TL Status Class Events**

| TL Status Class Events                  | Description                                                                    |
|-----------------------------------------|--------------------------------------------------------------------------------|
| num_tlp_msg_ats_invalidate_req_received | Indicates the number of ATS Invalidate Req message TLPs received with data.    |
| num_tlp_msg_ats_invalidate_req_sent     | Indicates the number of ATS Invalidate Req message TLPs sent with data.        |
| num_tlp_msg_ats_invalidate_cpl_received | Indicates the number of ATS Invalidate Cpl message TLPs received without data. |
| num_tlp_msg_ats_invalidate_cpl_sent     | Indicates the number of ATS Invalidate Cpl message TLPs sent without data.     |
| num_tlp_msg_ats_page_req_received       | Indicates the number of ATS Page Req message TLPs received without data.       |
| num_tlp_msg_ats_page_req_sent           | Indicates the number of ATS Page Req message TLPs sent without data.           |
| num_tlp_msg_ats_prg_response_received   | Indicates the number of ATS PRG Response message TLPs received without data.   |
| num_tlp_msg_ats_prg_response_sent       | Indicates the number of ATS PRG Response message TLPs sent without data.       |

### 6.3.5 Automatic Translated Response from VIP:

VIP also provides capability to automatically respond to address translation requests by automatically creating an address translation entry in the ATPT with an address within the boundary specified by `automatic_at_response_min_mem_range` and `automatic_at_response_max_mem_range`.

The following configurations are used to enable this capability:

- ❖ `svt_PCIE_target_app_configuration::enable_automatic_at_response`
- ❖ `svt_PCIE_target_app_configuration::automatic_at_response_min_mem_range`
- ❖ `svt_PCIE_target_app_configuration::automatic_at_response_max_mem_range`



**Note** After enabling this capability, you are not required to implement **WRITE\_ATPT** service from test/sequence.

## 6.4 PCIe VIP Bare COM Support

### 6.4.1 Background

In 2.5 GT/s or 5.0 GT/s transmission (8b10b encoding only), a normal transmitted SKP Ordered Set consists of a *COM* Symbol (K28.5) followed by three SKP Symbols (K28.0). The term *Bare COM* is used in reference to the PIPE interface during either 2.5 GT/s or 5.0 GT/s transmission where the datum being received across that interface is a *COM* symbol (K28.5 symbol) with the RxStatus equal to 2 indicating “1 SKP removed”.

In a real PCIe system, the *Bare COM* PIPE scenario will be the result of a number of repeaters or re-timers each removing “1 SKP” Ordered Set. The last one in the string of three will then result in this *Bare COM* with the remaining three SKP symbols having been removed by previous repeaters leaving only the *COM* and the “1 SKP removed” RxStatus of 2 as indicated.

### 6.4.2 Enabling VIP Bare COM transmission (to mimic the system scenario)

When the PCIe VIP's `MIN_TX_SKP_SYMBOLS_IN_ORDERED_SET_VAR` variable is set to 0 in a test for the SPIPE model (`IS_PIPE_MASTER` is 0 and `PHY_INTERFACE_TYPE` is 0), the possibility of transmitting a *Bare COM* as a SKP Ordered Set is enabled. If that PCIe VIP SPIPE model's `MAX_TX_SKP_SYMBOLS_IN_ORDERED_SET_VAR` variable is also set to 0, every SKP Ordered Set is assured to be a *Bare COM*. This is the method that guarantees *Bare COM* transmission.

The above scenario results in a *COM* with RxStatus equal to 2 being transmitted on the PIPE interface (*Bare COM*).

#### 6.4.2.1 Misconfiguration Warning Message

If the `MIN_TX_SKP_SYMBOLS_IN_ORDERED_SET_VAR` is set to 0 and either the VIP model's `IS_PIPE_MASTER` parameter is 1 (MPIPE) or the `PHY_INTERFACE_TYPE` is not 0 (SERDES or PMA models), then the VIP will issue the following warning (and, as indicated, will set the number of SKP symbols to the normal 3):

```
WARNING: endpoint0.port0.p10..: 'Bare COM' (num_skp_symbols_to_send == 0) is illegal for
'IS_PIPE_MASTER' == 1 (s/b 0) OR 'PHY_INTERFACE_TYPE = 0'(s/b 0 - PIPE) to support 'Bare
COM' SKP OS) - set 'num_skp_symbols_to_send' to 3.
```

### 6.4.3 Enabling VIP Bare COM Reception

The reception of a *Bare COM* in any PCIe VIP PIPE model release that includes the *Bare COM* support in “[Enabling VIP Bare COM transmission \(to mimic the system scenario\)](#)” needs no special setup and is available by default for 2.5 GT/s and 5.0 GT/s data rates.

#### 6.4.3.1 Ordered Set Checker Warnings

*Bare COM* reception in a PCIe MPIPE model will result in the following warning:

```
WARNING: endpoint0.port0.p10.ordered_set_checker0.: Detected undersize SKP ordered set
with 1 COM and 1 SKP symbols. Expecting 3 SKP symbols.
```

The warning indicates “1 COM and 1 SKP” (rather than the expected “0 SKP”) due to the `ordered_set_checker` interpreting the `RxStatus` equal to 2 being received with the *COM* as having removed a received SKP (“1 SKP removed” status) and therefore including that SKP Symbol as having been received (as would have been the case if a real PHY was attached to the PIPE).

To suppress the above warnings in any test that intentionally transmits *Bare COMs*, all the receiving model's `ordered_set_checker` modules requires message suppression using the `MSGCODE_PCIE SVC_ORDERED_SET_CHECKER_UNDERSIZE_SKIP` message suppression code.

## 6.5 OBFF Feature Support

### 6.5.1 Basic Attributes

VIP support for OBFF feature is disabled by default. You can enable the OBFF feature – that is, to track CPU states either using `WAKE#` signal or OBFF MSG requests using `svt_PCIE_t1_configuration::enable_obff` attribute.



The `enable_obff` attribute must be set to the same value in VIP as the DUT's `enable_obff` value. As per base PCIe specifications, OBFF messaging and `WAKE#` signal based mechanism cannot be enabled simultaneously.

When the OBFF feature is enabled, VIP indicates the current CPU state using `svt_PCIE_t1_status::cpu_state` attribute.

- ❖ When programmed as RC, VIP updates CPU state after it has transmitted OBFF message or after it has completely generated `WAKE#` signal pattern for CPU state transition.
- ❖ When programmed as EP, VIP updates CPU state after it has received OBFF message or after it has decoded complete `WAKE#` signal pattern for CPU state transition. The previous CPU state is made available via `svt_PCIE_t1_status::prev_cpu_state` attribute.

### 6.5.2 Signal Connectivity

- ❖ In an environment with single EP and single RC/Bridge, `wake_n` of VIP must be connected to `wake_n` of DUT.
- ❖ In an environment where there are multiple EP VIP instances, VIP's respective `wake_n` signal must be tied together and connected to `wake_n` signal of RC/Bridge.

- ❖ In an environment with multiple PCIE hierarchies, all the `wake_n` signals within one hierarchy should be tied together. The `wake_n` signal from one PCIE hierarchy should not be tied to `wake_n` signal from another PCIE hierarchy.



Users do not need to connect external pull up to this signal.

### 6.5.3 Generating CPU State Transition Using RCVIP

RC VIP can be directed to indicate CPU state transition to EP using `svt_PCIE_TL_Service::CHANGE_CPU_STATE` service request. Based on `svt_PCIE_TL_Configuration::enable_obff` programming, the `CHANGE_CPU_STATE` service request will either generate OBFF messages or WAKE# signal patterns.

RC VIP can be programmed to generate OBFF messages to indicate CPU state using one of the following approaches:

1. Using `svt_PCIE_Driver_App_Transaction` objects' sequence where `tlp_type` is MSG and `message_type` is OBFF.
2. Using `svt_PCIE_TLP` transaction objects' sequence where `tlp_type` is MSG and `message_type` is OBFF.
3. Using `svt_PCIE_TL_Service::CHANGE_CPU_STATE` service request with appropriate `obff_code` and programming `svt_PCIE_TL_Configuration::enable_obff = {1, 2}`.



When using this service request with OBFF message based mechanism, you must map ``SVT_PCIE_DEFAULT_APPLICATION_NUMBER_TL`` application ID to a Requester ID as per the testbench requirements. If not programmed, default Requester ID of 0 will be mapped to application ID value of ``SVT_PCIE_DEFAULT_APPLICATION_NUMBER_TL``.

RC VIP can be programmed to generate WAKE# signal patterns to indicate CPU state using the following approach:

By programming `svt_PCIE_TL_Configuration::enable_obff = 3` and using `svt_PCIE_TL_Service::CHANGE_CPU_STATE` service request. When RC VIP receives `CHANGE_CPU_STATE` service request it starts generating WAKE# signal patterns after the delay of `svt_PCIE_TL_Configuration::wake_transition_delay_in_ns` NS.

RC VIP generated WAKE# signal pattern pulse widths are user-programmable using the following attributes:

1. `svt_PCIE_TL_Configuration::wake_high_pulse_width_in_ns`: This attribute indicates pulse width of WAKE# signal from a rising edge to a falling edge in terms of ns.
2. `svt_PCIE_TL_Configuration::wake_low_pulse_width_in_ns`: This attribute indicates pulse width of WAKE# signal from a falling edge to a rising edge in terms of ns.



`svt_PCIE_TL_Configuration::wake_transition_delay_in_ns` is only applicable when VIP is acting as an Active device.

### 6.5.4 Decoding and Validating CPU State Transition Using EP VIP

EP VIP can be programmed to enable CPU state transitions' checking by setting `svt_PCIE_TL_Configuration::enable_cpu_state_transition_checking` to 1. When enabled, EP VIP can be programmed using `svt_PCIE_TL_Service::ADD_EXPECTED_CPU_STATES` service request ahead of

time to verify CPU state transitions that a RC would carry out. An EP VIP will issue an error message on a mismatch between decoded CPU state transition as indicated by RC and programmed expected CPU state. If an EP VIP encounters any additional CPU state transition than programmed expected or any lesser CPU state transitions than programmed expected value; it issues an error message.

An EP VIP uses `svt_PCIE_t1_configuration::wake_high_pulse_width_in_ns` and `svt_PCIE_t1_configuration::wake_low_pulse_width_in_ns` attributes to decode WAKE# signal patterns to interpret CPU state transitions. These attribute values in VIP should be programmed to match DUT values. When WAKE# high and low pulse widths are generated by DUT ranges in a certain time zone, EP VIP is expected to be programmed with upper range of pulse width.



`svt_PCIE_t1_configuration::wake_high_pulse_width_in_ns` and `svt_PCIE_t1_configuration::wake_low_pulse_width_in_ns` are used by VIP decode Wake# signaling pattern while acting as an Active device.

### 6.5.5 Protocol Checks

- ❖ `cpu_idle_to_low_power_check`: Applicable when `enable_obff` is non-zero. The intention of this protocol check is to validate time required by software to take link to low power state (that is, not in L0) when RC CPU goes to IDLE state. If the time taken to transition link to low power state after CPU has transitioned to IDLE state is more than user programmable `svt_PCIE_t1_configuration::cpu_idle_to_low_power_state_delay_in_ns` attribute value, then protocol check issues a violation.
- ❖ `non_idle_cpu_state_duration_check`: Applicable when `enable_obff` is non-zero. The intention of this protocol check is to validate that the amount of time CPU spends in either ACTIVE or OBFF or ACTIVE+OBFF states prior to transitioning to IDLE state is greater than user programmable `svt_PCIE_t1_configuration::min_duration_for_non_idle_cpu_state_in_ns`. If the amount of time spent in ACTIVE or OBFF or ACTIVE+OBFF combined CPU state is lesser than this attribute, then the protocol check issues a violation.
- ❖ `cpu_obff_check`: Applicable when `enable_obff` is non-zero and VIP is programmed as RC. The protocol check is not applicable when CPU state is ACTIVE or IDLE. When CPU state is OBFF, protocol check issues a violation for any request generated by EP other than memory read or write. As per the base specifications, OBFF indication is simply a hint to EP, so EP is still permitted to generate other bus mastering requests when CPU state is OBFF however that is considered to be non-optimal from platform power consumption perspective. If EP is expected to generate requests other than memory reads or writes while in OBFF CPU state by design, this protocol check should be disabled.



Protocol checks are applicable in active mode of VIP.

### 6.5.6 Known Limitations

1. OBFF feature is supported by SVT VIP only.
2. OBFF feature is supported in UVM mode only.
3. OBFF feature is supported only when using unified interface.
4. VIP does not support variation A mechanism using OBFF messages.

If user queues OBFF messages in low power states in Variation A, VIP will not discard them automatically.

## 6.6 Replay Timer

The replay timeout calculation as per the PCIe specification is as follows:

- ❖ For specification version prior to 4.0, the replay timeout value is based on a formula listed in the 3.1 specification.
- ❖ For specification version 4.0 and higher, the replay timeout value can be set to 1 of 2 values based on the extended sync bit value.

The specification provides an option to support the Gen3 replay timeout calculation when supporting Gen4 features. This option can only be used if speeds greater than 8G are not supported.

### 6.6.1 Configuration

The VIP will automatically select the replay timeout method based on the `pcie_spec_ver` variable and extended sync bit (when applicable).



There is no change for the tests with `replay_timeout` settings in DL configuration.

Replay timeout settings for Gen3 and Gen4 are as follows:

- ❖ For Gen3, only `replay_timeout` variable is used.
- ❖ For Gen4, you can use the following variables:
  - † `replay_timeout`: The `replay_timeout` variable sets timeout when the extended sync bit is 0. The default value of this variable is set to 31k.
  - † `replay_extended_sync_timeout`: The `replay_extended_sync_timeout` variable provides control over the timeout value when the extended sync bit is 1. This variable is only applicable to specification version 4.0 or higher. The default value of this variable is set to 100k.

Per the specification, the valid ranges are 24k–31k and 80k–100k (extended sync). Default is set to the largest suggested value such that no tuning is required.

The VIP provides checkers to verify the DUT's implementation of the replay timeout. Configuration of the checker variables is required only if the DUT's implementation deviates from the specification values. All configuration variables associated with the replay timeout checker have `attached_` prepended to the names. The checkers are configured as per the specification similar to the replay timeout. Based on the DUT's internal delays, you may configure the dependent variables.

**Table 6-8 Replay Timer Variables**

| Variable                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| replay_timeout                                  | <p>Specifies the timeout count value for the replay timer in symbols.</p> <ul style="list-style-type: none"> <li>For <code>pcie_spec_ver &lt; 4.0</code>, setting this variable to 0 enables automatic timeout updates if <code>#max_payload_size</code>, <code>link_width</code>, or speed change.</li> <li>For <code>pcie_spec_ver &gt;= 4.0</code>, this variable sets the simplified replay timeout of the VIP if the extended sync bit is not set.</li> </ul> <p>If randomized, the variable will resolve to a value within the range specified by the constraint <code>#valid_ranges</code>.</p> <p>Note: Utilized by the active component only.</p> |
| replay_extended_sync_timeout                    | <p>Specifies the timeout count value for the replay timer in symbols when the extended sync bit is set. Only applicable for specification version 4.0 and using a simplified replay timer.</p> <p>If randomized, the variable will resolve to a value within the range specified by the constraint <code>#valid_ranges</code>.</p> <p>Note: Utilized by the active component only.</p>                                                                                                                                                                                                                                                                     |
| enable_gen3_replay_timeout_calc_in_gen4         | <p>Specifies how the replay timeout value in VIP is derived when supporting PCIe specification version 4.0 (Gen4).</p> <ul style="list-style-type: none"> <li>If 16G speed is supported, the simplified retimer approach must be used.</li> <li>If 16G speed is not supported at Gen4, the replay timeout value can optionally be derived per PCIe specification 3.1 (Gen3).           <ul style="list-style-type: none"> <li>- 0: Will enable a simplified replay timer.</li> <li>- 1: Will enable automatic update of timer per Gen3 specification.</li> </ul> </li> </ul> <p>Note: Utilized by the active component only.</p>                           |
| attached_replay_timeout                         | <p>Specifies the length of the attached replay timeout in symbols. Used to check the replay timer of DUT/link partner.</p> <ul style="list-style-type: none"> <li>For <code>pcie_spec_ver &lt; 4.0</code>, setting this variable to 0 enables automatic updates if <code>#max_payload_size</code>, <code>link_width</code>, or speed change.</li> <li>For <code>pcie_spec_ver &gt;= 4.0</code>, this variable sets the simplified replay timeout of the DUT if extended sync bit is NOT set.</li> </ul> <p>* The value has to be within the range specified by the constraint <code>#valid_ranges</code>.</p>                                              |
| attached_replay_extended_sync_timeout           | <p>Specifies the length of the attached replay timer in symbols when extended sync bit is enabled. Used to check the DUT's replay timer. This value is used only for <code>pcie_spec_ver &gt;= 4.0</code> and using a simplified replay timer.</p> <p>The value has to be within the range specified by the constraint <code>#valid_ranges</code>.</p> <p>Note: Utilized by the active component only.</p>                                                                                                                                                                                                                                                 |
| enable_replay_timer_adjust_extended_sync_change | <p>Specifies whether the replay timer is reset when extended sync bit is changed when replay timer is running. Per the specification, resetting the replay timer is optional. As this is enabled by default, replay timeouts will not occur.</p> <p>This variable is applicable to <code>pcie_spec_ver &gt;= 4.0</code>. For <code>pcie_spec_ver &lt; 4.0</code>, this variable is ignored.</p> <p>Note: Utilized by the active component only.</p>                                                                                                                                                                                                        |

## 6.7 SRIS/SRNS

### 6.7.1 Introduction

The specification supports two kinds of clocking where the Tx and Rx Refclk rates differ. One clock allows at least 600 ppm difference with no SSC (Separate Reference Clocks With No SSC - SRNS) and the other clock allows 5600 ppm difference for separate Refclks utilizing independent SSC (Separate Reference Clocks with Independent SSC - SRIS) (SSC introduces a 5000 ppm difference and Tx/Rx crystal tolerance introduces another 600 ppm).

### 6.7.2 Basic Attributes

VIP support for SRIS/SRNS is disabled by default. You can enable this feature – that is to introduce ppm in serial bit clock on the transmit path using `svt_PCIE_Pl_Configuration::ssc_mode`, `svt_PCIE_Pl_Configuration::ssc_max_spread`, `svt_PCIE_Pl_Configuration::ssc_modulation_rate` and `svt_PCIE_Pl_Configuration::fixed_ppm_due_to_tx_rx_xo` attributes.

- ❖ `svt_PCIE_Pl_Configuration::ssc_mode`: This attribute specifies the spread spectrum clocking (SSC) mode for serial bit clock on the transmit path. VIP allows two profiles to introduce spread spectrum – Down spread and Center spread.
- ❖ `svt_PCIE_Pl_Configuration::ssc_max_spread`: This attribute specifies the SSC spread value in ppm (parts per million) for the rates that PCIe supports.
- ❖ `svt_PCIE_Pl_Configuration::ssc_modulation_rate`: This attribute specifies the modulation rate for SSC clock. By default, it is set to 33 kHz.
- ❖ `svt_PCIE_Pl_Configuration::fixed_ppm_due_to_tx_rx_xo`: This attribute specifies the fixed ppm value in tx serial bit clk which comes due to different tx/rx crystal oscillator.

All these attributes are only applicable for VIP running with serial interface. For more details about the usage, see “`svt_PCIE_Pl_Configuration`” in the HTML class reference documentation.



**Note** At higher speeds, you need to be aware of the inherent maximum of 1fs precision in SystemVerilog. For example, at 16G, trying to run with a 600ppm difference would result in the default bit period 0.0675ns being adjusted by 0.0000375ns or 37.5fs. To generate a clock with this period requires an attosecond resolution, which SystemVerilog does not support. It is therefore recommended to round the ppm either up or down to the nearest 1fs so that there will be no rounding errors in the clock period and adjust SKP intervals accordingly.

### 6.7.3 Enabling the SRNS Mode

Set the following configurations:

- ❖ `svt_PCIE_Pl_Configuration::ssc_mode` for all rates should be configured with `svt_PCIE_Pl_Configuration::SSC_MODE_DISABLED` (default).
- ❖ `svt_PCIE_Pl_Configuration::fixed_ppm_due_to_tx_rx_xo` has to be configured with a ppm value within the range of -300 to +300ppm.

Example code where +300ppm constant ppm value is introduced in transmit serial bit clock:

```
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[0] = svt_PCIE_Pl_Configuration::SSC_MODE_DISABLED;
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[1] = svt_PCIE_Pl_Configuration::SSC_MODE_DISABLED;
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[2] = svt_PCIE_Pl_Configuration::SSC_MODE_DISABLED;
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[3] = svt_PCIE_Pl_Configuration::SSC_MODE_DISABLED;
```

```
cfg.rc_cfg.pcie_cfg.pl_cfg.fixed_ppm_due_to_tx_rx_xo = 300;
```

For SRNS, there is no change in SKP OS scheduling interval. The SKP Ordered Set must be scheduled for transmission at an interval between 1180 and 1538 symbol times if the device is running in Gen1 or Gen2 rate. For higher rates, SKP Ordered Set must be scheduled for transmission at an interval between 370 to 375 blocks.

#### 6.7.4 Enabling the SRIS Mode

Set the following configurations:

- ❖ VIP provides mechanism to introduce SSC in a particular line rate.
- ❖ `svt_PCIE_Pl_Configuration::SSC_Mode` should be configured with `svt_PCIE_Pl_Configuration::SSC_MODE_DOWN_SPREAD` or `svt_PCIE_Pl_Configuration::SSC_MODE_CENTER_SPREAD` for the desired rate.
- ❖ `svt_PCIE_Pl_Configuration::SSC_Max_Spread` should be configured with the SSC spread value in terms of ppm for the desired rate. Specification allows a maximum of 5000 ppm difference.
- ❖ `svt_PCIE_Pl_Configuration::SSC_Modulation_Rate` can be used to specify the modulation rate of SSC clock. Allowed range is 30 kHz to 33 kHz.
- ❖ `svt_PCIE_Pl_Configuration::fixed_ppm_due_to_tx_rx_xo` has to be configured with a ppm value within the range of -300 to +300 ppm.

When SRIS mode is enabled by the device, specification constraints the SKP OS scheduling interval with respect to rate. The SKP Ordered Set must be scheduled for transmission at an interval of less than 154 Symbol Times for Gen1 and Gen2 rates. For higher rates, a SKP Ordered Set must be scheduled for transmission at an interval less than 38 Blocks, when the LTSSM is not in the Loopback state or is a Loopback Slave that has not started looping back the incoming bit stream.

Above configurations can be done by using the following `svt_PCIE_Pl_Configuration` attributes:

- ❖ `min_tx_skp_interval_in_symbol_times`
- ❖ `max_tx_skp_interval_in_symbol_times`
- ❖ `min_tx_skp_interval_in_blocks`
- ❖ `max_tx_skp_interval_in_blocks`

In L0 LTSSM state, specification also allows SKP OS generation at the rate used in SRNS mode even though port is running in SRIS.

This is applicable when the following conditions are true.

- ❖ Bit is set for the appropriate data rate in the Lower SKP OS Reception Supported Speeds Vector field of the Link Capabilities 2 register of the receiver.
- ❖ Bit is set for the appropriate data rate in the Lower SKP OS Generation Supported Speeds Vector field of the Link Capabilities 2 register of the transmitter.

If both conditions are true, then the above mentioned SKP interval configurations can be reconfigured during L0 LTSSM state as per SKP generation at the rate used in SRNS.

Following is the example code where VIP is configured to introduce down spread SSC in transmit bit clock for all supported rates.

```
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[0] =
    svt_PCIE_Pl_Configuration::SSC_MODE_DOWN_SPREAD;
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[1] =
    svt_PCIE_Pl_Configuration::SSC_MODE_DOWN_SPREAD;
```

```
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[2] =  
    svt_PCIE_pl_configuration::SSC_MODE_DOWN_SPREAD;  
cfg.rc_cfg.pcie_cfg.pl_cfg.ssc_mode[3] =  
    svt_PCIE_pl_configuration::SSC_MODE_DOWN_SPREAD;  
cfg.rc_cfg.pcie_cfg.pl_cfg.fixed_ppm_due_to_tx_rx_xo = 300;  
  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_symbol_times = 153;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_symbol_times = 153;  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_blocks = 37;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_blocks = 37;
```

If lower SKP OS generation is supported and allowed during SRIS mode, above SKP interval configurations must be reconfigured with the following values in L0 LTSSM state.

```
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_symbol_times = 1180;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_symbol_times = 1538;  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_tx_skp_interval_in_blocks = 370;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_tx_skp_interval_in_blocks = 375;
```

### 6.7.5 Configuring the VIP Receiver for SRIS/SRNS Mode

The VIP receiver supports both SRIS and SRNS mode. When VIP receiver is running with SRIS mode and expected to receive SKP OS in the interval specified as per SRIS specification, then the following `svt_PCIE_pl_configuration` attributes must be configured with proper values as shown below. Otherwise, VIP will trigger `phy_too_many_skp_sets` check.

```
cfg.rc_cfg.pcie_cfg.pl_cfg.min_rx_skp_interval_in_symbol_times = 1;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_rx_skp_interval_in_symbol_times = 153;  
cfg.rc_cfg.pcie_cfg.pl_cfg.min_rx_skp_interval_in_blocks = 1;  
cfg.rc_cfg.pcie_cfg.pl_cfg.max_rx_skp_interval_in_blocks = 37;
```



# 7 Gen5 Features

This chapter describes the Gen5 features available with the Synopsys PCIe Verification IP.

This chapter discusses the following topics:

- ❖ [Version Support](#)
- ❖ [Supported Interfaces](#)
- ❖ [VIP License Requirements](#)
- ❖ [Supported Features](#)
- ❖ [Enabling Gen5 Support](#)
- ❖ [Gen5 Support for PIPE Interface](#)
- ❖ [Gen5 Symbol Logging](#)

## 7.1 Version Support

The Synopsys PCIe SVT VIP supports the following specification versions:

| Protocol Specification | Version                                                                                 |
|------------------------|-----------------------------------------------------------------------------------------|
| PCI Express Base Spec  | PCIe Gen 5.0 Revision 1.0                                                               |
| PIPE Interface Spec    | <ul style="list-style-type: none"><li>• PIPE 5.1.1</li><li>• PIPE 4.4 / 4.4.1</li></ul> |

## 7.2 Supported Interfaces

Currently, the Gen5 support is available only for serial and PIPE interface using the PCIe SVT Unified model.



- Gen5 support for legacy instantiation models will not be supported.
- For PIPE Interface, this feature is currently available only when PCIe SVT VIP is used in active mode only.
  - PIPE 5.1.1 LPC, [PIPE5 Features](#).
  - For PIPE 5.1.1, SerDes architecture is available as EA. For more details, contact Synopsys Support.

## 7.3 VIP License Requirements

To enable Gen5 features, use the Gen5 license key `VIP-PCIE-G5-SVT` or `VIP-LIBRARY2019-SVT`. The Gen5 license is standalone and inclusive of all other PCIe SVT VIP features. For more details, see [Licensing Information](#).

## 7.4 Supported Features

The following features are implemented for Gen5:

- ❖ To advertise support and run at 32 GT/s
- ❖ Enhanced Link Control Behavior.
  - ◆ Equalization controls at 32GT/s.
  - ◆ Modified TS1/TS2 OS
- ❖ Precoding
- ❖ Equalization via Loopback
- ❖ Multi lane BERT Testing

## 7.5 Enabling Gen5 Support

Setting up the VIP to run at Gen5 is similar to the steps followed with other versions. Following are the additional steps required:

1. Add the `\define SVT_PCIE_ENABLE_GEN5` define to your environment to compile Gen5 features.
2. Configure the VIP to support the PCIe 5 specification in the device configuration.
 

```
vip_cfg.pcie_spec_ver = svt_pcie_device_configuration::PCIE_SPEC_VER_5_0;
```
3. In case of PIPE interface configuration, the VIP with PIPE specification setting in the device configuration is as follows:
  - ◆ PIPE Spec version 5.1.1:
 

```
vip_cfg.pipe_spec_ver = svt_pcie_device_configuration::PIPE_SPEC_VER_5_1;
```
  - ◆ PIPE Spec version 4.4
 

```
vip_cfg.pipe_spec_ver = svt_pcie_device_configuration::PIPE_SPEC_VER_4_4;
```
4. Set the supported speeds to include 32GT/s in the PL configuration.
 

```
vip_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_32_0G | `SVT_PCIE_SPEED_16_0G | `SVT_PCIE_SPEED_8_0G | `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G, `SVT_PCIE_SPEED_32_0G, `SVT_PCIE_SPEED_32_0G)
```

## 7.6 Gen5 Configuration Settings

### 7.6.1 32G Equalization

The new 32G Equalization items mirror the existing ones that are used at 8G and 16G. For more details, see HTML class reference documentation:

[`\$DESIGNWARE\_HOME/vip/svt/pcie\_svt/latest/doc/pcie\_svt\_uvm\_class\_reference/html/configuration/class\_svt\_PCIE\_pl\_configuration.html#group\_gen5\_params`](#)

The VIP attributes specific for Gen5 are post-fixed with \_32g.

In the HTML class reference documentation, you can search for \_32g in the "search" tab to get the list of attributes.

**Table 7-1 32G Equalization Configuration Settings**

| Parameter                                                             | Description                                                                                                                                                                                                            |
|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>fs_value_32g</code>                                             | The FS value that the VIP advertises during phase 1 EQ at 32G.                                                                                                                                                         |
| <code>fs_value_32g</code>                                             | The FS value that the VIP advertises during phase 1 EQ at 32G.                                                                                                                                                         |
| <code>expected_lf_value_32g</code>                                    | The LF value that the VIP expects the DUT to advertise at 32G during phase 1 EQ.                                                                                                                                       |
| <code>expected_fs_value_32g</code>                                    | The LF value that the VIP expects the DUT to advertise at 32G during phase 1 EQ.                                                                                                                                       |
| <code>preset_to_coefficients_mapping_table_32g</code>                 | This sets up what coefficients the VIP will use when asked for a specific preset during phase2/3 equalization.                                                                                                         |
| <code>preset_to_coefficients_mapping_entry_valid_32g</code>           | Indicates that a given preset is considered valid by the VIP during equalization at 32G. If a preset entry is invalid, the VIP will automatically reject any received request for that preset during phase2/phase3 EQ. |
| <code>expected_preset_to_coefficients_mapping_table_32g</code>        | The table which sets the DUT's preset to coefficient mapping at 32G.                                                                                                                                                   |
| <code>expected_preset_to_coefficients_mapping_entry_enable_32g</code> | Sets which presets are valid and supported by the DUT at 32G.                                                                                                                                                          |
| <code>upstream_receiver_preset_hint_32g</code>                        | Depending on whether the VIP is configured at a RC or EP, this sets the preset hint to either be advertised or expected in received EQTS2 that are received before Phase 0 EQ at 32G.                                  |
| <code>downstream_receiver_preset_hint_32g</code>                      | Downstream hint transmitted in EQTS1s during phase 1 EQE at 32G.                                                                                                                                                       |
| <code>downstream_receiver_preset</code>                               | Sets the default downstream preset when entering EQ at 32G.                                                                                                                                                            |

**Table 7-1 32G Equalization Configuration Settings**

| Parameter                                            | Description                                                                                                                                                     |
|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| upstream_receiver_preset                             | Sets the preset the upstream port should be using when entering EQ at 32G.                                                                                      |
| upstream_advertise_32g_support_before_16g_eq         | Controls whether or not the upstream port advertised 32G before 16G equalization has completed. Downstream must follow the rules outlined in the specification. |
| enable_upstream_tx_16g_eqts2_with_preset_in_rcvr_cfg | Optionally allow the upstream port to communicate presets to the downstream port before EQ begins.                                                              |

## 7.6.2 Configuring Coefficient and Preset Requests

Coefficient requests and preset requests are handled at 32G the same way they are handled in 8G and 16G – by using the QUEUE\_EQ\_TX\_REQUEST\_PRESET\_COEFF service call.

### Service Call Sequence

```
task svt_PCIE_PL_Service_queue_EQ_tx_request_preset_coeff::body();
begin
    svt_PCIE_PL_Service_queue_EQ_tx_request_preset_coeff_req;
    `svt_verbose("body", "Physical Layer, Queue Equalization Preset/Coefficient Request started");
    `svt_xvm_do_with(queue_EQ_tx_request_preset_coeff_req,{service_type == svt_PCIE_PL_Service::QUEUE_EQ_TX_REQUEST_PRESET_COEFF;
        eq_lane_num == local::eq_lane_num;
        preset_valid == local::preset_valid;
        preset_value == local::preset_value;
        precursor_coeff == local::precursor_coeff;
        cursor_coeff == local::cursor_coeff;
        postcursor_coeff == local::postcursor_coeff;
        expect_reject == local::expect_reject});
    `svt_verbose("body", "Physical Layer, Queue Equalization Preset/Coefficient Request ended");
end
endtask : body
```

### Example 7-1 Sequence Usage

```
//Preset requests
for (int lane = 0; lane < vip_cfg.pcie_cfg.pl_cfg.get_expected_link_width_value(); lane++)
begin
    `svt_xvm_do_on_with(preset_coeff_exception_sequence, dut_seqr.pcie_virt_seqr.pl_seqr, {
        eq_lane_num == lane;
        preset_valid == 1'b1;
        preset_value == 4'h2;
        expect_reject == 0;
    })
end
```

### 7.6.3 Enhanced Link Behavior Control - TS1/2 Symbol 5 (Optional)

| Control                                          | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Full Equalization required (00b)                 | <p><code>cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_FULL_EQUALIZATION_REQUIRED);</code></p> <p><b>Note:</b> <code>set_link_eq_attribute_values(LINK_EQ_MODE_FULL_EQUALIZATION_REQUIRED)</code> Internally sets PI configuration attributes:</p> <pre>equalization_bypass_to_highest_rate_support_disable = 1; no_equalization_needed_support_disable = 1;</pre> |
| Equalization bypass to highest rate support(01b) | <p><code>cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_EQ_BYPASS_TO_HIGHEST_RATE);</code></p> <p><b>Note:</b> <code>set_link_eq_attribute_values(LINK_EQ_MODE_EQ_BYPASS_TO_HIGHEST_RATE)</code> Internally sets PI configuration attributes:</p> <pre>equalization_bypass_to_highest_rate_support_disable = 0; no_equalization_needed_support_disable = 1;</pre>   |
| No Equalization needed(10b)                      | <p><code>cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_eq_attribute_values(LINK_EQ_MODE_NO_EQUALIZATION_NEEDED);</code></p> <p><b>Note:</b> <code>set_link_eq_attribute_values(LINK_EQ_MODE_NO_EQUALIZATION_NEEDED)</code> Internally sets PI configuration attributes:</p> <pre>equalization_bypass_to_highest_rate_support_disable = 0; no_equalization_needed_support_disable = 0;</pre>         |
| Modified TS1/TS2 Ordered Sets supported(11b)     | <code>cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_modified_ts_mode_values ( 1 /*advertise_support_for_modified_ts */ );</code>                                                                                                                                                                                                                                                                         |

### 7.6.4 Skew Support for 32G

| Parameter                         | Description                                                                                                                 |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| <code>min_tx_lane_skew_32g</code> | When the lane skew mode is set to random, specifies the minimum lane skew between transmit lanes in symbol times at 32Gt/s. |
| <code>max_tx_lane_skew_32g</code> | When the lane skew mode is set to random, specifies the maximum lane skew between transmit lanes in symbol times at 32Gt/s. |

### 7.6.5 nFTS at 32G

| Parameter                            | Description                                                                                                                         |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <code>num_rx_fts_required_32g</code> | Specifies the minimum number of FTS ordered sets required for a receiver to infer lock when exiting from electrical idle at 32GT/s. |

### 7.6.6 Retimer Latency on RX Data Path

| Parameter                 | Description                                                                      |
|---------------------------|----------------------------------------------------------------------------------|
| rx_retimer_latency_32g_ns | Programmable latency used to mimic the presence of a Retimer on the rx data path |

### 7.6.7 Precoding

| Parameter                        | Description                                                                        |
|----------------------------------|------------------------------------------------------------------------------------|
| transmitter_preamble_request_32g | When set to a 'b1, the VIP will request that the far-end transmitter use precoding |

### 7.6.8 32G Loopback Controls

Service Call: Loopback is initiated using a service call `svt_PCIE_pl_service_initiate_loopback`.

To control Gen5-specific features, use the following fields:

| Parameter                                       | Description                                                                                                                                   |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| enable_loopback_w_equalization                  | Enables VIP to perform equalization to the lane under test before entering loopback.                                                          |
| loopback_lane_under_test                        | Defines the lane under test when loopback with equalization is being performed.                                                               |
| set_ts_transmit_modified_compliance_in_loopback | When set, the loopback master will set the <code>transmit_modified_compliance_in_loopback</code> bit in outgoing TS when requesting loopback. |

## 7.7 EIEOSQ Controls

This feature is used for block alignment state machine testing.

| Parameter                  | Description                                                          |
|----------------------------|----------------------------------------------------------------------|
| num_tx_eieos_in_eieosq_32g | Number of EIEOS ordered sets in an EIEOSQ a transmitter should send. |
| num_rx_eieos_in_eieosq_32g | Number of EIEOS ordered sets a receiver should expect in an EIEOSQ.  |

## 7.8 Gen5 Support for PIPE Interface

The PCIe SVT VIP supports Gen5 speed over PIPE when it is compatible with *PCIe Base Specification Revision 5.0* and *PIPE Specifications Revision 4.4/4.4.1*. This feature is currently available only when PCIe SVT VIP is used in active mode and only when using the Unified instantiation module.

### 7.8.1 Enabling Gen5 Support

To enable Gen5 support, set the following configurations:

- ❖ Set the Gen5 license key. For more details, see [Licensing Information](#).

- ❖ Define the `SVT_PCIE_ENABLE_GEN5` macro in the makefile.
- ❖ Set the PCIe specification version `PCIE_SPEC_VER_5_0`.
- ❖ Set the PIPE specification version `PIPE_SPEC_VER_4_4`.
- ❖ Set the `svt_PCIE_pl_configuration::enable_gen5_using_pipe_4_4` attribute to 1.



**Note** No changes in callbacks and analysis ports.

## 7.8.2 Protocol Checks and Exceptions

All 128/130b checks at 8G and 16G will be applicable for 32G. All 8G and 16G equalization checks will be applicable for 32G.

For the detailed list of checks, see HTML class reference documentation.

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/protocolChecks.html`

### Example 7-2 Searching “PCIE v5.0” in the Browser

| SELECT ALL | SELECT ALL          | Protocol Check Instance name                                     | Reference                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|---------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Group      | Sub Group           |                                                                  |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ACTIVE_PL  | TS_OS               | <a href="#">phy_received_modified_ts_when_not_negotiated</a>     | <a href="#">PCIE v5.0: 4.2.6.3.2 Configuration.Linkwidth.Accept</a>             | The variable <code>use_modified_TS1_TS2_Ordered_Set</code> must be set to 1b if all of the following conditions are true:LinkUp = 0b, The component had transmitted Modified TS1/TS2 Ordered Sets supported value 11b in the Enhanced Link Behavior Control field in Symbol 5 of TS1 and TS2 Ordered Sets in Polling and Configuration states since entering the Polling State. The received eight consecutive TS2 Ordered Sets on all Lanes of the currently configured Link that caused the transition from Polling.Configuration to Configuration state had the Modified TS1/TS2 Ordered Sets supported value 11b in the Enhanced Link Behavior Control field in Symbol 5 and 32.0 GT/s data rate is supported bit is set to 1b in the received eight consecutive TS2 Ordered Sets. |
| ACTIVE_PL  | CONFIGURATION_LTSSM | <a href="#">phy_supported_linkwidth_exceeds_configured_width</a> | <a href="#">PCIE v5.0: 4.2.6.3 Configuration</a>                                | Supported linkwidth exceeds configured linkwidth                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ACTIVE_PL  | FRAMING             | <a href="#">phy_stp_not_aligned_to_lane0_after_idl_on_rx</a>     | <a href="#">PCIE v5.0: 4.2.1.2 Framing and Application of Symbols to Lanes</a>  | Physical Layer received STP token not aligned to Lane0 after receiving IDL on Rx path                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ACTIVE_PL  | FRAMING             | <a href="#">phy_received_multiple_stp_at_same_symbol_time</a>    | <a href="#">PCIE v5.0: 4.2.1.2 Framing and Application of Symbols to Lanes</a>  | Physical Layer detected multiple STP tokens at the same symbol time on Rx path                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ACTIVE_PL  | VIP_INTERNAL        | <a href="#">phy_vip_internal_tx_fifo_overflow</a>                | <a href="#">PCIE v5.0: 4 Physical Layer Logical Block: VIP internal message</a> | VIP specific message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 7.8.3 Gen5 Example

For details on Gen5 example, see [Testbench Structure](#) and for usage details, contact Synopsys Support

## 7.9 Gen5 Symbol Logging

When the VIP is enabled to run at Gen5 and symbol logging is enabled, by default the Symbol Logger will display the following set of Gen5-specific data points for Gen5 debug analysis.

### 7.9.1 Precoding Display

- ❖ A marker when speed changes to 32.0 GT/s indicating the transmitter Precoding status of DUT(RX) and VIP(TX).

**Example**

The following example illustrates the scenario where VIP's link partner (on LHS) requested VIP to turn ON precoding but VIP (on RHS) did not make the same request.

```

33803: spd_1      *2d *2d *2d *2d | 00 00 00 00 -> Recov.Rcvrcfg >RX:EQ_TS2_OS on Lane0
33803: spd_1      00 00 00 00 | 00 00 00 00 -> Recov.Rcvrcfg
33804: spd_1      00 01 02 03 | 98 98 98 98 -> Recov.Rcvrcfg
33804: spd_1      ff ff ff ff | 45 45 45 45 -> Recov.Rcvrcfg
33805: spd_1      be be be | 45 45 45 45 -> Recov.Rcvrcfg
33805: spd_1      00 00 00 00 | 45 45 45 45 -> Recov.Rcvrcfg
33806: spd_1      00 00 00 00 | 45 45 45 45 -> Recov.Rcvrcfg
33806: spd_1      10 81 81 81 | 45 45 45 45 -> Recov.Rcvrcfg
33807: spd_1      45 45 45 45 | 45 45 45 45 -> Recov.Rcvrcfg
33807: spd_1      45 45 45 45 | 20 45 45 45 -> Recov.Rcvrcfg
33808: spd_1      45 45 45 45 | 08 45 45 f7 -> Recov.Rcvrcfg >TX:EQ_TS2_OS on Lane0-3
33808: spd_1      45 45 45 45 | *2d *2d *2d *2d -> Recov.Rcvrcfg
33809: spd_1      45 45 45 45 | 00 00 00 00 -> Recov.Rcvrcfg
33809: spd_1      45 45 45 45 | 00 01 02 03 -> Recov.Rcvrcfg
33810: spd_1      45 45 45 45 | ff ff ff ff -> Recov.Rcvrcfg
33810: spd_1      08 45 45 f7 | fe fe fe fe -> Recov.Rcvrcfg >RX:EQ_TS2_OS on Lane1-3
.
.
.
spd_1      -- Detected change in data rate to 32 GT/s. TX Precoding: On, RX Precoding: Off. See file header for special encodings.

```

**7.9.2 ELBC Display**

- ❖ Mutually supported ELBC when entering Config.Idle.

**Example**

The following example illustrates the scenario where VIP's link partner (on LHS) advertised "Full Equalization required" and VIP (on RHS) advertised "No Equalization needed" and the mutually supported EQ option is resolved to Full EQ Required.

```

21504: spd_1      COM COM COM COM | 45 45 45 45 -> Cfg.Complete
21508: spd_1      00 00 00 00 | 45 45 45 45 -> Cfg.Complete
21512: spd_1      00 01 02 03 | 45 45 45 45 -> Cfg.Complete
21516: spd_1      ff ff ff ff | 45 45 45 45 -> Cfg.Complete
21520: spd_1      7e 7e 7e 7e | 45 45 45 45 -> Cfg.Complete
21524: spd_1      00 00 00 00 | 45 45 45 45 -> Cfg.Complete >TX:TS2_OS on Lane0-3
21528: spd_1      45 45 45 45 | COM COM COM COM -> Cfg.Complete
21532: spd_1      45 45 45 45 | 00 00 00 00 -> Cfg.Complete
21536: spd_1      45 45 45 45 | 00 01 02 03 -> Cfg.Complete
21540: spd_1      45 45 45 45 | ff ff ff ff -> Cfg.Complete
21544: spd_1      45 45 45 45 | 7e 7e 7e 7e -> Cfg.Complete
21548: spd_1      45 45 45 45 | 80 80 80 80 -> Cfg.Complete
21552: spd_1      45 45 45 45 | 45 45 45 45 -> Cfg.Complete
21556: spd_1      45 45 45 45 | 45 45 45 45 -> Cfg.Complete
21560: spd_1      45 45 45 45 | 45 45 45 45 ---> Cfg.Idle: Mutually Supported EQ Option: Full EQ Required,
Transition Reason: LTSSM_TRANSITION_STANDARD

```

### 7.9.3 EQ Via Loopback Display

#### Example

The following example illustrates the scenario where VIP is Loopback master and has chosen lane 3 to be 'Lane Under Test' and slave is not required to send Modified Compliance on lanes that are not under test.

```
19511: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a --> Loopback.Entry: lane_under_test = 3,  
transmit_modified_compliance_pattern_in_loopback = 0, Transition Reason: LTSSM_TRANSITION_DIRECTED  
19515: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry  
19519: spd_0          COM COM COM COM | 4a 4a 4a 4a -> Loopback.Entry  
19523: spd_0          PAD PAD PAD PAD | 4a 4a 4a 4a -> Loopback.Entry  
19527: spd_0          PAD PAD PAD PAD | 4a 4a 4a 4a -> Loopback.Entry  
19531: spd_0          ff ff ff ff | 4a 4a 4a 4a -> Loopback.Entry  
19535: spd_0          3e 3e 3e 3e | 4a 4a 4a 4a -> Loopback.Entry  
19539: spd_0          80 80 80 80 | 4a 4a 4a 4a -> Loopback.Entry  
19543: spd_0          4a 4a 4a 4a | COM COM COM COM -> Loopback.Entry  
19547: spd_0          4a 4a 4a 4a | PAD PAD PAD PAD -> Loopback.Entry  
19551: spd_0          4a 4a 4a 4a | PAD PAD PAD PAD -> Loopback.Entry  
19555: spd_0          4a 4a 4a 4a | ff ff ff ff -> Loopback.Entry  
19559: spd_0          4a 4a 4a 4a | 3e 3e 3e 3e -> Loopback.Entry  
19563: spd_0          4a 4a 4a 4a | 00 00 00 44 -> Loopback.Entry  
19567: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry  
19571: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry  
19575: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry  
19579: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry  
19583: spd_0          COM COM COM COM | 4a 4a 4a 4a -> Loopback.Entry  
19587: spd_0          PAD PAD PAD PAD | 4a 4a 4a 4a -> Loopback.Entry  
19591: spd_0          PAD PAD PAD PAD | 4a 4a 4a 4a -> Loopback.Entry  
19595: spd_0          ff ff ff ff | 4a 4a 4a 4a -> Loopback.Entry  
19599: spd_0          3e 3e 3e 3e | 4a 4a 4a 4a -> Loopback.Entry  
19603: spd_0          80 80 80 80 | 4a 4a 4a 4a -> Loopback.Entry  
19607: spd_0          4a 4a 4a 4a | COM COM COM COM -> Loopback.Entry  
19611: spd_0          4a 4a 4a 4a | PAD PAD PAD PAD -> Loopback.Entry  
19615: spd_0          4a 4a 4a 4a | PAD PAD PAD PAD -> Loopback.Entry  
19619: spd_0          4a 4a 4a 4a | ff ff ff ff -> Loopback.Entry  
19623: spd_0          4a 4a 4a 4a | 3e 3e 3e 3e -> Loopback.Entry  
19627: spd_0          4a 4a 4a 4a | 00 00 00 44 -> Loopback.Entry  
19631: spd_0          4a 4a 4a 4a | 4a 4a 4a 4a -> Loopback.Entry
```

Lane#3 is  
under test, bit  
5 is 0

### 7.9.4 use\_modified\_TS1\_TS2\_Ordered\_Set Variable Display

- ❖ Point at which use\_modified\_TS1\_TS2\_Ordered\_Set variable gets set. Modified TS will be sent and received beyond this point.

**Example**

The following example illustrates the scenario where both devices support Modified TS.

```

17918: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17922: spd_1      COM COM COM COM | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17926: spd_1      00  00  00  00 | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17930: spd_1      PAD PAD PAD PAD | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17934: spd_1      ff  ff  ff  ff | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17938: spd_1      3e  3e  3e  3e | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17942: spd_1      c0  c0  c0  c0 | COM COM COM COM -> Cfg.Linkwidth.Accept
17946: spd_1      4a  4a  4a  4a | 00  00  00  00 -> Cfg.Linkwidth.Accept
17950: spd_1      4a  4a  4a  4a | PAD PAD PAD PAD -> Cfg.Linkwidth.Accept
17954: spd_1      4a  4a  4a  4a | ff  ff  ff  ff -> Cfg.Linkwidth.Accept
17958: spd_1      4a  4a  4a  4a | 3e  3e  3e  3e -> Cfg.Linkwidth.Accept
17962: spd_1      4a  4a  4a  4a | c0  c0  c0  c0 -> Cfg.Linkwidth.Accept
17966: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17970: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17974: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17978: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17982: spd_1      4a  4a  4a  4a | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
17986: spd_1      COM COM COM COM | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
.
.
18162: spd_1      00  00  00  00 | 4a  4a  4a  4a -> Cfg.Linkwidth.Accept
18166: spd_1      00  00  00  00 | 4a  4a  4a  4a --> Cfg.Lanenum.Wait: use_modified_ts1_ts2_ordered_set = 1,
Transition Reason: LTSSM_TRANSITION_STANDARD
18170: spd_1      00  00  00  00 | 4a  4a  4a  4a -> Cfg.Lanenum.Wait

```

Bit[7:6] is 2'b11, both support modified TS.  
Following message displays the marker where use\_modified\_TS1\_TS2\_Ordered\_Set variable gets set.

# 8 PIPE Features

This chapter describes the PIPE feature support available with Synopsys PCIe Verification IP.

This chapter discusses the following topics:

- ❖ [PIPE Support](#)
- ❖ [RxStandby/RxStandbyStatus Handshake Support](#)
- ❖ [Nominal Empty Mode for EFIFO \(Elastic Buffer Mode\)](#)
- ❖ [PIPE Signals Controllability in VIP](#)

## 8.1 PIPE Support

Configure the attribute `svt_PCIE_Device_Configuration::pipe_spec_ver` to enable the required PIPE specification features as follows:

- ❖ `PIPE_SPEC_VER_2` - Enables PIPE version 2.0
- ❖ `PIPE_SPEC_VER_4` - Enables PIPE version 4.0
- ❖ `PIPE_SPEC_VER_4.2` - Enables PIPE version 4.2
- ❖ `PIPE_SPEC_VER_4.3` - Enables PIPE version 4.3
- ❖ `PIPE_SPEC_VER_4.4` - Enables PIPE version 4.4
- ❖ `PIPE_SPEC_VER_5_1` - Enables PIPE version 5.1

### 8.1.1 PIPE Version 2.0

[Table 8-1](#) lists the PIPE specification version 2.0 supported features and signals.

**Table 8-1 PIPE Version 2.0**

| Feature Name                                                               | PIPE Signal (S) Used             | VIP Support |
|----------------------------------------------------------------------------|----------------------------------|-------------|
| PIPE Reset                                                                 | Reset#                           | Yes         |
| Data transmission and reception (8b/10b at 2.5 GT/s and 5 GT/s data rates) | TxDATA, TxDATAK, RXDATA, RXDATAK | Yes         |

**Table 8-1 PIPE Version 2.0**

| Feature Name                                                  | PIPE Signal (S) Used              | VIP Support |
|---------------------------------------------------------------|-----------------------------------|-------------|
| Power Management (P0, P0s, P1 and P2)                         | PowerDown, PhyStatus              | Yes         |
| PCLK as PHY output setup only                                 | PCLK                              | Yes         |
| Changing Signaling Rate (2.5 GT/s and 5 GT/s)                 | Rate, PhyStatus                   | Yes         |
| Fixed data path implementations (8-bit and 16-bit PIPE width) | NA                                | Yes         |
| Transmitter Margining                                         | TxMargin                          | Yes         |
| Transmitter Voltage Swing Level                               | TxSwing                           | Yes         |
| Selectable De-emphasis                                        | TxDemph                           | Yes         |
| Receiver Detection                                            | TxDetectRx/Loopback, PhyStatus    | Yes         |
| Transmitting/Detecting a beacon                               | PowerDown, TxElecIdle, RxElecIdle | Yes         |
| Clock tolerance compensation                                  | RxStatus                          | Yes         |
| Error detection                                               | RxStatus                          | Yes         |
| Loopback                                                      | TxDetectRx/Loopback               | Yes         |
| Polarity inversion                                            | RxPolarity                        | Yes         |
| Setting negative disparity                                    | TxCompliance                      | Yes         |
| Electrical Idle sequence                                      | TxElecIdle, RxElecIdle, RxValid   | Yes         |
| Lane turn off signaling                                       | TxElecIdle, TxCompliance          | Yes         |

### 8.1.2 PIPE Version 4.0

Table 8-2 lists the PIPE specification version 4.0 additional supported features and signals.

**Table 8-2 PIPE Version 4.0**

| Feature Name                                                    | PIPE Signal (S) Used                                                                                                | VIP Support |
|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------|
| PCLK as PHY output setup only                                   | PCLK, Max PCLK                                                                                                      | Yes         |
| Operating Mode                                                  | PHY mode                                                                                                            | No          |
| 8b/10b Encoding/Decoding                                        | EncodeDecodeBypass                                                                                                  | No          |
| Data transmission and reception (128/130b at 8 GT/s data rates) | TxData, RxData, BlockAlignControl, TxStartBlock, RxStartBlock, TxDataValid, RxDataValid, TxSyncHeader, RxSyncHeader | Yes         |
| Power Management (L1 substates PHY specific power states P4-P7) | PowerDown, PhyStatus                                                                                                | Yes         |

**Table 8-2 PIPE Version 4.0**

| Feature Name                                                                   | PIPE Signal (S) Used                                                                                                                 | VIP Support |
|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Changing Signaling Rate (2.5 GT/s, 5 GT/s and 8 GT/s)                          | Rate, PhyStatus, PCLK Rate                                                                                                           | Yes         |
| Fixed/Variable data path implementations (8-bit, 16-bit and 32-bit PIPE width) | Width, DataBusWidth, PhyStatus                                                                                                       | Yes         |
| Link Equalization Evaluation                                                   | FS, LF, TxDeemph, RxPresetHint, RxEqEval, LinkEvaluationFeedbackFigureMerit, LinkEvaluationFeedbackDirectionOnChange, InvalidRequest | Yes         |
| Receiver Standby                                                               | RxStandby, RxStandbyStatus                                                                                                           | Yes         |
| Data Throttling                                                                | TxDataValid, RxDataValid                                                                                                             | Yes         |
| Dynamic Preset Coefficient Updates (Dynamic Equalization)                      | LocalFS, LocalLF, GetLocalPresetCoefficients, LocalPresetIndex, LocalTxCoefficientsValid, LocalTxPresetCoefficients                  | Yes         |

### 8.1.3 PIPE Version 4.2

[Table 8-3](#) lists the PIPE specification version 4.2 additional supported features and signals.

**Table 8-3 PIPE Version 4.2**

| Feature Name                                                                | PIPE Signal (S) Used                                                                                                                               | VIP Support |
|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| PCLK as PHY output/input setup                                              | PCLK, Max PCLK                                                                                                                                     | Yes         |
| Data transmission and reception (128/130b at 8 GT/s and 16 GT/s data rates) | TxData, RxData, BlockAlignControl, TxStartBlock, RxStartBlock, TxDataValid, RxDataValid, TxSyncHeader, RxSyncHeader                                | Yes         |
| Changing Signaling Rate (2.5 GT/s, 5 GT/s, 8 GT/s and 16 GT/s)              | Rate, PhyStatus, PCLK Rate, PclkChangeOk, PclkChangeAck                                                                                            | Yes         |
| Link Equalization Evaluation                                                | FS, LF, TxDeemph, RxPresetHint, RxEqEval, LinkEvaluationFeedbackFigureMerit, LinkEvaluationFeedbackDirectionChange, InvalidRequest, RxEqInProgress | Yes         |

### 8.1.4 PIPE Version 4.3

[Table 8-4](#) lists the PIPE specification version 4.3 additional supported features and signals.

**Table 8-4 PIPE Version 4.3**

| Feature Name                                                     | PIPE Signal (S) Used                      | VIP Support |
|------------------------------------------------------------------|-------------------------------------------|-------------|
| Power Management (L1 substates PHY specific power states P4-P15) | PowerDown, PhyStatus, AsyncPowerChangeAck | Yes         |
| Elastic Buffer information                                       | ElasticBufferLocation                     | No          |

### 8.1.5 PIPE Version 4.4

[Table 8-5](#) lists the PIPE specification version 4.4 additional supported features and signals.

**Table 8-5 PIPE Version 4.4**

| Feature Name                                                                | PIPE Signal (S) Used                                                                                                | VIP Support |
|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------|
| SRIS (Separate Refclk Independent SSC) support                              | SRISEnable                                                                                                          | Yes         |
| Nominal Empty Elastic Buffer Mode                                           | Elasticity Buffer Mode                                                                                              | Yes         |
| L1 substates sideband signals handshake                                     | RxEIDetectDisable, TxCommonModeDisable                                                                              | Yes         |
| Dynamic Preset Coefficient Updates (Dynamic Equalization)                   | LocalFS, LocalLF, GetLocalPresetCoefficients, LocalPresetIndex, LocalTxCoefficientsValid, LocalTxPresetCoefficients | Yes         |
| Electrical Idle sequence                                                    | TxElecIdle, RxElecIdle, RxValid                                                                                     | Yes         |
| Setting negative disparity                                                  | TxCompliance                                                                                                        | Yes         |
| Lane turn off signaling                                                     | TxElecIdle, TxCompliance                                                                                            | Yes         |
| PCIe RX margining and elastic buffer depth control (PCLK as PHY input mode) | MBI (Message Bus Interface) - M2P_MessageBus and P2M_MessageBus                                                     | Yes         |

### 8.1.6 PIPE Version 4.4.1

[Table 8-6](#) lists the PIPE version 4.4.1 additional supported features and signals.

**Table 8-6 PIPE Version 4.4.1**

| Feature Name                                                                       | PIPE Signal (S) Used                                            | VIP Support |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------|
| PCIe RX margining and elastic buffer depth control (PCLK as PHY input/output mode) | MBI (Message Bus Interface) - M2P_MessageBus and P2M_MessageBus | Yes         |

VIP supports all the sub-features of PIPE 4.4 specifications when programmed to be `PIPE_SPEC_VER_4_4`. The PIPE specification version 4.4.1 has made only a single clarification above PIPE specification version 4.4. This clarification is with respect to MBI support when PCLK is PHY output. For all practical purposes both PIPE 4.4 and PIPE 4.4.1 are same. Thus, VIP does not have a separate programming mode for

PIPE\_SPEC\_VER\_4\_4\_1. VIP supports all the sub-features of PIPE specification version 4.4.1 when programmed to be PIPE\_SPEC\_VER\_4\_4.

### 8.1.7 PIPE Version 5.1.1

The Synopsys PCIe SVT VIP supports the *PIPE Specification Version 5.1.1*. For more information, see [PIPE5 Features](#).

## 8.2 RxStandby/RxStandbyStatus Handshake Support

### 8.2.1 Basic Attributes

VIP support for RxStandby/RxStandbyStatus handshake is enabled by default. VIP can be programmed to support RxStandby/RxStandbyStatus handshake using `svt_PCIE_pl_configuration::rx_standby_supported`.



**Note**  
Value of `rx_standby_supported` must be set to the same value in VIP as per the DUT's support for RxStandby/RxStandbyStatus handshake.

Significance of PL configuration attribute `rx_standby_supported`:

- ❖ When `rx_standby_supported` is enabled and VIP is programmed as MPIPE/MAC, VIP asserts RxStandby.
- ❖ When `rx_standby_supported` is enabled and VIP is programmed as SPIPE/PHY, VIP responds RxStandby with RxStandbyStatus assertion.
- ❖ When `rx_standby_supported` is disabled and VIP is programmed as MPIPE/MAC, VIP does not assert RxStandby.
- ❖ When `rx_standby_supported` is disabled and VIP is programmed as SPIPE/PHY, VIP does not need RxStandby assertion and will not respond with RxStandbyStatus.

### 8.2.2 Additional Attributes

- ❖ `svt_PCIE_pl_configuration::rx_standby_controls`: Specifies the controls for RxStandby assertion by MPIPE VIP in various scenarios only when configuration attribute `rx_standby_supported` is set to 1.
  - † Bit 0: Enables RxStandby assertion during rate change. RxStandbyStatus assertion is expected in this case.
  - † Bit 1: Enables RxStandby assertion in `Rx.L0s.Idle` LTSSM state. RxStandbyStatus assertion is expected in this case.
  - † Bit 2: Enables RxStandby assertion in P1 or lower power states (for PowerDown change in L1 and L2 LTSSM states). RxStandbyStatus assertion is not expected in this case.
  - † Bit 3: Enables RxStandby assertion for PowerDown change in Detect.Quiet LTSSM state. RxStandbyStatus assertion is not expected in this case.
  - † Bit 4: Enables RxStandby assertion for PowerDown change in Disabled LTSSM state. RxStandbyStatus assertion is not expected in this case.
  - † Bit 5: Enables RxStandby assertion on unused/inactive lanes or turned off lanes. RxStandbyStatus assertion is not expected in this case.

- † Bit 6: Enables RxStandby assertion when LTSSM moves from L0 state to Recovery state by Inferring Electrical Idle.
- † Bit 7: Enables RxStandby assertion in Recovery . Speed LTSSM state even when there is no rate change.

The default value of this attribute is set to 8'b00111111.

- ❖ `svt_PCIE_pl_configuration::rxstandbystatus_timeout_ns`: Specifies the time in ns, MPIPE VIP after asserting RxStandby will wait for RxStandbyStatus to go high only for those scenarios listed above where RxStandByStatus assertion is expected. The attribute controls the timeout value for `phy_rxstandbystatus_timeout` protocol check. This attribute needs to be programmed to match DUT PHY behavior so that MPIPE VIP can check DUT's timing for RxStandbyStatus signal assertion if checking actual timing is desired. The default value of this attribute is set to 1000.

### 8.2.3 Protocol Checks

`phy_rxstandbystatus_timeout`: Applicable when `svt_PCIE_pl_configuration::rx_standby_supported` is enabled along with individual control as described by `svt_PCIE_pl_configuration::rx_standby_controls` and `PowerDown` is either P0 or P0s. The intention of this protocol check is to validate that PHY responds to RxStandby with RxStandbyStatus assertion within the stipulated time period given by PL configuration attribute `rxstandbystatus_timeout_ns`.

## 8.3 Nominal Empty Mode for EFIFO (Elastic Buffer Mode)

This feature is supported when VIP is compliant with PIPE specification version 4.4.

### 8.3.1 Interface

VIP supports this mode only in Unified interface mode. Unified interface now has a new signal called `svt_PCIE_pipe_if.elasticity_buffer_mode`. The signal is implemented as a shared signal between all lanes.

### 8.3.2 Status

VIP indicates Nominal Empty mode for EFIFO by capturing the signal value and providing it as part of PIPE status class using the `svt_PCIE_pipe_status::elasticity_buffer_mode` attribute.

### 8.3.3 Configuration

To enable Nominal Empty mode for EFIFO, set the `svt_PCIE_pl_configuration::elasticity_buffer_mode` attribute.

VIP provides control over whether to assert RxDataValid in an optimized manner after it has been deasserted to indicate FIFO empty condition. This can be programmed using `svt_PCIE_pl_configuration::enable_optimized_rxdatavalid_assertion` attribute.

In order to verify MAC DUT behavior in Nominal Empty mode to handle empty condition of FIFO, SPIPE VIP provides the following attributes to control the number of SKP/AA symbols in SKIP OS and control over number of FIFO empty conditions within a SKIP interval and delay between subsequent FIFO empty conditions.

- ◆ `svt_PCIE_pl_configuration::remove_all_skp_aa_symbols`
- ◆ `svt_PCIE_pl_configuration::num_of_empty_symbols_in_skp_interval_8b10b`

- ◆ `svt_PCIE_pl_configuration::num_of_empty_symbols_in_skp_interval_128b_130b`
- ◆ `svt_PCIE_pl_configuration::empty_symbol_interval_8b10b[6]`
- ◆ `svt_PCIE_pl_configuration::empty_symbol_interval_128b130b[24]`

For detailed information about all these attributes, see [HTML class reference documentation](#).

### 8.3.4 Protocol Checks

VIP supports the following protocol checks in active mode:

- ◆ `pipe_elasticity_buffer_mode_check`
- ◆ `pipe_elasticity_buffer_empty_condition_check`
- ◆ `pipe_elasticity_buffer_skip_removal_check`
- ◆ `pipe_elasticity_buffer_no_underflow_check`
- ◆ `pipe_elasticity_buffer_rxdatavalid_assertion_check`

For detailed information about these protocol checks, see [HTML class reference documentation](#).

## 8.4 PIPE Signals Controllability in VIP

### 8.4.1 Using MPIPE VIP

**Table 8-7 MPIPE Signals**

| Signal Name | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxData      | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"><li>• Callback class name: <code>svt_PCIE_pl_callback</code></li><li>• Function name: <code>pre_pipe_data_out_put</code></li><li>• Attach exception using <code>svt_PCIE_pipe_data_exception</code> with below attributes:<br/><code>error_kind = svt_PCIE_pipe_data_exception::FORCE_DATA</code><br/><code>forced_data = &lt;value&gt;</code></li></ul>     |
| TxDataK     | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"><li>• Callback class name: <code>svt_PCIE_pl_callback</code></li><li>• Function name: <code>pre_pipe_data_out_put</code></li><li>• Attach exception using <code>svt_PCIE_pipe_data_exception</code> with below attributes:<br/><code>error_kind = svt_PCIE_pipe_data_exception::FORCE_DATA_K</code><br/><code>forced_data_k = &lt;value&gt;</code></li></ul> |

**Table 8-7 MPIPE Signals**

| Signal Name            | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxDataValid            | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"> <li>• Callback Class name: svt_PCIE_PL_CALLBACK</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_PCIE_PIPE_DATA_EXCEPTION with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_PIPE_DATA_EXCEPTION::FORCE_DATA_VALID forced_data_valid = &lt;value&gt;</pre>   |
| TxStartBlock           | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_PCIE_PL_CALLBACK</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_PCIE_PIPE_DATA_EXCEPTION with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_PIPE_DATA_EXCEPTION::FORCE_START_BLOCK forced_start_block = &lt;value&gt;</pre> |
| PHY Mode               | Not applicable                    |                                                                                                                                                                                                                                                                                                                                                                                     |
| SRISEnable             | Yes                               | <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::srис_mode_enabled</pre>                                                                                                                                                                                                                                                                              |
| Elasticity Buffer Mode | Yes                               | <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::elasticity_buffer_mode</pre>                                                                                                                                                                                                                                                                         |
| TxDetectRx/Loopback    | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_TYPES::PIPE_TXDETECTRX event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre>                                                     |
| TxElecidle             | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_PCIE_PL_CALLBACK</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_PCIE_PIPE_DATA_EXCEPTION with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_PIPE_DATA_EXCEPTION::FORCE_ELEC_IDLE forced_data = &lt;value&gt;</pre>          |

**Table 8-7 MPIPE Signals**

| Signal Name  | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxCompliance | Yes                               | <p>Using PIPE callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_PCIE_PL_CALLBACK</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_PCIE_PIPE_DATA_EXCEPTION with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_PIPE_DATA_EXCEPTION::FORCE_TX_COMPLIANCE forced_tx_compliance = &lt;value&gt;</pre>                                                |
| RxPolarity   | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_DRIVE_SIDEBAND_SIGNAL signal_name = svt_PCIE_TYPES::PIPE_RXPOLARITY event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::invert_tx_polarity</pre> |
| Reset#       | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_INJECT_RESET event_delay = &lt;value&gt; event_width = &lt;value&gt;</pre>                                                                                                                                                                                      |

**Table 8-7 MPIPE Signals**

| Signal Name      | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PowerDown        | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_pl_service</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_pl_service::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_types::PIPE_POWERDOWN event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attributes:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_pl_configuration::pipe_powerdown_state_for_l1_0</li> <li>• svt_PCIE_pl_configuration::pipe_powerdown_state_for_l1_1</li> <li>• svt_PCIE_pl_configuration::pipe_powerdown_state_for_l1_2_entry</li> <li>• svt_PCIE_pl_configuration::pipe_powerdown_state_for_l1_2_idle</li> <li>• svt_PCIE_pl_configuration::pipe_powerdown_state_for_l1_2_exit</li> </ul> |
| RxIDetectDisable | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_pl_service</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_pl_service::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_types::PIPE_RXELECidle_DISABLE event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_pl_configuration::l1ss_rxelecidle_disable_assertion_delay_ns</li> <li>• svt_PCIE_pl_configuration::l1ss_rxelecidle_disable_deassertion_delay_ns</li> </ul>                                                                                                                                                                                         |

**Table 8-7 MPIPE Signals**

| Signal Name         | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxCommonModeDisable | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_pl_service</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_pl_service::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_types::PIPE_TXCOMMONMODE_DISABLE event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_pl_configuration::l1ss_txcommonmode_disable_assertion_delay_ns</li> <li>• svt_PCIE_pl_configuration::l1ss_txcommonmode_disable_deassertion_delay_ns</li> </ul> |
| Rate                | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_pl_service</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_pl_service::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_types::PIPE_RATE event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class function:</p> <pre>svt_PCIE_pl_configuration::set_link_speed_values</pre>                                                                                                                                                                       |
| Width               | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_pl_service</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_pl_service::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_types::PIPE_WIDTH event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_pl_configuration::pipe_width</pre>                                                                                                                                                                                |

**Table 8-7 MPIPE Signals**

| Signal Name      | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCLK Rate        | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_TYPES::PIPE_PCLK_RATE event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::pclk_rate</pre>                       |
| TxDeemph         | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::SET_LANE_TX_DEEMPH tx_deemph = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::tx_select_deemphasis</li> <li>• svt_PCIE_PL_CONFIGURATION::preset_to_coefficients_mapping_table*</li> </ul> |
| RxPresetHint     | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::upstream_receiver_preset_hint*</li> <li>• svt_PCIE_PL_CONFIGURATION::downstream_receiver_preset_hint*</li> </ul>                                                                                                                                                                                                                  |
| LocalPresetIndex | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_GET_LOCAL_PRESET_COEFFICIENTS event_delay = &lt;value&gt; preset_value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::enable_get_local_preset_coefficients</pre>                                                       |

**Table 8-7 MPIPE Signals**

| Signal Name                | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GetLocalPresetCoefficients | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_GET_LOCAL_PRESET_COEFFICIENTS event_delay = &lt;value&gt; preset_value = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <pre>svt_PCIE_PL_CONFIGURATION::enable_get_local_preset_coefficients</pre>                                                                                                                                                                                                                              |
| FS                         | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::use_dynamic_fs_lf_values</li> <li>• svt_PCIE_PL_CONFIGURATION::fs_value*</li> <li>• svt_PCIE_PL_CONFIGURATION::attached_fs*</li> </ul>                                                                                                                                                                                                                                                                                                                                                                   |
| LF                         | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::use_dynamic_fs_lf_values</li> <li>• svt_PCIE_PL_CONFIGURATION::fs_value*</li> <li>• svt_PCIE_PL_CONFIGURATION::attached_fs*</li> </ul>                                                                                                                                                                                                                                                                                                                                                                   |
| RxEqEval                   | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::QUEUE_EQ_TX_REQUEST_PRESET_COEFF preset_valid = &lt;value&gt; preset_value = &lt;value&gt; cursor_coeff = &lt;value&gt; precursor_coeff=&lt;value&gt; postcursor_coeff=&lt;value&gt; expect_reject=&lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::pipe_rxeqeval_assertion_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::pipe_rxeqeval_deassertion_delay</li> </ul> |
| RxEqInProgress             | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::simultaneous_deassertion_of_rxeqinprogress</li> <li>• svt_PCIE_PL_CONFIGURATION::pipe_rxeqinprogress_assertion_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::pipe_rxeqinprogress_deassertion_delay</li> </ul>                                                                                                                                                                                                                                                                                              |

**Table 8-7 MPIPE Signals**

| Signal Name       | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| InvalidRequest    | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li><code>svt_PCIE_PL_Configuration::min_num_pclk_cycles_to_assert_invalid_request</code></li> <li><code>svt_PCIE_PL_Configuration::max_num_pclk_cycles_to_assert_invalid_request</code></li> </ul>                                                                                                                                                                                                                                                                                         |
| TxMargin          | Yes                               | <p>Using PL configuration class function:<br/> <code>svt_PCIE_PL_Configuration::tx_margin</code></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TxSwing           | Yes                               | <p>Using PL configuration class function:<br/> <code>svt_PCIE_PL_Configuration::tx_swing</code></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TxSyncHeader      | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>Callback class name: <code>svt_PCIE_PL_Callback</code></li> <li>Function name: <code>pre_pipe_data_out_put</code></li> <li>Attach exception using <code>svt_PCIE_Pipe_Data_Exception</code> with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_Pipe_Data_Exception::FORCE_SYNC_HDR - forced_sync_hdr = &lt;value&gt;</pre>                                                                                                                                                             |
| BlockAlignControl | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: <code>svt_PCIE_PL_Service</code></p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_Service::PIPE_DRIVE_SIDEBAND_SIGNAL signal_name = svt_PCIE_Types::PIPE_BLOCK_ALIGN_CONTROL event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre>                                                                                                                                                                                                                         |
| RxStandby         | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: <code>svt_PCIE_PL_Service</code></p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_Service::PIPE_DRIVE_SIDEBAND_SIGNAL signal_name = svt_PCIE_Types::PIPE_RXSTANDBY event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li><code>svt_PCIE_PL_Configuration::rx_standby_supported</code></li> <li><code>svt_PCIE_PL_Configuration::rx_standby_controls</code></li> </ul> |

**Table 8-7 MPIPE Signals**

| <b>Signal Name</b>  | <b>User Controllability Availability</b> | <b>User APIs</b>                                                                                                                                                                                                                                                                                                                                   |
|---------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EncodeDecodeBypass  | Not Available                            |                                                                                                                                                                                                                                                                                                                                                    |
| PclkChangeAck       | Yes                                      | Using PL configuration class function:<br><code>svt_PCIE_PL_Configuration::pclk_change_ack_delay</code>                                                                                                                                                                                                                                            |
| AsyncPowerChangeAck | Yes                                      | Using PL configuration class function:<br><code>svt_PCIE_PL_Configuration::async_power_change_ack_delay</code>                                                                                                                                                                                                                                     |
| M2P_MessageBus      | Yes                                      | Using PL service request as below:<br>Service request class name: <code>svt_PCIE_PL_Service</code><br>Attributes used:<br><code>service_type = svt_PCIE_PL_Service::MBI_CMD</code><br><code>mbi_lane_num= &lt;value&gt;</code><br><code>mbi_cmd=&lt;value&gt;</code><br><code>mbi_addr=&lt;value&gt;</code><br><code>mbi_data=&lt;value&gt;</code> |

#### 8.4.2 Using SPIPE VIP

**Table 8-8 SPIPE Signals**

| <b>Signal Name</b> | <b>User Controllability Availability</b> | <b>User APIs</b>                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RxData             | Yes                                      | Using pipe callback as below:<br><ul style="list-style-type: none"> <li>• Callback Class name: <code>svt_PCIE_PL_Callback</code></li> <li>• Function name: <code>pre_pipe_data_out_put</code></li> <li>• Attach exception using <code>svt_PCIE_Pipe_Data_Exception</code> with below attributes:<br/><br/> <code>error_kind = svt_PCIE_Pipe_Data_Exception::FORCE_DATA</code><br/> - <code>forced_data = &lt;value&gt;</code></li> </ul>     |
| RxDataK            | Yes                                      | Using pipe callback as below:<br><ul style="list-style-type: none"> <li>• Callback class name: <code>svt_PCIE_PL_Callback</code></li> <li>• Function name: <code>pre_pipe_data_out_put</code></li> <li>• Attach exception using <code>svt_PCIE_Pipe_Data_Exception</code> with below attributes:<br/><br/> <code>error_kind = svt_PCIE_Pipe_Data_Exception::FORCE_DATA_K</code><br/> - <code>forced_data_k = &lt;value&gt;</code></li> </ul> |

**Table 8-8 SPIPE Signals**

| Signal Name  | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RxDataValid  | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_pcie_pl_callback</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_pcie_pipe_data_exception with below attributes:</li> </ul> <pre>error_kind = svt_pcie_pipe_data_exception::FORCE_DATA_VALID - forced_data_valid = &lt;value&gt;</pre>   |
| RxStartBlock | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_pcie_pl_callback</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_pcie_pipe_data_exception with below attributes:</li> </ul> <pre>error_kind = svt_pcie_pipe_data_exception::FORCE_START_BLOCK - forced_start_block = &lt;value&gt;</pre> |
| RxEleIdle    | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_pcie_pl_callback</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_pcie_pipe_data_exception with below attributes:</li> </ul> <pre>error_kind = svt_pcie_pipe_data_exception::FORCE_ELEC_IDLE - forced_data = &lt;value&gt;</pre>          |
| LocalFS      | Yes                               | <p>Using PL configuration class function:<br/> <code>svt_pcie_pl_configuration::local_fs*</code></p>                                                                                                                                                                                                                                                                                  |
| LocalLF      | Yes                               | <p>Using PL configuration class function:<br/> <code>svt_pcie_pl_configuration::local_lf*</code></p>                                                                                                                                                                                                                                                                                  |
| RxSyncHeader | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_pcie_pl_callback</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_pcie_pipe_data_exception with below attributes:</li> </ul> <pre>error_kind = svt_pcie_pipe_data_exception::FORCE_SYNC_HDR - forced_sync_hdr = &lt;value&gt;</pre>       |

**Table 8-8 SPIPE Signals**

| Signal Name               | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RxStandbyStatus           | Yes                               | <p>Using PL service request as below:</p> <p>Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::PIPE_DRIVE_SIDEBOARD_SIGNAL signal_name = svt_PCIE_TYPES::PIPE_RXSTANDBY_STATUS event_delay = &lt;value&gt; event_width = &lt;value&gt; value = &lt;value&gt;</pre> <p>Using PL configuration class function:</p> <pre>svt_PCIE_PL_CONFIGURATION::rx_standby_supported</pre> |
| PclkChangeOk              | Yes                               | <p>Using PL configuration class function:</p> <pre>svt_PCIE_PL_CONFIGURATION::pclk_change_ok_delay</pre>                                                                                                                                                                                                                                                                                                                                       |
| P2M_Message Bus           | No                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LocalTxPresetCoefficients | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::enable_get_local_preset_coefficients</li> <li>• svt_PCIE_PL_CONFIGURATION::preset_to_coefficients_mapping_table*</li> <li>• svt_PCIE_PL_CONFIGURATION::min_spipe_preset_coefficients_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::max_spipe_preset_coefficients_delay</li> </ul>                                              |
| LocalTxCoefficientValid   | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::enable_get_local_preset_coefficients</li> <li>• svt_PCIE_PL_CONFIGURATION::preset_to_coefficients_mapping_table*</li> <li>• svt_PCIE_PL_CONFIGURATION::min_spipe_preset_coefficients_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::max_spipe_preset_coefficients_delay</li> </ul>                                              |

**Table 8-8 SPIPE Signals**

| Signal Name                           | User Controllability Availability | User APIs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LinkEvaluationFeedbackFigureMerit     | Yes                               | <p>Using PL service request as below:<br/> Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::QUEUE_EQ FIGURE_MERIT_RESPONSE eq_lane_num = &lt;value&gt; figure_of_merit = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::min_rx_eq_eval_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::max_rx_eq_eval_delay</li> </ul>                             |
| LinkEvaluationFeedbackDirectionChange | Yes                               | <p>Using PL service request as below:<br/> Service request class name: svt_PCIE_PL_SERVICE</p> <p>Attributes used:</p> <pre>service_type = svt_PCIE_PL_SERVICE::QUEUE_EQ_DIRECTION_CHANGE_RESPONSE eq_lane_num = &lt;value&gt; direction_change_response = &lt;value&gt;</pre> <p>Using PL configuration class attribute:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::min_rx_eq_eval_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::max_rx_eq_eval_delay</li> </ul>               |
| RxValid                               | No                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PhyStatus                             | Yes                               | <p>Using PL configuration class function:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_PL_CONFIGURATION::min_spipe_phystatus_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::max_spipe_phystatus_delay</li> <li>• svt_PCIE_PL_CONFIGURATION::enable_per_lane_spipe_phystatus_rand_delay</li> </ul> <p>Using svt_PCIE_PIPE_PHYSTATUS_RESPONSE_CONFIGURATION handle present inside svt_PCIE_PL_CONFIGURATION.</p> <pre>svt_PCIE_PIPE_PHYSTATUS_RESPONSE_CONFIGURATION phystatus_response_cfg[\$].</pre> |
| RxStatus                              | Yes                               | <p>Using pipe callback as below:</p> <ul style="list-style-type: none"> <li>• Callback class name: svt_PCIE_PL_CALLBACK</li> <li>• Function name: pre_pipe_data_out_put</li> <li>• Attach exception using svt_PCIE_PIPE_DATA_EXCEPTION with below attributes:</li> </ul> <pre>error_kind = svt_PCIE_PIPE_DATA_EXCEPTION::FORCED_RX_STATUS - forced_rx_status = &lt;value&gt;</pre>                                                                                                                         |

**Table 8-8 SPIPE Signals**

| Signal Name           | User Controllability Availability | User APIs |
|-----------------------|-----------------------------------|-----------|
| ElasticBufferLocation | Not available                     |           |
| DataBusWidth          | No                                |           |



# 9 PIPE5 Features

This chapter describes the PIPE5 feature support available with Synopsys PCIe Verification IP.

This chapter discusses the following topics:

- ❖ [Version Support](#)
- ❖ [Supported Interfaces](#)
- ❖ [Supported Features](#)
- ❖ [VIP Requirements](#)
- ❖ [Limitations](#)
- ❖ [PIPE Interface Usage Model](#)

## 9.1 Version Support

The Synopsys PCIe SVT VIP supports the *PIPE Specification Version 5.1.1, July 2018*. Functionality and controls will be updated as the specification changes.

## 9.2 Supported Interfaces

Support to PIPE5 feature set is available when using the `svt_PCIE_PIPE5_if` interface with PCIe SVT Unified model. For more details, [PCIe PIPE Interface](#).



PIPE5 support for legacy instantiation models will not be supported.

## 9.3 Supported Features

### 9.3.1 PIPE 5.1.1 Features

Following are the features introduced in *PIPE Specification Version 5.1.1*:

- ❖ Mapping of legacy signals with Message Bus Registers

- ❖ Low pin count interface
  - ◆ m2p\_message\_bus
  - ◆ p2m\_message\_bus
- ❖ SERDES architecture
  - ◆ Including 64-bit wide data path

The *PIPE Specification Version 5.1.1* provides PIPE interface for devices compatible with *PCI Express Base Specification Version 5.0* or earlier. However, PCIe VIP provides support to *PIPE Specification Version 5.1.1* only when programmed as a device compatible with *PCI Express Base Specification Revision 5.0 Version 0.7*. With this approach, VIP provides a new low pin count interface named `svt_PCIE_PIPE5_if` where legacy signals are not available. The `svt_PCIE_PIPE5_if` is added as a subinterface of `svt_PCIE_if` interface.



**Note** To enable support to Gen5 speed when using traditional architecture and legacy signals using *PIPE Specification Version 4.4* or *4.4.1*, you must use `svt_PCIE_PIPE_if` and enable Gen5 speed support as described in [Gen5 Support for PIPE Interface](#).

### 9.3.2 PIPE 5.1.1 Features Supported in Active VIP

Following are the PIPE 5.1.1 features supported in this release:

- ❖ Initial link negotiation
  - ◆ x1 to x32
- ❖ Speed negotiation for speeds 2.5G, 5G, 8G, 16G, and 32G
- ❖ PIPE Width/Rate/PCLKRate configurations as per Appendix [PCIe PIPE Interface](#).
- ❖ Per lane sideband signals in `svt_PCIE_PIPE5_if`
- ❖ Low power states, L1SS with sideband signals
- ❖ PclkChangeOk/PclkchangeAck handshake support for rate and width changes
- ❖ Receiver detection in P2 power states
- ❖ MAC and PHY register space associated with MBI
  - ◆ All MAC and PHY registers compatible with PIPE 5.1.1
  - ◆ API to generate MBI commands from the testbench.

The `svt_PCIE_pl_service_request_mbi_cmd_sequence` service sequence is used to initiate MBI commands.

  - ◆ Auto-generation of `writeAck` and `ReadCompletion` in response to received write and read.
  - ◆ Tracking of MAC and PHY registers of MBI in MPIPE and SPIPE mode.
- ❖ Mapping of legacy handshake over MBI
  - ◆ Polarity Inversion
  - ◆ Block Align Control
  - ◆ Receiver Equalization
  - ◆ Dynamic Preset Coefficient updates

- ◆ FS, LF, LocalFS, LocalLF, LocalG4FS, LocalG4LF, LocalG5FS, LocalG5LF, and TxDeemph
- ◆ Rx Margining
- ◆ Lane Margining
- ❖ MBI Handshakes for lane reversal configurations
- ❖ RefClkRequired# signal
- ❖ Functional coverage for Original PIPE Architecture and Low Pin Count Interface
- ❖ Mapping of legacy signals into Message Bus registers
- ❖ Low pin count interface
  - ◆ m2p\_message\_bus
  - ◆ p2m\_message\_bus
- ❖ SerDes architecture
- ❖ Including 64-bit wide data path
- ❖ Custom support for PCLK as PHY output. For more details, see [VIP Requirements](#).



- Note**
- The existing VIP APIs for the above features are applicable for PIPE 5.1.1 and earlier versions.
  - Additionally, the handshake mechanism is the only feature updated for PIPE 5.1.1.
  - The PIPE 5.1.1 specification mandates PCLK as PHY input.

### 9.3.2.1 SerDes Architecture

Support for SerDes architecture is available from P-2019.06-3 release. [Figure 9-1](#) shows the comparison between SerDes architecture and traditional architecture.

**Figure 9-1 Traditional Architecture Vs SerDes Architecture**

Verification of SerDes architecture is ongoing. This feature is in EA stage.

### 9.3.2.1.1 Enabling SerDes Mode

Serde architecture mode is enabled using a configuration attribute `svt_PCIE_pl_configuration::enable_serdes_arch`.

Additionally, you must define the `SVT_PCIE_ENABLE_SERDES_ARCH` macro.

### 9.3.2.1.2 Controlling RX Data Path PIPE Configuration

In SerDes architecture mode, the TX data path PIPE configuration is still controlled using the existing `pipe_width` and `pclk_rate` attributes from `svt_PCIE_pl_configuration` class. The RX data path configurations can now be controlled using `svt_PCIE_pl_configuration::pipe_rx_width` attribute. For detailed information of this attribute, see HTML class reference guide.

### 9.3.2.1.3 Controlling SSC, PPM, and rxclk Skew Settings

In SerDes architecture mode, when the VIP is operating as SPIPE mode, VIP provides controls over SSC, PPM and skew settings of rxclk. Refer to the existing attributes `ssc_max_spread`, `ssc_modulation_rate`, and `fixed_ppm_due_to_tx_rx_xo` for SSC and PPM controls of rxclk. For detailed information about these attributes, see `svt_PCIE_pl_configuration::min_rx_clk_skew` and `svt_PCIE_pl_configuration::max_rx_clk_skew` attributes.

## 9.4 VIP Requirements

To enable PIPE 5.1.1 feature, set the following configurations:

- ❖ Set the following Gen4 and Gen5 licenses:
  - ◆ VIP-PCIE-G4-SVT
  - ◆ VIP-PCIE-G5-SVT

For more details, see [Licensing Information](#).

- ❖ Define the `SVT_PCIE_ENABLE_GEN5` macro.
- ❖ Define the `SVT_PCIE_ENABLE_PIPE5` macro.
- ❖ Set the PCIe specification version.  
`svt_PCIE_device_configuration::PCIE_SPEC_VER_5_0`
- ❖ Set the PIPE specification version.  
`svt_PCIE_device_configuration::PIPE_SPEC_VER_5_1`
- ❖ Set the interface `svt_PCIE_pipe5_if`.

For more details, [PIPE Interface Usage Model](#).

- ❖ To enable PCLK as PHY output feature, define the `SVT_PCIE_ENABLE_PIPE5_PCLK_AS_PHY_OUTPUT_MODE` mode (this mode is outside the PIPE 5.1 specification which states that PCLK as PHY output mode is not supported for PCIe 5.0 and above).
- ❖ To enable SerDes architecture mode, you must define `SVT_PCIE_ENABLE_SERDES_ARCH`.

## 9.5 Limitations

VIP supports PIPE 5.1.1 only when used as an Active agent. The features listed below will be available in the upcoming releases.

### 9.5.1 Known Limitations in Active VIP

Following PIPE 5.1.1 features are not supported in this release:

- ❖ Support to CCIX ESM speeds when using `svt_PCIE_pipe5_if`.
- ❖ 64/80 bit PIPE width is not fully supported.

## 9.6 PIPE Interface Usage Model

The PCIe SVT VIP implements `svt_PCIE_if` interface for DUT connectivity. For PIPE interfaces, `svt_PCIE_if` offers two subinterfaces namely `svt_PCIE_pipe_if` and `svt_PCIE_pipe5_if`. You must use only one PIPE interface—that is, either `svt_PCIE_pipe_if` or `svt_PCIE_pipe5_if`. To choose between `svt_PCIE_pipe_if` and `svt_PCIE_pipe5_if`, refer to the descriptions in [Applicable Scenarios for Using svt\\_PCIE\\_pipe\\_if](#) and [Applicable Scenarios for Using svt\\_PCIE\\_pipe5\\_if](#) respectively.

### 9.6.1 Applicable Scenarios for Using `svt_PCIE_pipe_if`

- ❖ Supports *PIPE Specification Version 4.4.1* or earlier.
- ❖ To be used only when:
  - ◆ Design/DUT is compatible with *PCIe Specification Version 4.0* or earlier.
  - ◆ Using a custom mode where 64-bit data width is required to achieve Gen3/Gen4/Gen5 speeds (for *PIPE Specification Version 4.3* and later).
  - ◆ Using a custom enhancement which supports PIE8 interface.
  - ◆ Using a custom enhancement which supports Gen5 speed and *PIPE Specification Version 4.4.1*.

### 9.6.2 Applicable Scenarios for Using `svt_PCIE_pipe5_if`

- ❖ Supports *PIPE Specification Version 5.1.1* and later.

- ❖ To be used only when design/DUT is compatible with *PCIe Specification Version 5.0* and later and *PIPE Specification Version 5.1.1* and later.
- ❖ Using a custom mode where 64-bit data width is required to achieve Gen1/Gen2/Gen3/Gen4/Gen5 speeds (for *PIPE Specification Version 5.1.1* and later).

### 9.6.3 Features Supported in `svt_PCIE_pipe_if` and `svt_PCIE_pipe5_if`

**Table 9-1** lists the supported features in `svt_PCIE_pipe_if` and `svt_PCIE_pipe5_if`.

**Table 9-1 Feature Comparison**

| Features                                   | <code>svt_PCIE_pipe_if</code>     | <code>svt_PCIE_pipe5_if</code> |
|--------------------------------------------|-----------------------------------|--------------------------------|
| Legacy pin interface                       | Supported                         | Not supported                  |
| Low pin count interface                    | Supported ONLY for RX margining   | Supported                      |
| Original PIPE architecture                 | Supported                         | Supported                      |
| SERDES architecture                        | Not supported                     | Supported                      |
| Link speeds up to 16G                      | Supported                         | Supported                      |
| 32G link speed                             | Supported with custom enhancement | Supported                      |
| Compatible with PCIe specification version | 4.0                               | 5.0                            |

# 10 PCIe Verification Topologies

---

This chapter shows the supported interfaces of the PCIe VIP. It contains the following sections:

- ❖ [Introduction](#)
- ❖ [Unified PCIe VIP Component](#)
- ❖ [Check 'x' or 'z' on Signal](#)

## 10.1 Introduction

The PCI Express Transceiver VIP is a bus functional model that can generate and respond to PCI Express transactions. It can be used to verify PCI Express endpoint, switch, or root complex devices.

[Figure 10-1](#) shows all the supported layers in the PCIe VIP. The layers below the PHY layer will be supported based on the interface selected for the VIP. If the SERDES interface is selected, then the PCS and SERDES layers are included in the VIP along with the other three layers. If the Parallel interface is selected, then the PCS layer gets included along with the other three layers. For the PIPE interface, the VIP will contain the Transaction Layer, the Data Link Layer, and the PHY Layer.

**Figure 10-1 PCIe VIP Structure**

## 10.2 Unified PCIe VIP Component

### 10.2.1 Introduction

This section provides key features and the use model of SVT PCIe Unified (or PCIe Single Port Device) VIP component for use in the UVM testbench. The Unified PCIe VIP component is a combination of Unified PCIe VIP Agent (UVM\_COMPONENT), Unified PCIe VIP Interface (`svt_PCIE_if`) and Unified PCIe VIP HDL (`svt_PCIE_single_port_device_agent_hdl`) module.



Unified model is the interconnect moving forward as the legacy instantiation models will be deprecated in the future releases.

**Figure 10-2 Existing VIP and Unified VIP Structure**

### 10.2.2 Existing VIP Structure

The existing VIP consists of SystemVerilog HDL module and global defines. At the core of the model is a SystemVerilog HDL module. It handles all basic tasks in managing the PCIe stack. It communicates with an UVM SystemVerilog Agent which is the interface to the user's testbench. You configure the model using both UVM configuration classes and global defines.

Connecting the model to the user DUT is done in the following ways:

- ❖ Signal connectivity is done through the Verilog module.
- ❖ There are separate HDL instantiation models defining all width, rate, and PHY connectivity variations (PIPE/SERDES/PMA). There are currently 40+ instantiation models that define all permissible variations of PIPE, SERDES, and PMA interfaces. For more information on instantiation models, see [Instantiation Models](#).
- ❖ The UVM based interface model (dynamic) and the Verilog module interfaces (static) rely on a combination of Verilog defines and parameters to control the compile type connection topology of VIP. The macro based settings being global in nature restrict the testbench to use of a single setting across multiple VIP instances.
- ❖ As a result, these factors limit VIP usage when trying to verify highly configurable, multi-link PCIe designs.

### 10.2.3 Unified PCIe VIP Component

The PCIe VIP is enhanced with a Unified interface VIP component to use the model seamlessly for configurable single link/multi-link designs. It consists of the following components:

- ❖ Uses Unified PCIe Verilog HDL VIP as single SystemVerilog module configurable through parameters (does not rely on defines).
- ❖ Uses a Unified PCIe VIP Interface as single interface object. This interface is non-parameterized and non-macro based. Each of the sub-interfaces supports maximum link width of 32 lanes.
  - ◆ The signal names used in the sub-interfaces are all in lower case. If the specification refers these using mixed case, then the rule followed is insert an `\_` preceding each capital letter and convert the string to lower case. The trailing numerical portion in signal names is used to indicate the specific lane that the signal is associated with. An example showing TxData for lane 0 is represented by tx\_data\_0[31:0] and TxData for lane 1 is represented by tx\_data\_1[31:0].
  - ◆ Since the model supports multiple versions of PIPE specification, it implements some signals on shared basis (per link), and some on per lane basis. For example, PIPE Spec version 4.2 and above support supports the option of the PCLK signal being driven by Controller instead of the PHY (that is, parameter SVT\_PCIE\_UI\_PIPE\_CLK\_FROM\_MAC is set to 1). This functionality is modeled using pclk\_\* signals (on per lane basis), but for PIPE Spec Version prior to 4.2, the PCLK signal is driven from the PHY to controller and this is modeled using pclk (on shared basis).  
For more details on individual signals, see the in-line comments in *svt\_PCIE\_pipe\_if.svi*, *svt\_PCIE\_pma\_if.svi*, and *svt\_PCIE\_serdes\_if.svi*. files available at <design dir>/include/sverilog/.  
See also, *svt\_PCIE\_if* (Interfaces tab) in the in PCIe VIP UVM class reference.
- ❖ Scalable and simplified integration use model.

Figure 10-3 provides an overview of the Unified PCIe Verilog HDL VIP Framework.

**Figure 10-3 Unified PCIe Verilog HDL VIP****Note**

For debugging the active VIP component, you can use the waveform viewer to access the internal nodes by accessing one of the following paths. The strings in bold represent the name of the mutually exclusive generate blocks shown above.

```
Instance_of_svt_PCIE_single_port_device_agent_hdl.m_ser.port0... OR  
Instance_of_svt_PCIE_single_port_device_agent_hdl.m_pma.port0... OR  
Instance_of_svt_PCIE_single_port_device_agent_hdl.m_spipe.port0... OR  
Instance_of_svt_PCIE_single_port_device_agent_hdl.m_mpipe.port0... OR  
Instance_of_svt_PCIE_single_port_device_agent_hdl.m_app.port0...
```

#### 10.2.3.1 Configurable Parameters for the Unified PCIe Verilog HDL VIP

The Unified VIP instance supports a number of configuration settings using some parameters. Some of these parameters should not be changed post compilation. These are called static parameters. Other parameters can be changed during the simulation through various configuration classes, such as `svt_PCIE_device_configuration`. These are referred to as dynamic parameters.

[Table 10-1](#) shows the list of available parameters.

**Table 10-1 Configurable Parameters for the Unified PCIe Verilog HDL VIP**

| Parameter Name                      | Default                  | Static Vs Dynamic                                                                | Remarks                                                                                                                                          |
|-------------------------------------|--------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| SVT_PCIE_UI_PCIE_SPEC_VER           | SVT_PCIE_U_PCIE_SPEC_VER | Dynamic                                                                          | Represents PCIe spec version that the VIP instance implements.                                                                                   |
| SVT_PCIE_UI_PIPE_SPEC_VER           | SVT_PCIE_U_PIPE_SPEC_VER | Static                                                                           | Represents PIPE spec version that the VIP instance implements.                                                                                   |
| SVT_PCIE_UI_SERIAL_CLK_TOLERANCE    | 0.000100                 | Static                                                                           | Controls the behavior of VIP receive path during the clock recovery process.                                                                     |
| SVT_PCIE_UI_NUM_PHYSICAL_LANES      | 32                       | Dynamic as long as the new value is less than the value set at the compile time. | Represents the maximum number of lanes to be supported by the VIP instance. The legal values are 1, 2, 4, 8, 16, and 32.                         |
| SVT_PCIE_UI_NUM_PMA_INTERFACE_BITS  | 10                       | Static                                                                           | Represents the maximum number of bits (per lane) that need to be supported by PMA interface of the VIP. The legal values are 10, 20, 40, and 80. |
| SVT_PCIE_UI_NUM_PIPE_INTERFACE_BITS | 32                       | Dynamic                                                                          | Represents the maximum number of bits (per lane) that need to be supported by the PIPE interface of the VIP. The legal values are 8, 16, and 32. |
| SVT_PCIE_UI_DISPLAY_NAME            | single_port_device       | Static                                                                           | Instance name of the HDL module along with the trailing “.”. It is used to identify instance in symbol log file.                                 |
| SVT_PCIE_UI_HIERARCHY_NUMBER        | 0                        | Static                                                                           | Used to distinguish PCIe tree originating at different roots in a multi root system.                                                             |

**Table 10-1 Configurable Parameters for the Unified PCIe Verilog HDL VIP**

| Parameter Name                            | Default                                                                             | Static Vs Dynamic | Remarks                                                                                                                                                                                                                                      |
|-------------------------------------------|-------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SVT_PCIE_UI_ENABLE_SHADOW_MEMORY_CHECKING | 1                                                                                   | Dynamic           | The application layer of VIP has a logic to check payload from end-to-end transfer point of view. Setting this parameter to 1 allows testbench to enable this checker.                                                                       |
| SVT_PCIE_UI_ENABLE_CFG_BLOCK              | 1                                                                                   | Dynamic           | When set to 1, the Active VIP Driver and Requester application layer components implement a structure similar to PCIe configuration space.                                                                                                   |
| SVT_PCIE_UI_MPIPE                         | 1                                                                                   | Static            | Applicable only if<br>SVT_PCIE_UI_PHY_INTERFACE_TYPE =<br>'`SVT_PCIE_UI_PHY_INTERFACE_TYPE_PIPE<br>• If 1, indicates instance represents a PIPE compliant "MAC".<br>• If 0, indicates instance represents a PIPE compliant "PHY".            |
| SVT_PCIE_UI_PHY_INTERFACE_TYPE            | 'SVT_PCIE_UI_PHY_INTERFACE_TYPE_PIPE<br>Y_INT<br>ERFA<br>CE_T<br>YPE_<br>SERD<br>ES | Static            | The legal Values are: <ul style="list-style-type: none"><li>SVT_PCIE_UI_PHY_INTERFACE_TYPE_SERDE</li><li>SVT_PCIE_UI_PHY_INTERFACE_TYPE_PIPE</li><li>SVT_PCIE_UI_PHY_INTERFACE_TYPE_PMA</li><li>SVT_PCIE_UI_PHY_INTERFACE_TYPE_APP</li></ul> |
| SVT_PCIE_UI_DEVICE_IS_ROOT                | 1                                                                                   | Dynamic           | If 1, then indicates, instance is configured as a Root Complex. Any other value is an Endpoint.<br>If 0, all layers of active component are turned off.                                                                                      |
| SVT_PCIE_UI_CONNECT_ACTIVE_VIP            | 1                                                                                   | Static            | If 0, all layers of active component are turned off.                                                                                                                                                                                         |
| SVT_PCIE_UI_DUT_IN_V2V_CTL_TB             | 1                                                                                   | Static            | Applicable only to VIP-to-VIP testbenches. No impact on standalone VIP functionality.<br><b>Note:</b> Do not care from DUT connections point of view.                                                                                        |

**Table 10-1 Configurable Parameters for the Unified PCIe Verilog HDL VIP**

| Parameter Name                      | Default                          | Static Vs Dynamic | Remarks                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------|----------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SVT_PCIE_UI_PIPE_CLK_FROM_MAC       | 0                                | Static            | Applicable only if SVT_PCIE_UI_PHY_INTERFACE_TYPE = `SVT_PCIE_UI_PHY_INTERFACE_TYPE_PIPE PIPE spec 4.2 and above support pclk to be sourced by MAC instead of PIPE. When set to 1, VIP instance (with SVT_PCIE_UI_MPIPE = 1) will source the PCLK.                                                                             |
| SVT_PCIE_UI_ENABLE_IO_SKEW          | 0                                | Static            | Can be set to 1 if SVT_PCIE_UI_MPIPE = 1. This parameter enables clocking block for PIPE signals.                                                                                                                                                                                                                              |
| SVT_PCIE_UI_SETUP_PS                | 10ps                             | Static            | Applicable if SVT_PCIE_UI_MPIPE = 1 & SVT_PCIE_UI_ENABLE_IO_SKEW = 1<br>This real-time parameter specifies setup time of clocking block. Smallest non-zero value can be 1fs.                                                                                                                                                   |
| SVT_PCIE_UI_HOLD_PS                 | 5ps                              | Static            | Applicable if SVT_PCIE_UI_MPIPE = 1 & SVT_PCIE_UI_ENABLE_IO_SKEW = 1<br>This real-time parameter specifies hold time of clocking block. Smallest non zero value can be 1fs.                                                                                                                                                    |
| SVT_PCIE_UI_PIPE_MAX_PCLK_SUPPORTED | `SVT_PCIE_PIPE_MAX_PCLK_1000_MHZ | Static            | Represents the max_pclk supported by PHY. Legal values are: <ul style="list-style-type: none"> <li>• `SVT_PCIE_PIPE_MAX_PCLK_4000_MHZ</li> <li>• `SVT_PCIE_PIPE_MAX_PCLK_2000_MHZ</li> <li>• `SVT_PCIE_PIPE_MAX_PCLK_1000_MHZ</li> <li>• `SVT_PCIE_PIPE_MAX_PCLK_500_MHZ</li> <li>• `SVT_PCIE_PIPE_MAX_PCLK_250_MHZ</li> </ul> |

While instantiating the Unified PCIe VIP HDL module, the testbench must configure the above parameters according to testbench needs.

For more details on how to set the values for individual instances, see the example file *top\_PCIE\_pipe\_topology.sv* available in the *examples* directory.

**Table 10-2 Parameters Applicable to Unified VIP Instances**

| Parameter                                 | Applicable to Active Unified VIP Instances Representing |            |                     |                   |
|-------------------------------------------|---------------------------------------------------------|------------|---------------------|-------------------|
|                                           | PIPE Master                                             | PIPE Slave | Serial Link Partner | Application Layer |
| SVT_PCIE_UI_PCIE_SPEC_VER                 | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_PIPE_SPEC_VER                 | √                                                       | √          | X                   | X                 |
| SVT_PCIE_UI_NUM_PHYSICAL_LANES            | √                                                       | √          | √                   | X                 |
| SVT_PCIE_UI_NUM_PMA_INTERFACE_BITS        | X                                                       | X          | X                   | X                 |
| SVT_PCIE_UI_NUM_PIPE_INTERFACE_BITS       | √                                                       | √          | X                   | X                 |
| SVT_PCIE_UI_DISPLAY_NAME                  | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_HIERARCHY_NUMBER              | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_ENABLE_SHADOW_MEMORY_CHECKING | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_ENABLE_CFG_BLOCK              | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_MPIPE                         | √                                                       | √          | X                   | X                 |
| SVT_PCIE_UI_PHY_INTERFACE_TYPE            | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_DEVICE_IS_ROOT                | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_CONNECT_ACTIVE_VIP            | √                                                       | √          | √                   | √                 |
| SVT_PCIE_UI_DUT_IN_V2V_CTL_TB             | 0                                                       | 0          | 0                   | 0                 |
| SVT_PCIE_UI_PIPE_CLK_FROM_MAC             | √                                                       | √          | X                   | X                 |
| SVT_PCIE_UI_ENABLE_IO_SKEW                | √                                                       | 0          | 0                   | 0                 |
| SVT_PCIE_UI_SETUP_PS                      | √                                                       | 0          | 0                   | 0                 |
| SVT_PCIE_UI_HOLD_PS                       | √                                                       | 0          | 0                   | 0                 |
| SVT_PCIE_UI_SERIAL_CLK_TOLERANCE          | X                                                       | X          | √                   | X                 |
| SVT_PCIE_UI_PIPE_MAX_PCLK_SUPPORTED       | √                                                       | √          | X                   | X                 |

√ – Implies the parameter is valid and can accept any legal value.

X – Implies its a don't care.

0 – Implies the default value.



**Note** Any signal corresponding to lanes less than NUM\_PHYSICAL\_LANES should not be left floating. All unused input ports must be tied to 0, with the exception of \*\_elec\_idle\_n. Any unused \*\_elec\_idle\_n input ports must be tied to 1.

#### 10.2.4 Verilog HDL Module to SystemVerilog UVM Class Intercommunication

The svt\_PCIE\_if interface acts as a bridge between Verilog HDL based module and the SystemVerilog UVM class-based testbench. To accommodate the testbenches and DUT topologies, you can configure svt\_PCIE\_if. See [Table 10-2](#) for the list of parameters available for the testbench.

By using the svt\_PCIE\_if as a conduit to carry compile-time information from the Verilog module to UVM testbench, it eliminates the need for shared defines (for example, SVT\_PCIE\_MAX\_LINK\_WIDTH).

The parameters listed above are captured as variables in svt\_PCIE\_if. These variables allow the testbench to tune the values of (and/or constraints on) members of the svt\_PCIE\_device\_configuration class.



**Note** Irrespective of the topology of testbench (SERDES, PIPE, Single Link, or MultiLink) or the DUT type (PHY, RC, EP, Switch, and Repeater) the testbench must ensure that an svt\_PCIE\_if instance is not shared between two Verilog VIP HDL instances.

#### 10.2.5 Using a Virtual Interface Handle

Each Unified VIP model instance implements a method called update\_if\_variables(...). The testbench must invoke this method at time 0 (prior to invoking run\_test). This method copies the module parameter values listed previously into corresponding variables in svt\_PCIE\_if instance associated with the Unified VIP module instance. It also invokes uvm\_config\_db::set calls to pass the virtual interface handles for the active component. The testbench can leverage the information in the virtual interface handles to appropriately initialize the svt\_PCIE\_device\_configuration instance associated with the module instance. You must invoke method

svt\_PCIE\_device\_configuration::set\_initial\_values\_via\_unified\_vif to pass the handle of the virtual interface to the active VIP component.

- ❖ In one of the initial blocks, you must invoke `module_instance.update_if_variables(....)`.
- ❖ During the build phase of `uvm_test_top` instance (or its sub-environment)
  - ◆ Retrieve virtual svt\_PCIE\_if (that is, svt\_PCIE\_vif) interface handle by invoking `uvm_config_db::get(....)`.
  - ◆ Create an instance of svt\_PCIE\_device\_configuration class and associate this instance with the virtual interface handle retrieved in the previous step by invoking `svt_PCIE_device_configuration::set_initial_values_via_unified_vif(....)`. For more details, see svt\_PCIE\_device\_configuration class in the HTML documentation of class reference documentation.

- ◆ Modify the content of `svt_PCIE_Device_Configuration` instance and finally pass it to `svt_PCIE_Device_Agent` instance using `uvm_config_db::set(...)`.



**Note** You must not modify property `svt_PCIE_Device_Configuration::model_instance_scope`, its correct value is derived automatically during the execution of method `svt_PCIE_Device_Configuration::set_initial_values_via_unified_vif`.

The inputs to the method `update_if_variables` are as follows:

- ❖ bit [3:0] `port_id`: It is used to form a unique string required to store the `svt_PCIE_if` virtual handle in `uvm_config_db`.
- ❖ bit [7:0] `link_id`: It is used (conditionally) to form a unique string required to store the `svt_PCIE_if` virtual handle in `uvm_config_db`. The use of `link_id` value to form a string to pass the handle of active component interface is dependent on argument `use_link_id_prefix_for_active_if_name`.
- ❖ string `ac_parent_class_hier`: It is used to control the visibility of `svt_PCIE_if` virtual handle stored in `uvm_config_db`.
- ❖ bit `use_link_id_prefix_for_active_if_name`: If this bit is 1, the `link_id` will be used to create a string used to pass `svt_PCIE_if` type handle via `uvm_config_db`:
  - ◆ If 1, the string value used will be `link_<link_id as %0d>_vif_< port_id as %0d>`
  - ◆ If 0, the string value used will be `vif_< port_id as %0d>`

## 10.2.6 Backward Compatibility With Existing Testbench

The use model and features of the unified testbench setup does not affect the existing test cases and sequences in any way. The proposed changes affect only the connection style between VIP and DUT.

## 10.2.7 Installing the Unified VIP Example

To install the example, perform the following steps (assuming you have downloaded the PCIe VIP model and set up all licensing and access to the VCS simulator):

1. Install the example. At the command line, invoke the following. The location `<design_dir>` is the location you will install the example.

```
$DESIGNWARE_HOME/bin/dw_vip_setup -path <design dir> -e  
pcie_svt/tb_PCIE_SVT_UVM_UNIFIED_VIP_SYS -svtb
```

2. Change working directory to the installed example:

```
cd <design dir>/>/examples/sverilog/pcie_svt/tb_PCIE_SVT_UVM_UNIFIED_VIP_SYS
```

3. The README contains a description of the example.

4. To run the example, use the following command:

```
gmake USE_SIMULATOR=vcsvlog base_multi_link_test WAVES=1
```

## 10.2.8 Testbench Structure

### 10.2.8.1 Key Files

The following are the key files in the example:

- ❖ `top.sv`: Top Level testbench module contains a generic code applicable to all tests.

- ❖ `env/pcie_device_base_test.sv`: Extension of `uvm_test`, serves as base class for individual test cases.
- ❖ Individual test cases (extension of `pcie_device_base_test.sv`): The same sequence is used to demonstrate flow of packets in different topologies of the testbench.
  - ◆ `tests/ts.base_multi_link_test.sv`
  - ◆ `tests/ts.base_pipe_test.sv`
  - ◆ `tests/ts.base_pma_test.sv`
  - ◆ `tests/ts.base_serdes_test.sv`
  - ◆ `tests/ts.base_pie8_eq_test.sv`
  - ◆ `tests/ts.base_pipe5_test.sv`
  - ◆ `tests/ts.base_serdes5_test.sv`



**Note** These file names contain the name of the test for the `gmake` invocation. In this case, remove the “`ts`.” and the file extension (`.sv`)

- ❖ `hdl_interconnect_macros.sv`: Building blocks of code, used to simplify the integration effort.
- ❖ `top_test.sv`: Include file included in the `top.sv`. Contains Test/DUT topology specific code.

#### 10.2.8.2 Topology File Structure

The example testbench demonstrates the Unified PCIe VIP as part of different test topologies. The topology variations are captured in the following files that use macros from the file `hdl_interconnect_macros.sv`:

- ❖ `top.pcie_multi_link_topology.sv`
- ❖ `top.pcie_pma_topology.sv`
- ❖ `top.pcie_serdes_topology.sv`
- ❖ `top.pcie_pie8_eq_topology.sv`
- ❖ `top.pcie_pipe_topology.sv`
- ❖ `top.pcie_pipe5_topology.sv`
- ❖ `top.pcie_serdes5_topology.sv`

The `top_test.sv` file is a soft link pointing to one of the topology files. The link is updated by the Makefile based on the test name supplied by the user. These topology files contain the code to instantiate and connect the Unified VIP instances. The DUT instance is also part of the topology file.

#### 10.2.8.3 Helper Macros

The example testbench comes with a set of multi-line macros. These are shared as source code so that testbench can use them as starting point and enhance them. The help macros are in the `tb_pcie_svt_uvm_unified_vip_sys/hdl_interconnect_macros.sv` file.

Table 10-3 lists the available Helper macros.

**Table 10-3 Helper Macros**

| Macro Name                    | Arguments                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SVT_PCIE_ICM_CREATE_PORT_INST | port_id                               | <p>This macro requires a decimal value as input (<code>port_id</code>)</p> <ul style="list-style-type: none"><li>Creates instance of <code>svt_PCIE_if</code>. Uses <code>port_id</code> to generate an unique name for the instance.</li><li>Creates instance of PCIe single port device. Uses <code>port_id</code> to generate an unique name for the instance.</li><li>Declares set of parameters and ties them to a PCIe single port device instance. Uses <code>port_id</code> to associate the parameter with PCIe single port device instance. This parameter can be updated using a <code>defparam</code> and can also be used in “generate” statements residing in the module instantiating PCIe single port device.</li></ul> |
| SVT_PCIE_ICM_CREATE_LINK      | link_id,<br>spd_a,<br>spd_b           | <p>This macro accepts three inputs:</p> <ul style="list-style-type: none"><li>Decimal value as <code>link_id</code>.</li><li>Reference to instance of VIP module representing a port of the link.</li><li>Reference to instance of another VIP module representing peer port of the link.</li></ul> <p>It invokes the <code>update_if_variables</code> method for both instances of the VIP, and if required also handles VIP application layer connection requirements.</p> <p>The connection requirements take effect only when the VIP has its application layer enabled, but the lower stack of PHY, Data Link, and Transaction Layer is disabled (that is, VIP instance is being used to test RTL controller implementation).</p>  |
| SVT_PCIE_ICM_PIPE_PIPE_LINK   | link_id,<br>spipe_inst,<br>mpipe_inst | <p>This macro accepts three inputs:</p> <ul style="list-style-type: none"><li>Decimal value as <code>link_id</code>.</li><li>Reference to instance of VIP module representing a SPIPE port of the link.</li><li>Reference to instance of another VIP module representing MPIPE port of the link.</li></ul> <p>It is used to connect the pipe signals of two controllers (assumption is each of the pipe controller instances has a member called <code>vip_port_if</code> and this member is of type <code>svt_PCIE_if</code>).</p>                                                                                                                                                                                                     |

**Table 10-3 Helper Macros**

| <b>Macro Name</b>             | <b>Arguments</b>                      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SVT_PCIE_ICM_SER_SER_LIN_K    | link_id,<br>ser_inst_a,<br>ser_inst_b | This macro accepts three inputs:<br><ul style="list-style-type: none"> <li>• Decimal value as link_id.</li> <li>• Reference to instance of VIP module representing a Serial port of the link.</li> <li>• Reference to instance of another VIP module representing peer Serial port of the link.</li> </ul> It is used to connect the serial signals of two controllers (assumption is each of the controller instances has a member called <code>vip_port_if</code> and this member is of type <code>svt_PCIE_if</code> ). |
| SVT_PCIE_ICM_PMA_PMA_LIN_K    | link_id,<br>pma_inst_a,<br>pma_inst_b | This macro accepts three inputs:<br><ul style="list-style-type: none"> <li>• Decimal value as link_id.</li> <li>• Reference to instance of VIP module representing a PMA port of the link.</li> <li>• Reference to instance of another VIP module representing peer PMA port of the link.</li> </ul> It is used to connect the PMA signals of two controllers (assumption is each of the controller instances has a member called <code>vip_port_if</code> and this member is of type <code>svt_PCIE_if</code> ).          |
| SVT_PCIE_ICM_PIPE5_PIPE5_LINK | spipe_inst,<br>mpipe_inst             | This macro accepts two inputs:<br><ul style="list-style-type: none"> <li>• Reference to instance of VIP module representing a SPIPE port of the link.</li> <li>• Reference to instance of another VIP module representing MPIPE port of the link.</li> </ul> It is used to connect signals of MAC controller with PIPE5 interface to PIPE5 compliant PHY + MAC.                                                                                                                                                            |

#### 10.2.8.4 Single/Multi-Link Base Test (`pcie_device_base_test.sv`)

This is the top level user-defined component in the UVM hierarchy. It is extended from the `uvm_test` class. The existing setup is configured to support up to four (controlled through local macro `SVT_PCIE_MAX_NUM_LINKS`) active links running concurrently.

The code in the build method parses the `config_db` structure looking for reference to the virtual `svt_PCIE_if` handles. On successful retrieval of the interface handles of the required type, and adhering to naming convention, it does some basic checks on variables stored as part of these instances. If the checks are successful, then it creates a child component of type `pcie_device_unified_vip_instances_env`. Each such instance represents a link created in the topology file.

The code in `align_vif_and_cfg_prop(....)` ensures the default values and/or constraint limits of `svt_PCIE_device_configuration` members are in-line with the compile-time settings listed in topology files.

#### 10.2.8.5 Running Test Cases

The following are the command line invocation of all the test cases:

- ❖ gmake base\_pipe\_test
- ❖ gmake base\_pma\_test
- ❖ gmake base\_serdes\_test
- ❖ gmake base\_multi\_link\_test
- ❖ gmake base\_pie8\_eq\_test
- ❖ gmake base\_pipe5\_test
- ❖ gmake base\_serdes5\_test

### 10.2.9 DUT Integration

The reference model shown in this section is a PIPE interface, but the same can be applied to PMA and Serial interfaces.

The following figure represents the content of the *top\_PCIE\_pipe\_topology.sv* (single link EP DUT) in graphical form.



If you want to replace EP DUT (SPD\_1 instance) with the RTL implementation, then perform the following steps:

1. Create a new topology file similar to the one provided in the *example* directory. Instantiate DUT module in the topology file.
  2. Ensure that the VIP instance that is being replaced by DUT does not drive the signal interface. To achieve this goal, do not exclude or comment the VIP instance. Instead follow either step 3. or step 4.
  3. Disable the Active Component of Unified VIP.
- For example, if you want to disable a VIP instance with instance name as `spd_1: defparam SVT_PCIE_UI_CONNECT_ACTIVE_VIP_P1=0`.
4. After modifying the settings as described in step 3., connect DUT ports to the appropriate sub-interface of Unified PCIe VIP interface (`port_if_1`).
  5. Create extensions of tests that need to run with a DUT as new files under a tests folder. Include these tests in the newly created topology file.
  6. Update the build method of the extended test to correctly populate the settings of `cust_cfg[0].endpoint_cfg`. This step is similar to non-unified or legacy testbench.

### 10.2.9.1 Topology and Interconnect Macros Files

The following figures are taken from `top_PCIE_multi_link_topology.sv`.

- ❖ Interconnect Macro file - `hdl_interconnect_macros.sv`
  - ◆ `hdl_interconnect_macros.sv` provides macro definitions and serves a common point to set key parameters of several VIP ports. Parameters with their default values are shown in the following screenshot. These can be updated on a per VIP instance basis using `defparam` overrides in the topology files.

```
`define SVT_PCIE_ICM_CREATE_PORT_INST(port_num) \
parameter SVT_PCIE_UI_PCIE_SPEC_VER_P`port_num`` = `SVT_PCIE_UI_PCIE_SPEC_VER_3_0` \
parameter SVT_PCIE_UI_PIPE_SPEC_VER_P`port_num`` = `SVT_PCIE_UI_PIPE_SPEC_VER_4_3` \
parameter SVT_PCIE_UI_NUM_PHYSICAL_LANES_P`port_num`` = 32; \
parameter SVT_PCIE_UI_NUM_PMA_INTERFACE_BITS_P`port_num`` = 10; \
parameter SVT_PCIE_UI_NUM_PIPE_INTERFACE_BITS_P`port_num`` = 32; \
parameter SVT_PCIE_UI_HIERARCHY_NUMBER_P`port_num`` = 0; \
parameter SVT_PCIE_UI_MPPIPE_P`port_num`` = 1; \
parameter SVT_PCIE_UI_PHY_INTERFACE_TYPE_P`port_num`` = `SVT_PCIE_UI_PHY_INTERFACE_TYPE_SERDES` \
parameter SVT_PCIE_UI_DEVICE_IS_ROOT_P`port_num`` = 1; /*behave as a root complex */ \
parameter SVT_PCIE_UI_ENABLE_SHADOW_MEMORY_CHECKING_P`port_num`` = 0; /*If set, applications will check memory reads against the shadow memory*/ \
parameter SVT_PCIE_UI_ENABLE_CFG_BLOCK_P`port_num`` = 1; \
parameter SVT_PCIE_UI_DUT_IN_V2V_CTL_TB_P`port_num`` = 0; /*Ignore this parameter, will be deprecated in future */ \
parameter SVT_PCIE_UI_CONNECT_ACTIVE_VIP_P`port_num`` = 1; \
parameter SVT_PCIE_UI_PIPE_CLK_FROM_MAC_P`port_num`` = 1'b0; \
parameter SVT_PCIE_UI_CONNECT_DOWNSTREAM_PORT_MONITOR_P`port_num`` = 1'b0; \
parameter SVT_PCIE_UI_CONNECT_UPSTREAM_PORT_MONITOR_P`port_num`` = 1'b0; \
svt_pcie_if port_if_`port_num``(); \
svt_pcie_single_port_device_agent_hdl spd_`port_num``(port_if_`port_num``); \
`ifndef VCS \
  defparam spd_`port_num``.SVT_PCIE_UI_DISPLAY_NAME = {"spd_`port_num``"}; \
`else \
  defparam spd_`port_num``.SVT_PCIE_UI_DISPLAY_NAME = $sformatf("spd_%0d.",port_num); \
`endif \
  defparam spd_`port_num``.SVT_PCIE_UI_ENABLE_CFG_BLOCK = SVT_PCIE_UI_ENABLE_CFG_BLOCK_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_PCIE_SPEC_VER = SVT_PCIE_UI_PCIE_SPEC_VER_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_PIPE_SPEC_VER = SVT_PCIE_UI_PIPE_SPEC_VER_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_NUM_PHYSICAL_LANES = SVT_PCIE_UI_NUM_PHYSICAL_LANES_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_NUM_PMA_INTERFACE_BITS = SVT_PCIE_UI_NUM_PMA_INTERFACE_BITS_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_NUM_PIPE_INTERFACE_BITS = SVT_PCIE_UI_NUM_PIPE_INTERFACE_BITS_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_HIERARCHY_NUMBER = SVT_PCIE_UI_HIERARCHY_NUMBER_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_MPPIPE = SVT_PCIE_UI_MPPIPE_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_PHY_INTERFACE_TYPE = SVT_PCIE_UI_PHY_INTERFACE_TYPE_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_DEVICE_IS_ROOT = SVT_PCIE_UI_DEVICE_IS_ROOT_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_ENABLE_SHADOW_MEMORY_CHECKING = SVT_PCIE_UI_ENABLE_SHADOW_MEMORY_CHECKING_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_DUT_IN_V2V_CTL_TB = SVT_PCIE_UI_DUT_IN_V2V_CTL_TB_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_CONNECT_ACTIVE_VIP = SVT_PCIE_UI_CONNECT_ACTIVE_VIP_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_PIPE_CLK_FROM_MAC = SVT_PCIE_UI_PIPE_CLK_FROM_MAC_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_CONNECT_DOWNSTREAM_PORT_MONITOR = SVT_PCIE_UI_CONNECT_DOWNSTREAM_PORT_MONITOR_P`port_num``; \
  defparam spd_`port_num``.SVT_PCIE_UI_CONNECT_UPSTREAM_PORT_MONITOR = SVT_PCIE_UI_CONNECT_UPSTREAM_PORT_MONITOR_P`port_num``; \

```

- ◆ Macro definition of link creation between two VIP instances.

```
// The following macro takes care of forming a link using 2 instances of interface objects connected to VIP.
// The link is uniquely identified using link_id argument. It also invokes the uvm_config_db calls
// (via update_if_variables) to pass the virtual interface handles to the class world.
`define SVT_PCIE_ICM_CREATE_LINK(link_id,spd_a,spd_b) \
    tri link_`{link_id}`_clkreq_n; \
initial begin \
    spd_a.update_if_variables(4'h0,link_id,"uvm_test_top","uvm_test_top"); \
    spd_b.update_if_variables(4'h1,link_id,"uvm_test_top","uvm_test_top"); \
end \
always @(*) spd_a.vip_port_if.app_if.reset = (spd_a.vip_port_if.phy_interface_type == PHY_INTERFACE_TYPE_APP) ? common_pwr_on_reset : 1'bz; \
always @(*) spd_b.vip_port_if.app_if.reset = (spd_b.vip_port_if.phy_interface_type == PHY_INTERFACE_TYPE_APP) ? common_pwr_on_reset : 1'bz; \
always @(*) spd_a.vip_port_if.app_if.appl_clk = (spd_a.vip_port_if.phy_interface_type == PHY_INTERFACE_TYPE_APP) ? spd_b.vip_port_if.app_if.appl_clk : 1'bz; \
always @(*) spd_b.vip_port_if.app_if.appl_clk = (spd_b.vip_port_if.phy_interface_type == PHY_INTERFACE_TYPE_APP) ? spd_a.vip_port_if.app_if.appl_clk : 1'bz; \

```

◆ Lane-to-Lane connection for PIPE.

```
// The following macro is used by user to cross connect signals of spipe interface
// with that of a mpipe interface
`define SVT_PCIE_ICM_PIPE_PIPE_LINK(link_id,spipe_inst,mpipe_inst) \
`SVT_PCIE_ICM_PIPE_PIPE_COMMON_CODE(link_id,spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 0) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 1) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 2) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 3) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 4) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 5) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 6) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 7) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 8) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 9) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 10) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 11) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 12) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 13) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 14) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 15) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 16) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 17) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 18) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 19) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 20) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 21) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 22) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 23) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 24) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 25) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 26) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 27) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 28) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 29) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 30) \
`SVT_PCIE_ICM_PIPE_PIPE_PER_LANE_CODE(spipe_inst.vip_port_if.pipe_if , mpipe_inst.vip_port_if.pipe_if , 31) \

```

- ◆ Lane-to-Lane connection for Serial connection.

```
// The following macro is used by user to cross connect signals of one serdes interface instance
// to another serdes interface instance
`define SVT_PCIE_ICM_SER_SER_LINK(link_id,ser_inst_a,ser_inst_b) \
  assign link_`link_id`_clkreq_n = ser_inst_a.vip_port_if.ser_if.clkreq_n; \
  assign link_`link_id`_clkreq_n = ser_inst_b.vip_port_if.ser_if.clkreq_n; \
  always @(*) begin \
    ser_inst_a.vip_port_if.ser_if.reset = common_pwr_on_reset; \
    ser_inst_b.vip_port_if.ser_if.reset = common_pwr_on_reset; \
  end \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 0) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 1) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 2) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 3) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 4) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 5) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 6) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 7) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 8) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 9) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 10) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 11) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 12) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 13) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 14) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 15) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 16) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 17) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 18) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 19) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 20) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 21) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 22) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 23) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 24) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 25) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 26) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 27) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 28) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 29) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 30) \
`SVT_PCIE_ICM_SER_SER_IF_PER_LANE_CODE(ser_inst_a , ser_inst_b , 31) \
```

- ◆ Lane-to-Lane connection for 10-bit PMA connection.

```
// The following macro is used by user to cross connect signals of one pma interface instance
// with that of another pma interface instance
`define SVT_PCIE_ICM_PMA_PMA_LINK(link_id,pma_inst_a,pma_inst_b) \
    assign link_`link_id`_clkreq_n = pma_inst_a.vip_port_if.pma_if.clkreq_n ; \
    assign link_`link_id`_clkreq_n = pma_inst_b.vip_port_if.pma_if.clkreq_n ; \
    always @(*) begin \
        pma_inst_a.vip_port_if.pma_if.reset = common_pwr_on_reset; \
        pma_inst_b.vip_port_if.pma_if.reset = common_pwr_on_reset; \
    end \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 0) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 1) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 2) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 3) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 4) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 5) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 6) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 7) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 8) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 9) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 10) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 11) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 12) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 13) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 14) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 15) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 16) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 17) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 18) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 19) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 20) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 21) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 22) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 23) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 24) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 25) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 26) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 27) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 28) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 29) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 30) \
`SVT_PCIE_ICM_PMA_IF_PER_LANE_CODE(pma_inst_a.vip_port_if.pma_if , pma_inst_b.vip_port_if.pma_if , 31) \\\
```

- ❖ Topology File – *top\_PCIE\_multi\_link\_topology.sv*
  - ◆ Connection between *spd\_0* and *spd\_1* done in the topology file.



Here, *spd\_1* can be disabled when integration with a RTL DUT by setting the parameter *SVT\_PCIE\_UI\_CONNECT\_ACTIVE\_VIP\_P1* to 0.



### 10.2.10 Known Limitations

- ❖ VMM is not supported.
- ❖ No HTML documentation for new prototype.
- ❖ Lack of Makefile infrastructure to support command line controls for individual link properties.
- ❖ The following signals are implemented as shared signal even though later PIPE specification versions require it to be on per lane basis (except for PIPE5 signal interconnect)
  - ◆ PowerDown
  - ◆ Elasticity Buffer Mode
  - ◆ PclkChangeOk
  - ◆ PclkChangeAck
  - ◆ AsyncPowerChangeAck



- The macros used in file *top.pcie\_pipe5\_topology.sv* are similar (but independent) to the ones explained in screenshots for *top.pcie\_pipe\_topology.sv*.
- The macros used in file *top.pcie\_serdes5\_topology.sv* are exactly the same as the ones used in *top.pcie\_serdes\_topology.sv*.

### 10.3 Check 'x' or 'z' on Signal

This feature checks that the signals at the interface are not driven to 'x' or 'z' state after reset de-assertion. The feature is command line controllable. It is disabled by default, it can be enabled in the Unified TB

(tb\_PCIE\_svt\_uvm\_unified\_vip\_sys) by adding a macro `+define+SVT_ENABLE_XCHECK=1` in the compile flow.

This check is used to check the case when a signal is not connected or if the signal is wrongly driven to tristate.

It is implemented on the principle that once Unified VIP is out of power on reset (issued via "reset" node) it can check all applicable (based on `svt_PCIE_device_configuration` content) interface signals for known values.

In case of signal driven to x or z, the error signature will be as follows.

```
[Unknown Value Observed by X Checker instance] offending signal is connected to
interface instance
test_top.spd_1.mpipe.port0.pipe_if.u_xcheck_pipe_if_rx_eq_in_progress_0.unnamed$$_1.
Please refer to instance name for further details.
```

In the above example message, the VIP is complaining about interface signal `pipe_if_rx_eq_in_progress_0`.

- ❖ Limitation:
  - ◆ This check is not applicable for conventional TBs.
  - ◆ It is applicable to UVM and OVM methodologies only.



# 11 Using the PCIe Verification IP

---

This chapter discusses the following topics:

- ❖ SystemVerilog UVM Example Testbenches
- ❖ Installing and Running the Examples
- ❖ Error Message Usage
- ❖ Setting VIP Configurations
- ❖ UVM Reporting Levels
- ❖ Controlling Verbosity From the Command Line
- ❖ Resetting the PCIe VIP
- ❖ Creating and Using Custom Applications
- ❖ Backdoor Access to Completion Target Configuration Space
- ❖ Setting VIP Lanes for Receiver Detect
- ❖ Using ASCII Signals
- ❖ Using the Ordering Application
- ❖ Customizing the Transaction Log Output
- ❖ Target Application
- ❖ Requester Application
- ❖ What Are Blocking and Non-blocking Reads in PCIe SVT?
- ❖ Using Service Class Reset App
- ❖ Using FLR
- ❖ Programming Hints and Tips
- ❖ Up/Down Configure
- ❖ Lane Reversal
- ❖ Lane Reversal with Different Link Width Configurations
- ❖ User-Supplied Memory Model Interface

- ❖ External Clocking and Per Lane Clocking for Serial Interface
- ❖ Callbacks
- ❖ Generating MSI/MSIx with PCIe VIP

## 11.1 SystemVerilog UVM Example Testbenches

This section describes SystemVerilog UVM example testbenches that show general usage for various applications. A summary of the examples is listed in [Table 11-1](#).

**Table 11-1 SystemVerilog Example Summary**

| Example Name                    | Level    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tb_pcie_svt_uvm_unified_vip_sys | Advanced | <p>The example consists of the following:</p> <ul style="list-style-type: none"> <li>• A top-level module, which includes tests, instantiates interfaces, HDL interconnect wrapper, generates system clock, and runs the tests</li> <li>• A base test, which is extended to create a directed and a random test</li> <li>• The tests create a testbench environment, which in turn creates PCIe System Env</li> <li>• PCIe System Env is configured with Root Complex and one Endpoint</li> </ul> |

The examples are located at:

\$DESIGNWARE\_HOME/vip/svt/pcie\_svt/latest/examples/sverilog/

Examples may be installed in your local design directory following the instructions in the installation chapter.

The tests in the unified example (tb\_pcie\_svt\_uvm\_unified\_vip\_sys) are:

- ❖ ts.address\_translation\_test.sv
- ❖ ts.base\_multi\_link\_test.sv
- ❖ ts.base\_pie8\_eq\_test.sv
- ❖ ts.base\_pipe\_in\_serdes\_arch\_mode\_test.sv
- ❖ ts.base\_pipe5\_test.sv
- ❖ ts.base\_pipe\_test.sv
- ❖ ts.base\_pma\_test.sv
- ❖ ts.base\_serdes5\_test.sv
- ❖ ts.base\_serdes\_test.sv
- ❖ ts.basic\_ptm\_test.sv

## 11.2 Installing and Running the Examples

Below are the steps for installing and running example, tb\_pcie\_svt\_uvm\_unified\_vip\_sys. Similar steps are applicable for other examples:

1. Install the example using the following command line:

```
% cd <location where example is to be installed>
% mkdir design_dir <provide any name of your choice>
% $DESIGNWARE_HOME/bin/dw_vip_setup -path ./design_dir -e
    pcie_svt/tb_pcie_svt_uvm_unified_vip_sys -svtb
```

This installs the example under:

<design\_dir>/examples/sverilog/pcie\_svt/tb\_pcie\_svt\_uvm\_unified\_vip\_sys

2. Use either one of the following to run the testbench:

a. Use the Makefile:

The following tests are provided in the "tests" directory:

- ✧ ts.address\_translation\_test.sv
- ✧ ts.base\_multi\_link\_test.sv
- ✧ ts.base\_pie8\_eq\_test.sv
- ✧ ts.base\_pipe\_in\_serdes\_arch\_mode\_test.sv
- ✧ ts.base\_pipe5\_test.sv
- ✧ ts.base\_pipe\_test.sv
- ✧ ts.base\_pma\_test.sv
- ✧ ts.base\_serdes5\_test.sv
- ✧ ts.base\_serdes\_test.sv
- ✧ ts.basic\_ptm\_test.sv

To run the `ts.base_serdes_test.sv` test, for example, do following:

```
gmake USE_SIMULATOR=vcsvlog base_serdes_test WAVES=1
```

To see more options, invoke "gmake help".

b. Use the sim script:

To run the `ts.base_pipe_test.sv` test, for example, do following:

```
./run_pcie_svt_uvm_unified_vip_sys -w base_pipe_test vcsvlog
```

To see more options, invoke `./run_pcie_svt_uvm_unified_vip_sys -help`.

For more details about installing and running the example, refer to the README file in the example, located at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/examples/sverilog/tb_pcie_svt_uvm_unified_vip_sys/README`

or

<design\_dir>/examples/sverilog/pcie\_svt/tb\_pcie\_svt\_uvm\_unified\_vip\_sys/README



For `dw_vip_setup` generated scripts and Makefiles, the waves generation is currently supported only for VCS.

### 11.2.1 Running the Example with +includer+

In the current setup, you install the VIP under `DESIGNWARE_HOME` followed by creation of a design directory which contains the versioned VIP files. With every newer version of the already installed VIP requires the design directory to be updated. This results in:

- ◆ Consumption of additional disk space
- ◆ Increased complexity to apply patches

The new alternative approach of directly pulling in all the files from `DESIGNWARE_HOME` eliminates the need for design directory creation. VIP version control is now in the command line invocation.

The following code snippet shows how to run the basic example from a script:

```
cd <testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/
// To run the example using the generated run script with +includer+
./run_pcie_svt_uvm_unified_vip_sys -verbose -includer base_pipe_test vcsvlog
```

For example, the following compile log snippet shows the paths and defines set by the new flow to use VIP files right out of `DESIGNWARE_HOME` instead of `design_dir`.

```
vcs -l ./logs/compile.log -q -Mdir=../output/csrc
+define+DESIGNWARE_INCDIR=<DESIGNWARE_HOME> \
+define+SVT_LOADER_UTIL_ENABLE_DWHOME_INCDIRS
+includer+<DESIGNWARE_HOME>/vip/svt/pcie_svt/S-2021.06/sverilog/include \
-ntb_opts uvm -full164 -sverilog +define+UVM_DISABLE_AUTO_ITEM_RECORDING
+define+UVM_PACKER_MAX_BYTES=8192 \
-debug_acc -timescale=1ns/1fs +libext+.v+.sv -y <testbench_dir>/src/verilog/vcs \
-y <testbench_dir>/src/sverilog/vcs +define+UVM_VERDI_NO_COMPWAVE \
-debug_acc -P pli.tab msglog.o +define+SVT_UVM_TECHNOLOGY +define+SYNOPSYS_SV
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/. \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/.../...
/env \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/.../en
v \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/env \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/dut \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/hdl_i
nterconnect \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/lib \
+includer+<testbench_dir>/examples/sverilog/pcie_svt/tb_pcie_svt_uvm_unified_vip_sys/tests \
\
-o ./output/simvcssvlog -f top_files -f hdl_files
```



For VIPs with dependency, include the `+includer+` for each dependent VIP.

#### 11.2.1.1 Supported Methodologies with Simulators

[Table 11-2](#) lists the methodologies supported with simulators.

**Table 11-2 Supported Methodologies with Simulators**

| Methodology | VCS       | MTI       | IUS           |
|-------------|-----------|-----------|---------------|
| UVM         | Supported | Supported | Not Supported |

**Table 11-2 Supported Methodologies with Simulators**

| Methodology | VCS           | MTI           | IUS           |
|-------------|---------------|---------------|---------------|
| OVM         | Supported     | Supported     | Not supported |
| VMM         | Supported     | Supported     | Not supported |
| HDL         | Not Supported | Not Supported | Not Supported |

## 11.3 Error Message Usage

The control of check and error messages from the model is handled through the svt\_err\_check class instance "err\_check" within the agent. class. Following is a message you might see from the model.

```
UVM_ERROR svt_err_check_stats.sv(817) @ 226895734.80 ps:  
uvm_test_top.env.root.port0.dl0  
[register_fail:AC_DL:PROTOCOL:dl_receive_nullified_tlp_lcrc] - Received TLP with EDB  
delimiter but bad LCRC = 0x8fb52aea, expected LCRC = 0x8fb52ae9
```

The main components of the message are:

- ❖ **Reporter:** "uvm\_test\_top.env.root.port0.dl0"
- ❖ **ID:** "register\_fail:AC\_DL:PROTOCOL:dl\_receive\_nullified\_tlp\_lcrc"
- ❖ **Message:** "Received TLP with EDB delimiter but bad ..."

The check interface gives you the ability to change how the message is issued based on the unique message ID. For example, you can write the following code to demote the ERROR message to a NOTE/UVM\_INFO message:

```
env.root.err_check.set_default_fail_effects("^AC_DL", "", svt_err_check_stats::NOTE,  
"dl_receive_nullified_tlp_lcrc$");
```

The resulting output is now:

```
UVM_INFO svt_err_check_stats.sv(817) @ 226895734.80 ps: uvm_test_top.env.root.port0.dl0  
[dl_receive_nullified_tlp_lcrc] - Received TLP with EDB delimiter but bad LCRC =  
0x8fb52aea, expected LCRC = 0x8fb52ae9
```

Users can change the behavior of the specified message by modifying the "effect" argument (argument three in the set\_default\_fail\_effects() method), which is of type svt\_err\_check\_stats::fail\_effect\_enum. The values available with the fail\_effect\_enum are:

- ❖ **IGNORE.** Ignore the check result.
- ❖ **VERBOSE.** Generate verbose message for the check results.
- ❖ **DEBUG.** Generate debug message for the check results.
- ❖ **NOTE.** Generate note message for the check results.
- ❖ **WARNING.** Generate warning message for the check results.
- ❖ **ERROR.** Generate error message for the check results.
- ❖ **EXPECTED.** Failure is expected.



**Hint** The NOTE, DEBUG, and VERBOSE settings equate to UVM\_INFO verbosity settings of UVM\_LOW, UVM\_HIGH, and UVM\_FULL respectively.

In addition to changing how messages are reported to you, the svt\_err\_check\_stats class has additional features for you to track messages:

- ❖ **exec\_count**. Tracks the number of times that a given check has been executed.
- ❖ **pass\_count**. Tracks the number of times that a given check has PASSED.
- ❖ **fail\_ignore\_count**. Tracks the number of times the check has failed, with IGNORED effect.
- ❖ **fail\_verbose\_count**. Tracks the number of times the check has failed, with VERBOSE effect.
- ❖ **fail\_debug\_count**. Tracks the number of times the check has failed, with DEBUG effect.
- ❖ **fail\_note\_count**. Tracks the number of times the check has failed, with NOTE effect.
- ❖ **fail\_warn\_count**. Tracks the number of times the check has failed, with WARNING effect.
- ❖ **fail\_err\_count**. Tracks the number of times the check has failed, with ERROR or FATAL effect.
- ❖ **fail\_expected\_count**. Tracks the number of times the check has failed, with EXPECTED effect.

To check the statistics count, get a handle to the stats container, using the same lookup strings as with

```
svt_err_check_stats check_stats = env.root.err_check.find("^DL$", "",  
"register_fail:DL:dl_receive_nullified_tlp_lcrc$");
```

The "check\_stats.fail\_note\_count" would now be incremented by 1.

To disable all tracking of an ID (no statistics or coverage collection), which would supersede the above call, do the following:

```
env.root.err_check.disable_checks("^DL$", "",  
"register_fail:DL:dl_receive_nullified_tlp_lcrc$");
```

The "^" and "\$" in the SVT call are the regex meta-character start/end string terminators respectively. The string arguments to the SVT err\_check interface are regex expressions. Blanks are considered wildcards.

The "" argument in the previous example is the sub\_group. The complete ID is register\_fail:[<group>]:[<sub\_group>.]<unique\_id>. The sub\_group may or may not appear in all cases. You can use the meta-characters when trying to isolate specific groups, sub\_groups, and IDs.

## 11.4 Setting VIP Configurations

The following steps can help you get started in configuring the model.

1. SetAllocated Credits
  - ◆ TL: Set initial credits for a VC
  - ◆ Use: svt\_PCIE\_tL\_configuration
2. SetVCEnable
  - ◆ TL: Enable / Disable VCs; disabled by default
  - ◆ Use: svt\_PCIE\_tL\_service\_set\_vc\_en\_sequence
3. SetTrafficClassMap
  - ◆ TL: Setup TC map

- ◆ Use: svt\_PCIE\_tL\_configuration
4. AddMemAddrAppIdMapEntry
    - ◆ TL: Sets AP ID for Memory target address range
    - ◆ Use: svt\_PCIE\_mem\_target\_service\_mem\_range\_sequence
  5. SetLinkEnable
    - ◆ DL: Enable / Disable the DL
    - ◆ Use: svt\_PCIE\_DL\_service\_link\_en\_sequence
  6. SetSupportedSpeeds
    - ◆ PL: Set supported speed for link training / default speed if link training is disabled
    - ◆ Use: svt\_PCIE\_pl\_phy\_configuration
  7. SetLinkWidth
    - ◆ PL: maximum link width, also initiates LTSSM negotiation
    - ◆ Use: svt\_PCIE\_pl\_phy\_configuration
  8. SetLinkEnable
    - ◆ PL: Enable / Disable the PL link
    - ◆ Use: svt\_PCIE\_pl\_service\_link\_en\_sequence

Example configuration code:

```
class pcie_shared_cfg extends uvm_object;
    rand svt_PCIE_device_configuration root_cfg;
    ...
    function new(string name = "pcie_shared_cfg");
        super.new(name);
        this.root_cfg = new("root_cfg");
        root_cfg.device_is_root = 1;
        root_cfg_PCIE_spec_ver = svt_PCIE_device_configuration:PCIE_SPEC_VER_2_1;
        root_cfg_PCIE_cfg.pl_cfg.link_width = 1;
        root_cfg_PCIE_cfg.pl_cfg.target_speed = `SVT_PCIE_SPEED_2_5_G;
        root_cfg_PCIE_cfg.pl_cfg.skip_polling_active = 1;
    endfunction : new
endclass : pcie_shared_cfg
```

Example to set credits.

```
class myTest extends uvm_test;
    ...
    virtual function void build_phase(uvm_phase phase);
        super.build_phase(phase);
        // Setup Initial TX Credits
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_p_hdr_tx_credits[0] = 104;
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_p_data_tx_credits[0] = 1020;
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_np_hdr_tx_credits[0] = 105;
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_np_data_tx_credits[0] = 1021;
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_cpl_hdr_tx_credits[0] = 106;
        cust_cfg.root_cfg_PCIE_cfg.tL_cfg.init_cpl_data_tx_credits[0] = 1022;
    ...
endclass
```

Example to enable the link:

```
class pcie_traffic_sequence extends svt_PCIE_device_system_virtual_base_sequence;
  ...
  task body();
    svt_PCIE_dl_service_set_link_en_sequence link_en_seq;
    svt_PCIE_pl_phy_service_set_phy_en_sequence phy_en_seq;
    ...
    `uvm_do_on_with(link_en_seq, p_sequencer.root_virt_seqr.mac_virt_seqr.dl_seqr,
                     {link_en_seq.enable == 1'b1;})
  ...
endtask : body
endclass : pcie_traffic_sequence
```

## 11.5 UVM Reporting Levels

The UVM verbosity level for message logging is set using the `+UVM_VERBOSITY` runtime option. For each verbosity level, the items that the UVM API prints to the log file are shown below.

- ❖ `UVM_NONE` – Only print error messages
- ❖ `UVM_LOW` – Print important messages that are not error messages
- ❖ `UVM_MEDIUM` – Drivers and monitors print transactions they transmit and receive
- ❖ `UVM_HIGH` – Print more detailed messages about component operation
- ❖ `UVM_FULL` – Print internal debug messages

## 11.6 Controlling Verbosity From the Command Line

The VIP can use all the UVM command line options for control of verbosity. The following table summarizes the options available. Please refer to the UVM Reference Guide for more details.

UVM Options are shown below.

**Table 11-3 UVM Verbosity Options**

| UVM Option                      | Description                                                               |
|---------------------------------|---------------------------------------------------------------------------|
| <code>+UVM_VERBOSITY</code>     | setting for all components                                                |
| <code>+uvm_set_verbosity</code> | Granular control by component and phase or time                           |
| <code>+uvm_set_action</code>    | Action to take upon message (None, display, log, count, stop, exit, hook) |
| <code>+uvm_set_severity</code>  | Severity override (upgrade or downgrade)                                  |

The remainder of this section will focus on verbosity control from the command line.

### Globally

The PCIe VIP is compliant with the verbosity options within UVM. The `uvm_cmdline_processor` looks for the `+UVM_VERBOSITY` option on the simulator command line, and will set the initial verbosity for all UVM components to the supplied level.

Examples:

```
// Display only UVM_FATAL, UVM_ERROR, UVM_WARNING
simv +UVM_TESTNAME=base_pipe_test +UVM_VERBOSITY=UVM_NONE
// Display all messages
simv +UVM_TESTNAME=base_pipe_test +UVM_VERBOSITY=UVM_FULL
```

### Per Component:

Also supported is the `+uvm_set_verbosity` which allows for more granular control. The command breakdown is as follows:

```
+uvm_set_verbosity=<component_name>, <id>, <verbosity>, <phase_name>
```

or

```
+uvm_set_verbosity=<component_name>, <id>, <verbosity>, time, <time>
```

Note, `<id>` can either be `all`, `_ALL_` or a specific message id.

Example:

```
// Set all components to UVM_NONE except for the t1 which is at UVM_LOW
simv +UVM_TESTNAME=base_pipe_test +UVM_VERBOSITY=UVM_NONE \
+uvm_set_verbosity=uvm_test_top.env.root.port0.t10,_ALL_,UVM_LOW,time,0
// Set all components to UVM_NONE except for root
simv +UVM_TESTNAME=base_pipe_test +UVM_VERBOSITY=UVM_NONE \
+uvm_set_verbosity=uvm_test_top.env.root.*,_ALL_,UVM_LOW,time,0
```

Another option for component control which applies only to SVT based VIPs is the `+vip_verbosity` option:

Example:

```
// UVM_NONE for all with the exception that all instances of the dl are at UVM_LOW and
// all instances of the t1 are at UVM_FULL
simv +vip_verbosity=svt_pcnie_dl:UVM_LOW,svt_pcnie_t1:UVM_FULL
```

### SVT Verbosity relationship to UVM Severity Levels

```
`define SVT_FATAL_VERBOSITY UVM_NONE
`define SVT_ERROR_VERBOSITY UVM_NONE
`define SVT_WARNING_VERBOSITY UVM_NONE
`define SVT_NORMAL_VERBOSITY UVM_LOW
`define SVT_TRACE_VERBOSITY UVM_MEDIUM
`define SVT_DEBUG_VERBOSITY UVM_HIGH
`define SVT_VERBOSE_VERBOSITY UVM_FULL
```

## 11.7 Resetting the PCIe VIP

Power-on reset to the VIP model uses the reset signal which is active high. Reset signal must be de-asserted at time 0 such that a posedge is seen by the VIP. Reset should be asserted for at least 100 ns. Once de-asserted, it should remain de-asserted for the remainder of the simulation. Do not attempt to assert VIP reset to re-initialize the VIP. Do not attempt to configure the VIP until the reset has been de-asserted.

When VIP model is in SPIPE mode, the `attached_pipe_reset_n` signal needs to be de-asserted (0->1) after the above power-on reset sequence has occurred. Also, `pipe_pclk` signal has to be stable (that is, toggling) before both reset and `attached_pipe_reset_n` signals are de-asserted.

To perform a reset of the DUT in mid-simulation, only the DUT should be reset as illustrated in the following example code. The VIP will detect the change on the bus and move to Detect. Training will resume and the bus will recover. Thus, for proper DUT verification, it is advisable to separate the VIP model reset from the DUT reset.

### Example Code:

```
/** Signal to generate the reset */
bit vip_reset;

// -----
/** 
 *  Setup the VIP reset.
 */
// -----
initial begin
    $timeformat(-9,5, " ns", 12);
    test_top.vip_reset = 1;
    #200;
    test_top.vip_reset = 0;
end
```

In a typical scenario, the following will happen:

1. Initialize and bring up link to stable after reset (normal config sequence)
2. Run traffic
3. Take down the link and check both IP/VIP are in link-down state
4. Bring link-up and check both IP/VIP are in a link-up state
5. Run traffic and verify all is well.

The `svt_PCIE_Device_Virtual_Reset_Sequence` class will perform a mid simulation reset as described in the previous steps. This sequence implements Reset. This class resets the VIP by doing the following:

- ❖ Sets the hotplug mode to unplugged in the PL.
- ❖ Calls `RESET_APP` on all of the applications.

Note that in order to start up the LTSSM again, the user will have to use a PL service call to set the hotplug mode to `HOTPLUG_DETECT`.

The model reset supports the following actions:

- ❖ Clears all of the Tx and Rx packet queues in the Transaction Layer. This deletes any completions in progress.
- ❖ Clears all packets queued in the `driver_app`, `requester_app`, `target_app`, and `svt_PCIE_TLP`.
- ❖ All storage elements are cleared or garbage collected as appropriate.
- ❖ Deletes all packets that are in transit (for example, in the link layer or in the phy layer).
- ❖ Kills all completion timeouts in transaction layer.
- ❖ Terminates compliance checks.

- ❖ Resets the LTSSM back to its default initial state (Detect).

**Note**

The test needs to wait for the VIP to be in an idle state (that is, no PIPE signal handshaking in progress) when changing VIP configuration during UNPLUG. The test can use the `is_pipe_idle` attribute in the `svt_PCIE_Pl_Status` class to determine when the VIP is idle.

## 11.8 Creating and Using Custom Applications

Custom applications and test sequences can be developed for the PCIe VIP analogous to that of the Driver, Requester, and Target. You can create applications that enable specific functionality not available through the built-in applications. Custom applications allow the user to interface to the TL with TLPs enabling end-user specific functionality.

Applications examples include SRIOV and address translation. User applications are instantiated as classes in the SVT testbench. User applications that send TLPs should communicate with the VIP's `tlp_seqr` TLP sequencer using a TLP sequence that generates TLPs from `svt_PCIE_Agent::tlp_seqr`.

User applications co-exist and run in parallel to the Synopsys-supplied applications. Alternatively, testbenches can emulate user applications using sequences that generate TLPs with unique application IDs. The sequences that generate these TLPs run on the `svt_PCIE_Agent::tlp_seqr` sequencer.

The `application_id` attribute of the TLP objects generated by that application is identified by this value. The `application_id` is available in `svt_PCIE_TLP::application_id`. Application IDs in the range 0 – 19h are reserved for VIP internal use. The testbench should ensure that the `application_id` used by the applications are unique.

### 11.8.1 Setting Up Application ID Maps

For traffic to be directed between the MAC and the user application, a routing map must be set up. In particular, for the TLP routing to work, application IDs must be mapped to specific memory/IO address ranges, message codes and so on. This can be accomplished using the `svt_PCIE_TL_Service` transactions. A sequence of this type will run on the `tl_seqr` of the device agent, as shown in [Example 11-1](#). Alternatively, the `application_id` to requester ID map is set up automatically by the VIP whenever a TLP with a specific RID and application ID is sent for the first time.

The following service transaction types can be used to set up application id maps:

```
ADD_MEM_ADDR_APPL_ID_MAP_ENTRY, ADD_IO_ADDR_APPL_ID_MAP_ENTRY  
ADD_AT_ADDR_APPL_ID_MAP_ENTRY, ADD_RID_MSG_CODE_APPL_ID_MAP_ENTRY  
ADD_RID_APPL_ID_MAP_ENTRY, ADD_CFG_BDF_APPL_ID_MAP_ENTRY
```

SEE the HTML reference documentation for more information on these service types.

#### Example 11-1

```
svt_PCIE_TL_Service add_mem_add_req;  
'uvm_do_with(add_mem_add_req, {service_type ==  
    svt_PCIE_TL_Service::ADD_MEM_ADDR_APPL_ID_MAP_ENTRY;  
    appl_id == 32'h21;  
    memory_addr == 0;  
    memory_window == 32'h1000;})
```

## 11.8.2 Using Testbench Sequences to Emulate User Applications

Testbenches can add sequences that generate TLPs with unique application IDs to emulate user applications. A sequence is created that generates TLPs with unique application IDs and is run on the tlp\_seqr of the PCIe agent contained in the PCI device agent. This sequencer can be accessed via the top-level virtual sequencer of type svt\_PCIE\_device\_system\_virtual\_sequencer:

```
`uvm_do_on(tlp_directed_seq, p_sequencer.root_virt_seqr.pcie_virt_seqr.tlp_seqr);
```

The output TLM port of this sequencer is internally connected to the sequence\_item\_port of the VIP's transaction layer.

The TLPs are set up with the appropriate application ID and requester ID and pushed into the seq\_item\_port, as indicated in [Example 11-2](#).

### Example 11-2

```
svt_PCIE_tlp mem_rd_request
`uvm_create(mem_rd_request);
mem_rd_request.cfg = cfg;
mem_rd_request.tlp_type = svt_PCIE_tlp::MEM_REQ;
mem_rd_request(fmt = svt_PCIE_tlp::NO_DATA_3_DWORD;
mem_rd_request.length = 2 + i;
mem_rd_request.ep = 0;
mem_rd_request.at = svt_PCIE_tlp::UNTRANSLATED;
mem_rd_request.first_dw_be = 4'b1111;
mem_rd_request.last_dw_be = 4'b1111;
mem_rd_request.application_id = 32'h21;
mem_rd_request.address = 32'h0000_4000 | ('h100 << i);
mem_rd_request.requester_id = 4;
`uvm_send(mem_rd_request)
```

## 11.8.3 Waiting for Completions

Completions are routed to the appropriate application\_id using the application ID-to-requester ID map. Using code like the following the completions can be accessed from the rx\_tlp\_peek port whenever they are available:

```
`uvm_send(mem_rd_request)
root.tl.EVENT RECEIVED_TLP.wait_trigger();
root.tl.rx_tlp_peek_port.peek(resp);
```

## 11.9 Backdoor Access to Completion Target Configuration Space

The Completion Target has access to its own Configuration space allowing reads and writes to Configuration registers (including Capabilities). In contrast with the VIP Memory and I/O targets, the Configuration space is located in a fixed 4K sized configuration block (as defined in the PCIE spec.) This block includes not only the standard PCI configuration registers, but the extended space (including extended capabilities) defined by PCIE.

Each device allocates a Configuration Pointer Table which contains pointers to all of the Configuration Blocks allocated (one for each function in the device).

### 11.9.1 Setting up the Configuration Space for Backdoor Access

The VIP model behavior is not defined by the configuration space as in a real device. The model behavior is defined by the attributes in the configuration and service classes. Though setting up the configuration space

does not define the VIP behavior, the model can be set up to respond to any incoming configuration TLP. A user can program the configuration space of the model though the backdoor using the APIs on the cfg\_database of the VIP model.

The VIP does not have a real configuration space like a RTL module. However, it has an internal memory that it uses for CfgWr/Rd transactions. The VIP stores the write value for the incoming CfgWr transactions, and use the return data from this memory while completing CfgRd TLPs.

There is a backdoor way to write/read this internal memory used by the VIP for configuration TLPs. Please note that you do not have to pre-load the configuration database to be able to use it. The VIP will respond to any configuration request, but it will have a default value of 0 in all of the registers.

To set up the configuration space in the pcie vip model without having to perform configuration write/read cycles, use the svt\_PCIE\_cfg\_database\_service class. This class contains these 3 service types:

- ❖ GET\_NUM\_FUNCTIONS(`SVT\_PCIE\_CFG\_DB\_SERVICE\_GET\_NUM\_FUNCTIONS) Get maximum number of functions.
- ❖ READ\_CFG\_DWORD(`SVT\_PCIE\_CFG\_DB\_SERVICE\_READ\_CFG\_DWORD) Read configuration DWORD.
- ❖ WRITE\_CFG\_DWORD(`SVT\_PCIE\_CFG\_DB\_SERVICE\_WRITE\_CFG\_DWORD) Write configuration DWORD.

These services also use these attributes to set up the configuration space.

- ❖ dword\_addr
- ❖ dword\_data
- ❖ function\_num

Following shows example code on backdoor access.

```
// This sequence creates backdoor then frontdoor (TLP) traffic sequences
class pcie_cfg_seq extends pcie_device_system_test_base_sequence;

  // Factory Registration.
  `svt_uvm_object_utils(pcie_cfg_seq)

  // Constructs the pcie_cfg_seq sequence
  // @param name string to name the instance.
  function new(string name = "pcie_cfg_seq");
    int err_status;
    super.new(name);
  endfunction

  // Executes PCIE configuration sequences to demonstrate backdoor/frontdoor accesses

  task body();
    begin
      pcie_device_system_link_up_sequence link_up_seq;
      svt_PCIE_driver_app_service_wait_until_idle_sequence wait_until_driver_idle_seq;

      cfg_read_sequence read_cfg_seq;
      //cfg_write_sequence write_cfg_seq;

      svt_PCIE_cfg_database_service cfg_database_seq;
```

```
svt_PCIE_device_agent endpoint_device;
bit [7:0] bus, func;
bit [15:0] remote_bdf;
bit [31:0] cfg_rdata, cfg_wdata;

bit [7:0] function_num;           // Function Number
bit [31:0] cpt_ptr;             // Configuration Pointer Table, CPT, which
                                // contains pointers to all the
                                // Configuration Blocks allocated (one per
                                // device)
bit      cfg_space_type = 0;     // Type 0 or Type 1
bit [3:0] function_type = 0 ;    // PF, BF, VF, etc.
bit [7:0] sriov_physical_function = 0; // The PF that is the parent Physical
                                         // function of the VF
bit [7:0] mriov_base_function = 0; // The BF that is the parent Base Function
                                         // of this function
bit [31:0] command_status;      // Returned status for allocate
bit [15:0] req_cap_id;
int      err_status;
int      remote_register_num;

int      test_data, test_addr;

super.body();

test_data = 32'habcd_1234;
test_addr = $urandom_range(0, 1023); // Scribble randomly in the cfg database

// Housekeeping:
// bring up link
`svt_uvm_do(link_up_seq);

// Can we get the BDF via these xx_device agents? Maybe in an
// enumerator that's considered 'cheating'?
if(!$cast(root_device, p_sequencer.find_root_agent(this))) begin
  `uvm_fatal(get_full_name(), "Failed attempting to obtain handle to Root Device
agent.");
end

if(!$cast(endpoint_device, p_sequencer.find_endpoint_agent(this))) begin
  `uvm_fatal(get_full_name(), "Failed attempting to obtain handle to Endpoint
Device agent.");
end

// Backdoor fill in the cfg database
`define BACKDOOR_CFG_ACCESS_WORKS      1
`ifdef BACKDOOR_CFG_ACCESS_WORKS      // currently it doesn't...
`endif

`svt_note("body", "Backdoor write started");

function_num = 0;
`uvm_create_on(cfg_database_seq,
               p_sequencer.endpoint_virt_seqr.cfg_database_seqr);
cfg_database_seq.service_type = svt_PCIE_cfg_database_service::WRITE_CFG_DWORD;
```

```
cfg_database_seq.function_num = function_num;
cfg_database_seq.dword_addr = test_addr;
cfg_database_seq.byte_enables = 4'b1111;
cfg_database_seq.dword_data = test_data; // 32'habcd_1234
`uvm_send(cfg_database_seq);

if(cfg_database_seq.command_status != `SVT_PCIE_CFG_DATABASE_STATUS_SUCCESSFUL)
  `uvm_error("body", $sformatf("Command status not SUCCESSFUL(0x%h) received
  0x%h", `SVT_PCIE_CFG_DATABASE_STATUS_SUCCESSFUL,
  cfg_database_seq.command_status))
`uvm_info("body", $sformatf("Config_reg 0 is backdoor written with 0x%x",
  cfg_database_seq.dword_data), UVM_LOW);

`uvm_create_on(cfg_database_seq,
  p_sequencer.endpoint_virt_seqr.cfg_database_seqr);
cfg_database_seq.service_type = svt_PCIE_cfg_database_service::READ_CFG_DWORD;
cfg_database_seq.function_num = function_num;
cfg_database_seq.dword_addr = test_addr;
cfg_database_seq.byte_enables = 4'b1111;
cfg_database_seq.dword_data = 32'hffff_ffff;
`uvm_send(cfg_database_seq);
if(cfg_database_seq.command_status != `SVT_PCIE_CFG_DATABASE_STATUS_SUCCESSFUL)
  `uvm_error("body", $sformatf("Command status not SUCCESSFUL(0x%h) received
  0x%h", `SVT_PCIE_CFG_DATABASE_STATUS_SUCCESSFUL,
  cfg_database_seq.command_status))
`uvm_info("body", $sformatf("Config_reg 0 is backdoor read data=0x%x",
  cfg_database_seq.dword_data), UVM_LOW);

if (cfg_database_seq.dword_data != test_data)
begin
  `svt_error("body", $sformatf("Backdoor read of cfg addr %0d returned 0x%x,
  expected 0x%x", test_addr, cfg_database_seq.dword_data, test_data));
end
`endif // BACKDOOR_CFG_ACCESS_WORKS
```

The `svt_PCIE_*` sequences that refers to the configuration space register number. The numbering is with regard to a dword address:

- ❖ SVT register number = 0 => [Device ID | Vendor ID] => PCIE registers [[3,2],[1,0]]
- ❖ SVT register number = 1 => [Status | Command ] => PCIE registers [[7,6],[5,4]]

Note, most Firmware uses as a convention register numbers 0, 1, 2, 3, 4, 5, 6, and 7 as byte offset numbers as defined in the specification.

## 11.10 Setting VIP Lanes for Receiver Detect

To set which lanes the VIP will see as present from the DUT when the VIP performs a receiver detect in the `detect.active` state, use the following configuration member:

```
svt_PCIE_pl_configuration::dut_receiver_present = 32'hffff_ffff
```

Each bit corresponds to a lane, with bit 0 corresponding to lane 0, and with bit 1 corresponding to lane 1, and so on.

For example, take the case of the VIP as an SPIPE configured to a width of x4. If you set dut\_receiver\_present to 32'h000\_0007, then the VIP will behave as if it only detected a receiver on lanes 0-2. As a result of this, the VIP will try to negotiate to a width of x2. Note that this controls what lanes the VIP sees as present, not which lanes the DUT sees as present. Use dut\_receiver\_present for serial and SPIPE models only. MPIPE models will use the mechanism defined in the PIPE interface to determine which receivers are present.

## 11.11 Using ASCII Signals

The following sections document the ASCII signals you can use for viewing within a waveform viewer. Note, you may see ASCII signals prefaced with “debug”. These are only for internal Synopsys use.

### 11.11.1 Transaction Layer ASCII Signals

The ASCII signals listed in [Table 11-4](#) are available for viewing within a waveform viewer. Access to the signals is through the XMR path to the TL. For example, in the examples shipped with the model, they are found at: “test\_top.root0.port0.tl0.\*ascii”

**Table 11-4 ASCII signals available for waveform viewers**

| Event Name           | Description                                                           |
|----------------------|-----------------------------------------------------------------------|
| ascii_rx_tlp_fc_type | Flow control credits associated with this TLP. Values are P, NP, CPL. |
| ascii_rx_tlp_type    | Type of received TLP as defined by (fmt, type) fields.                |
| ascii_rx_tlp_vc      | VC on which TLP is received.                                          |
| ascii_rx_tlp_xid     | Received TLP transaction ID.                                          |
| ascii_tx_tlp_fc_type | Flow control credits associated with this TLP. Values are P, NP, CPL. |
| ascii_tx_tlp_type    | Type of TLP to be sent as defined by (fmt, type) fields.              |
| ascii_tx_tlp_vc      | VC on which TLP is sent.                                              |
| ascii_tx_tlp_xid     | Sent TLP transaction ID.                                              |

### 11.11.2 Data Link Layer ASCII Signals

ASCII signals on the Data Link Layer are listed in [Table 11-5](#).

**Table 11-5 Data Link Layer ASCII signals**

| Signal Name                     | Description                                   |
|---------------------------------|-----------------------------------------------|
| ascii_tx_tlp_type               | Sent TLP type, defined by {fmt, type} fields. |
| ascii_tx_tlp_seq_num            | Sent TLP sequence number.                     |
| ascii_tx_tlp_ei_code            | TLP sent with this EI.                        |
| ascii_tx_dllp_type              | Sent DLLP type.                               |
| ascii_tx_dllp_seq_num           | Sent DLLP sequence number for ACK/NAK.        |
| ascii_tx_dllp_credit_vc         | Sent DLLP VC.                                 |
| ascii_tx_dllp_credit_data_value | Sent DLLP data credit value.                  |
| ascii_tx_dllp_credit_hdr_value  | Sent DLLP header credit value.                |

**Table 11-5 Data Link Layer ASCII signals (Continued)**

| Signal Name                     | Description                                       |
|---------------------------------|---------------------------------------------------|
| ascii_rx_tlp_type               | Received TLP type, defined by {fmt, type} fields. |
| ascii_rx_tlp_seq_num            | Received TLP sequence number.                     |
| ascii_rx_dllp_type              | Received DLLP type.                               |
| ascii_rx_dllp_seq_num           | Received DLLP sequence number for ACK/NAK.        |
| ascii_rx_dllp_credit_vc         | Received DLLP VC.                                 |
| ascii_rx_dllp_credit_data_value | Received DLLP data credit value.                  |
| ascii_rx_dllp_credit_hdr_value  | Received DLLP header credit value.                |
| ascii_dlcmsm_state              | Data Link Control Management State Machine.       |
| ascii_vc[0-7]_fcsm_state        | Flow Control State Machine for VC[0-7]            |
| ascii_tx_dllp_ei_code           | DLLP error codes.                                 |
| ascii_aspm_state;               | ASPM state                                        |
| ascii_pm_state;                 | PM state                                          |
| ascii_tx_callback;              | Callback being executed on TX side.               |
| ascii_rx_callback;              | Callback being executed on the RX side.           |
| ascii_fc_init_state;            | Flow control init state                           |

### 11.11.3 Physical Layer ASCII Signals

Physical Layer ASCII signals are listed in [Table 11-6](#).

**Table 11-6 Physical Layer ASCII signals**

| Signal Name               | Description                                                                      |
|---------------------------|----------------------------------------------------------------------------------|
| ascii_ltssm_tx_state      | LTSSM state of the transmitter                                                   |
| ascii_ltssm_rx_state      | LTSSM state of the receiver                                                      |
| ascii_lanen_rx_data       | Data received on lane n, where n is a number between 0 and 31.                   |
| ascii_lanen_tx_data       | Data transmitted on lane n, where n is a number between 0 and 31.                |
| ascii_pipe_lanen_rx_data; | Symbol data on received on PIPE lane n, where n is a number between 0 and 31.    |
| ascii_pipe_lanen_tx_data  | Symbol data on transmitted on PIPE lane n, where n is a number between 0 and 31. |
| ascii_hotplug_mode        | Current state of hotplug mode                                                    |
| ascii_prev_hotplug_mode   | Previous state of the hotplug.                                                   |
| ascii_lane_reversal_mode; | Lane reversal indicates if lane reversal is enabled.                             |

## 11.12 Using the Ordering Application

This component is provided as an optional feature which may be utilized by testbenches explicitly. The Ordering Application is implemented as a `uvm_component`. The agent components that are shipped with the VIP do not use this component by default. It has following functions:

- ❖ Validates ordering rules implementation of a DUT.
- ❖ It can optionally also be used to re-order outbound TLPs to act as application layer logic for a DUT that does not implement the rules in RTL.

It has following parts:

1. `svt_PCIE_ordering_app_configuration`: This configuration class is used to configure the application component.
2. `tx_tlp_in_port`: This is a sequence item pull port (SIPP) that processes all transactions that are scheduled for transmission by DUT. The application expects transactions of type `svt_PCIE_tlp` and hence it may be connected to a sequencer of type `svt_PCIE_tlp_sequencer`.
3. `rx_tlp_in_export`: This is an analysis implementation port. The testbench must connect this to an analysis port that broadcasts transactions received by the VIP.
4. `tx_tlp_out_port`: This is a TLM put port onto which the application pushes all re-ordered TLPs (if enabled).
5. `tl_status`: This is a reference to the TL status the VIP maintains.

### 11.12.1 Steps to Use the Ordering Application:

1. Create a new configuration object of type `svt_PCIE_ordering_app_configuration` and set the desired values to the properties.

```
svt_PCIE_ordering_app_configuration ordering_app_cfg = new();
```

2. Create the Ordering application in `build_phase()` of a containing component (typically an environment or test component).

```
ordering_app = svt_PCIE_ordering_app::type_id::create("ordering_app", this);
```

3. In the build phase, set the reference of the configuration object in the `uvm_config_db` so it can be obtained by the application.

```
uvm_config_db#( svb_PCIE_ordering_app_configuration )::set(this, "ordering_app", "cfg", ordering_app_cfg);
```

4. Create a new sequencer instance of type `svt_PCIE_tlp_sequencer`.

```
uvm_config_db #( svb_PCIE_tlp_configuration )::set( this, "ordering_app_seqr", "cfg", dut_cfg.pcie_cfg.tl_cfg );
```

```
ordering_app_seqr = svt_PCIE_tlp_sequencer::type_id::create("ordering_app_seqr", this);
```

5. In the `connect_phase()`, connect the ordering app with the sequencer created in step 4.

```
ordering_app.tx_tlp_in_port.connect(ordering_app_seqr.seq_item_export);
```

6. Set the reference of the `svt_PCIE_tlp_status` object (that the VIP maintains) in the `uvm_config_db` so it can be obtained by the application in `end_of_elaboration_phase()`. The application has need of this to obtain TCVC mapping and credit information.

```
uvm_config_db#( svb_PCIE_tlp_status)::set(this, "ordering_app", "tl_status", <vip_agent>.pcie_agent.pcie_status.tl_status);
```

7. Connect rx\_tlp\_in\_export port with an analysis port that broadcasts TLPs received by the VIP.  
`<analysis_port>.connect(ordering_app.rx_tlp_in_export);`
8. Optionally connect tx\_tlp\_out\_port with TLM blocking\_put\_imp of a downstream component. This will typically be responsible to send outbound transactions through DUT's application interface. This step is required if re-ordering of TLPs is enabled in the application (in case DUT does not support the Ordering rules in RTL).  
`ordering_app.tx_tlp_out_port.connect(<dut_driver_component>.<name_of_put_imp_port>);`
9. Now, use the ordering\_app\_seqr created in step 4 to schedule all transactions to be transmitted by DUT.

## 11.13 Customizing the Transaction Log Output

You can configure how the trace file displays information using the `svt_PCIE_configuration::dl_trace_options` member. These options apply to the default DL tracing format options.

- ❖ `dl_trace_options[1]` bit when set to 1'b1 enables optional printing of Cfg TLP Register Offset address as "O:0x???"
- ❖ `dl_trace_options[1]` bit when set to 1'b0 enables default printing of Cfg TLP Register Number as "R:0x???"
- ❖ `dl_trace_options[0]` bit when set to 1'b1 enables default printing of Cfg Access TLP Payload in Little Endian format
- ❖ `dl_trace_options[0]` bit when set to 1'b0 enables default printing of Cfg Access TLP Payload in Big Endian format

This first instance has the Cfg TLP Register Offset address option enabled (`svt_PCIE_configuration::dl_trace_options[1]=1`) and printing of the CFG access payload as big endian (`svt_PCIE_configuration::dl_trace_options[0]=0`). See the following:

```
endpoint0 18128.000 18236.000 R CfgWr0 0x0000/06 ... BDF:0x0107 O:0x010 0 c 1 H44008001 ...
0 fecacefa
endpoint0 18448.000 18540.000 R CfgRd0 0x0000/07 ... BDF:0x0107 O:0x010 0 f 1 H04008001 ...
endpoint0 18588.000 18696.000 T CplD 0x0000/07 ... ID:0x0107 Stat:SC BC:0004 1 H4a008001 ...
0 efbecefa
```

This second instance has the Cfg TLP Register Offset address option disabled (`svt_PCIE_configuration::dl_trace_options[1]=0`) and printing of the CFG access payload as LittleEndian (`svt_PCIE_configuration::dl_trace_options[0]=1`). See the following:

```
root0 18124.000 18232.000 T CfgWr0 0x0000/06 ... BDF:0x0107 R:0x004 0 c 1 H44008001 H0000060c ...
0 facecafe LittleEndian
root0 18444.000 18536.000 T CfgRd0 0x0000/07 ... BDF:0x0107 R:0x004 0 f 1 H04008001 H0000070f ...
root0 18592.000 18700.000 R CplD 0x0000/07 ... ID:0x0107 Stat:SC BC:0004 1 H4a008001 H01070004 ...
0 facebeef LittleEndian
```

## 11.14 Target Application

The Target Completer Application provides the following features:

- ❖ Provides completer services by responding to various inbound requests: CFG, Memory, IO and Interrupts
- ❖ Will break up reads into multiple completions
- ❖ Interleaved with other read completions

- ❖ Highly configurable
  - ◆ min:max read data size
  - ◆ Completion boundary (align)
  - ◆ Max payload size
  - ◆ min:max latency (mem, io, cfg ; all independent)
  - ◆ Un-Initialized mem mode: 0, completer abort

To configure the Target Completer Application you use the `svt_PCIE_target_app_configuration` class. Consult the HTML class reference for additional information. Following are some useful settings:

- ❖ `completer_id`: Default Completer ID used by the Target application in the generated completions until Configuration Write requests are received on the link to program the completer ID. This ID is concatenation of Bus number, Device number and a Function number.
- ❖ `max_io_cpl_latency`: The variable represents maximum latency in ns for each completion packet generated by the application in response to inbound IO requests.
- ❖ `min_cfg_cpl_latency`: The variable represents minimum latency in ns for the completion packet generated by the application in response to inbound Configuration requests.
- ❖ `read_completion_boundary_in_bytes`: The variable `read_completion_boundary_in_bytes` specifies the RCB value. The Target application uses this while creating completions.
- ❖ `max_payload_size_in_bytes`: The variable specifies maximum payload size in bytes. Any TLP payload cannot exceed this value in size.



**Note** The service sequence, `svt_PCIE_target_app_service_wait_until_idle_sequence` added to the PCIe VIP allows the target application to wait for the application to be idle. The attribute, `is_idle` added to the status class, `svt_PCIE_target_app_status` allows the user to check if the application is idle or not.

### 11.14.1 Target Application Callbacks

The target application is the component responsible for handling the auto-generated completions in the VIP model. The model has two callbacks defined at this application layer namely:

1. `post_rx_tlp_get()`: Called by the component after recognizing a TLP transaction received immediately from the link.
2. `pre_tx_tlp_put()`: Called by the component after scheduling a TLP transaction for transmission on the link, just prior to framing.

These callback can be used to inject errors into transactions using exception objects.

#### Example:

The following example illustrates how to set the Error Poison (EP) bit in a completion TLP generated by the target application.

```
// Callback Class
class set_ep_target_app_callback extends svt_PCIE_target_app_callback;
  `svt_uvm_object_utils(set_ep_target_app_callback)

  // Exception List and Exception class objects
```

```
svt_PCIE_tlp_exception_list my_tlp_exc_list = new("my_tlp_exc_list");
svt_PCIE_tlp_transaction_exception my_tlp_exc = new("my_tlp_exc");

function new(string name = "set_ep_target_app_callback");
    super.new();
endfunction

// Callback Function Implementation
virtual function void pre_tx_tlp_put(svt_PCIE_target_app target_app, svt_PCIE_tlp
transaction, ref bit drop);
    // Add any conditional statement here to look for a specific TL packet (if necessary).
    // The illustration below is unconditional so it would end up setting the EP bit on all
    // completion packets being transmitted by the target application.
    my_tlp_exc.error_kind = svt_PCIE_tlp_transaction_exception::CORRUPT_EP;
    my_tlp_exc.corrupted_data = 0;
    my_tlp_exc.corrupted_data[0] = 1;
    my_tlp_exc_list.add_exception(my_tlp_exc);
    `svt_note("pre_tx_tlp_get",$sformatf("ERP - pre_tx_tlp_put: Attaching exception
list - corrupting TLP EP field (was=1'b%b now=1'b%b).\n", transaction.ep,
my_tlp_exc.corrupted_data[0]));
    $cast(transaction.exception_list, my_tlp_exc_list.`SVT_DATA_COPY());
endfunction

endclass

// UVM Test Class
class base_pipe_test extends pcie_device_base_test;

    set_ep_target_app_callback set_ep_target_cb;
    ...
    virtual function void end_of_elaboration_phase(uvm_phase phase);
        super.end_of_elaboration_phase(phase);

        set_ep_target_cb = new("set_ep_target_cb");

        uvm_callbacks#(svt_PCIE_target_app, svt_PCIE_target_app_callback)::add(env.endpoint.targ
et[0], target_cb);
    endfunction

endclass
```

The same approach can be used to attach other errors on completions generated by the target application. To check the list of errors supported by the model, see HTML class reference documentation:

[DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/exception/class\\_svt\\_PCIE\\_tlp\\_exception.html#item\\_error\\_kind\\_enum]($DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_PCIE_tlp_exception.html#item_error_kind_enum)

## 11.15 Requester Application

Requester Application is used for generating background traffic. The Application generates PCIe Read/Write transactions to a given target. You can randomize the following:

- ❖ [minimum:maximum] address range(s)
- ❖ Number of writes

- ❖ Number of reads
- ❖ [minimum:maximum] data length
- ❖ Configure bandwidth
- ❖ Time between packets
- ❖ # requests per second

It performs a synchronize when it is finished.

You use the class `svt_PCIE_requester_app_configuration` for the Target Application. For additional information on configuration members, consult the HTML Class Reference. Following are some configuration members.

- ❖ `bandwidth_mode`. Specifies the mode which controls the read/write request generation mechanism. `BANDWIDTH_MODE_REQUESTS_PER_SEC` mode specifies the read/write request generation rate as number of requests to be generated per second.  
`BANDWIDTH_MODE_NS_DELAY_IN_REQUESTS` mode specifies the read/write request generation rate in terms of delay between successive requests generated.
- ❖ `completion_timeout_ns`. Completion timeout in nanoseconds.
- ❖ `num_mem_read`. Number of memory read transactions to be transmitted.
- ❖ `max_time_between_packets`. The variable is applicable when `bandwidth_mode` is set to `BANDWIDTH_MODE_NS_DELAY_IN_REQUESTS`. The value of this variable specifies maximum delay in NS in the successive packets to be generated.

## 11.16 What Are Blocking and Non-blocking Reads in PCIe SVT?

'Blocking' read prevents other transactions from being queued. Whereas in case of non-blocking read, a process does not wait for the completion. As a result, the transaction is queued.

The driver application layer uses the `block` attribute to control when the driver queues the next transaction. When it is set to 1, the driver will wait until the transaction is completed before the next transaction is queued.

When set to 0, the driver does not wait for transaction to complete and drives the sub-sequent transaction. The function of the `block` bit is to not return control to the user until the completion is received in the case of a read.

### Example:

```

`* block = 1, block until completion is received.
* block = 0, non-block.

For cfg_rd request:
    `uvm_do_on_with(cfg_rd_rq,p_sequencer.root_virt_seqr.driver_transaction_seq
r[0], {
    bdf == 16'h0100;
    block == 1'b1; // block until completion is received.
    first_dw_be == 4'hf;
    register_number inside {[0:50]};
});

```

For Mem\_rd request:

```
`uvm_do_on_with(mem_rd_request_seq,vip_seqr.driver_transaction_seqr[0], {
```

```
address == mem_wr_request_seq.address;
traffic_class == mem_wr_request_seq.traffic_class;
length == mem_wr_request_seq.length;
block == 1'b0; // it will not wait for completion
first_dw_be == mem_wr_request_seq.first_dw_be;
last_dw_be == mem_wr_request_seq.last_dw_be;
});
```

## 11.17 Using Service Class Reset App

The VC VIP provides functionality to support mid-simulation reset. The scenario is that the VIP is connected to the DUT, and that the DUT is reset sometime into the test after the initial reset of the VIP and DUT. The purpose of the test is to ensure the DUT recovers and that the link retrains. During this time you want to mimic that a reset also happening on the VIP. This means all activity should cease, all buffers should be cleared, and you should go back into our initial state waiting for training sets.

In terms of implementation note that the VIP has its own reset, and that it is only allowed to toggle once, typically at the beginning of a simulation. Further, the VIP reset should never be connected to the reset of the DUT.

Since the VIP reset doesn't toggle, a mid-sim reset is performed with a combination of hot plug control and application resets. The PL provides a mechanism to 'unplug' and then 'plug' the `svt_PCIE_PL_SERVICE_REQUEST_HOT_PLUG_MODE_SEQUENCE`. All applications provide a mechanism which resets the apps meaning they are re-initialized, `svt_PCIE_*_RESET_APP_SEQUENCE`. [Table 11-7](#) lists each one for each service class.

Synopsys also provides a sequence which wraps the hot plug and reset calls:  
`svt_PCIE_DEVICE_VIRTUAL_RESET_SEQUENCE`.

The following outlines the steps in a mid-sim reset.

1. Unplug VIP from bus (HOTPLUG\_UNPLUG)
2. Assert Reset on the DUT
3. Reset apps (all, some, or none – user choice)
4. Re-enable the VIP on the bus (HOTPLUG\_DETECT)
5. De-assert Reset on the DUT
6. Continue with the test
  - ◆ Suggest monitoring for a change in LTSSM state; PL : `WaitForLtssmStateChange()`
7. Initialize DUT and VIP, run to a point in the test where a mid-sim reset is to be performed

Option 1:

- ◆ Unplug VIP from bus, `svt_PCIE_PL_SERVICE_REQUEST_HOT_PLUG_MODE_SEQUENCE` with HOTPLUG\_UNPLUG
- ◆ Assert reset on DUT
- ◆ foreach (app) `ResetApp` (call on apps to reset; not necessary to reset all apps)
- ◆ execute `svt_PCIE_PL_SERVICE_REQUEST_HOT_PLUG_MODE_SEQUENCE` with HOTPLUG\_DETECT
- ◆ De-assert reset on DUT

Option 2:

- ◆ In parallel, assert DUT's reset line and execute: `svt_PCIE_DEVICE_VIRTUAL_RESET_SEQUENCE`

- ◆ After completion of sequence, reassert DUT's reset line
8. Continue with the test
- ◆ Suggest monitoring for a change in LTSSM state, or L0
- ```
wait (agent.status.pcie_status.pl_status.ltssm_state == svt_PCIE_types::L0)
```

**Table 11-7 Service Class App Sequence Resets**

| Reset Sequence for Application                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| svt_PCIE_requester_app_service_reset_app_sequence | <ul style="list-style-type: none"> <li>• This sequence implements ResetApp</li> <li>• RESET_APP is a reset for the Driver</li> <li>• The effect of resetting this application is to drop all queued and partially completed requests. After a reset the driver will check for completions on sent requests or check for timeouts.</li> <li>• It is not necessary to call Reset App at the beginning of simulation</li> </ul> |
| svt_PCIE_io_target_service_reset_app_sequence     | <ul style="list-style-type: none"> <li>• This sequence implements Reset App</li> <li>• RESET_APP resets the application back to its initial state. All data will be lost.</li> <li>• It is not necessary to call this at start of sim.</li> </ul>                                                                                                                                                                            |
| svt_PCIE_mem_target_service_reset_app_sequence    | <ul style="list-style-type: none"> <li>• This sequence implements Reset App</li> <li>• RESET_APP resets the memory target back to its initial state. All data will be lost.</li> <li>• It is not necessary to call this at start of sim</li> </ul>                                                                                                                                                                           |
| svt_PCIE_requester_app_service_reset_app_sequence | <ul style="list-style-type: none"> <li>• This sequence implements Reset App</li> <li>• RESET_APP is a reset for the requester. Any outstanding requests will be dropped, and there will be no timeouts for these dropped requests. If completions come in for the dropped requests they will be treated as unexpected completions.</li> <li>• It is not necessary to call RESET_APP at the start of simulation.</li> </ul>   |
| svt_PCIE_target_app_service_reset_app_sequence    | <ul style="list-style-type: none"> <li>• This sequence implements ResetApp</li> <li>• RESET_APP resets the target application. All outstanding requests are dropped and will not be completed.</li> <li>• It is not necessary to call RESET_APP at the start of simulation.</li> </ul>                                                                                                                                       |

Following is a code fragment showing midsim reset.

```
task midsim_reset_sequence::body();
begin
    pcie_device_system_link_up_sequence link_up_seq;
    svt_PCIE_requester_app_service_mem_range_sequence req_mem_range_seq;
    svt_PCIE_requester_app_service_app_sequence req_app_seq;
    svt_PCIE_requester_app_service_clr_stats_sequence req_clr_stats_seq;
    svt_PCIE_requester_app_service_disp_stats_sequence req_disp_stats_seq;
end
```

```
svt_PCIE_requester_app_service_reset_app_sequence reset_requester_app_seq;
svt_PCIE_target_app_service_reset_app_sequence reset_target_app_seq;
svt_PCIE_pl_service_request_hot_plug_mode_sequence request_hot_plug_mode_seq;
svt_PCIE_device_virtual_reset_sequence device_reset_vseq;

...
// bring up link
`svt_uvm_do(link_up_seq);

// Add memory ranges to Requester application

`svt_uvm_do_on_with(req_mem_range_seq,p_sequencer.endpoint_virt_seqr.requester_seqr, {
req_mem_range_seq.service_type == svt_PCIE_requester_app_service::ADD_MEM_RANGE,
... //}

Reset after a few TLPs have been sent
wait(ep_agent.status.pcie_status.tl_status.num_tlpss_sent == 3);

// Now reset both sides of the link
/*
// Note that this code has been left in intentionally to serve as an example on how
to reset only certain parts of the VIP
// The reset virtual sequence called below will reset all app layers.

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.endpoint_virt_seqr.pcie_virt_
seqr.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_UNPLUG;});

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.root_virt_seqr.pcie_virt_seqr
.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_UNPLUG;});

// App resets are optional, and are reset individually with a service call
`svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr, {
req_app_seq.service_type == svt_PCIE_requester_app_service::RESET_APP; });

`svt_uvm_do_on(reset_target_app_seq,p_sequencer.root_virt_seqr.target_seqr[0]);
 */

->seq_to_test1;
uvm_report_info( "TEST", "Triggering seq_to_test1 event.", UVM_NONE );

// Just use the reset virtual sequence
`svt_uvm_do_on(device_reset_vseq, p_sequencer.root_virt_seqr);

// EP should detect the EIOS and automatically enter detect.
wait(ep_agent.status.pcie_status.pl_status.ltssm_state ==
svt_PCIE_types::RECOVERY_RCVRLOCK);

->seq_to_test2;
uvm_report_info( "TEST", "Triggering seq_to_test2 event.", UVM_NONE );

`svt_uvm_do_on(device_reset_vseq, p_sequencer.endpoint_virt_seqr);

// Wait some time and start everything back up
```

```
#1000;

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.endpoint_virt_seqr.pcie_virt_
seqr.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_DETECT;});

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.root_virt_seqr.pcie_virt_seqr
.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_DETECT;});

wait(ep_agent.status.pcie_status.pl_status.ltssm_state == svt_PCIE_types::L0);

`svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr,
{req_app_seq.service_type == svt_PCIE_requester_app_service::START_APP; });

`svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr,
{req_app_seq.service_type == svt_PCIE_requester_app_service::IS_APP_FINISHED; });

// Wait until Requester application has completed pumping in specified memory
requests
if(req_app_seq.is_finished == 'b0) begin
    // wait until requester application is finished.
    `svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr,
{req_app_seq.service_type == svt_PCIE_requester_app_service::WAIT_UNTIL_FINISHED; });
end
...
// Now reset both sides of the link
/*
// Note that this code has been left in intentionally to serve as an example on how
to reset only certain parts of the VIP
// The reset virtual sequence called below will reset all app layers.

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.endpoint_virt_seqr.pcie_virt_
seqr.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_UNPLUG;});

`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.root_virt_seqr.pcie_virt_seqr
.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_UNPLUG;});

// App resets are optional, and are reset individually with a service call
`svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr,
{req_app_seq.service_type == svt_PCIE_requester_app_service::RESET_APP; });

`svt_uvm_do_on(reset_target_app_seq,p_sequencer.root_virt_seqr.target_seqr[0]);
*/
-seq_to_test1;
uvm_report_info( "TEST", "Triggering seq_to_test1 event.", UVM_NONE );

// Just use the reset virtual sequence
`svt_uvm_do_on(device_reset_vseq, p_sequencer.root_virt_seqr);
...
...
```

```
`svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.endpoint_virt_seqr.pcie_virt_seqr.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_DETECT;});  
  
'svt_uvm_do_on_with(request_hot_plug_mode_seq,p_sequencer.root_virt_seqr.pcie_virt_seqr.pl_seqr,{mode == svt_PCIE_pl_service::HOT_PLUG_DETECT;});  
  
wait(ep_agent.status.pcie_status.pl_status.ltssm_state == svt_PCIE_types::L0);  
  
'svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr, {  
req_app_seq.service_type == svt_PCIE_requester_app_service::START_APP; });  
  
'svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr, {  
req_app_seq.service_type == svt_PCIE_requester_app_service::IS_APP_FINISHED; });  
  
// Wait until Requester application has completed pumping in specified memory  
requests  
if(req_app_seq.is_finished == 'b0) begin  
    // wait until requester application is finished.  
    `svt_uvm_do_on_with(req_app_seq,p_sequencer.endpoint_virt_seqr.requester_seqr, {  
req_app_seq.service_type == svt_PCIE_requester_app_service::WAIT_UNTIL_FINISHED; });  
end  
  
'svt_uvm_do_on(req_disp_stats_seq,p_sequencer.endpoint_virt_seqr.requester_seqr);  
'svt_uvm_do_on(req_clr_stats_seq,p_sequencer.endpoint_virt_seqr.requester_seqr);  
'svt_uvm_do_on(req_disp_stats_seq,p_sequencer.endpoint_virt_seqr.requester_seqr);  
endtask
```

## 11.18 Using FLR

Perform the following steps to enable FLR support:

1. Initiate `cfg_wr` in the Device Control Register (Offset 08h) to initiate FLR
2. Wait until the device enters `flr_active`—that is, state `max_expected_time_to_enter_flr_active_in_ns`
3. Initiate the traffic from VIP
4. The function must complete the FLR within 100 ms. After 100 ms, there will be no traffic pending for that function.

FLR support can be enabled using RC instance of the VIP—that is, by Config Read/Write sequences on the Device Control Register.

### Example 11-3 Sample code

Driver App Transaction's Sequences:

|                                                              |                               |
|--------------------------------------------------------------|-------------------------------|
| <code>svt_PCIE_driver_app_transaction_cfg_wr_sequence</code> | <code>cfg_wr_sequence;</code> |
| <code>svt_PCIE_driver_app_transaction_cfg_rd_sequence</code> | <code>cfg_rd_sequence;</code> |

Read the control register's content:

```
`uvm_do_on_with(cfg_rd_sequence,  
p_sequencer.root_virt_seqr.driver_transaction_seqr[0], {cfg_rd_sequence.address ==  
16'h0100;  
    cfg_rd_sequence.block == 1'b1;  
    cfg_rd_sequence.register_number == 'h08;})  
  
// Set FLR bit to 1  
tmp_data = cfg_rd_sequence.req.payload[0] | 32'h0000_8000;  
//
```

Now update the Register:

```
`svt_xvm_do_on_with(cfg_wr_sequence,  
p_sequencer.root_virt_seqr.driver_transaction_seqr[0], {cfg_wr_sequence.address ==  
16'h0100;  
    cfg_wr_sequence.block == 1'b1;  
    cfg_wr_sequence.payload == tmp_data;  
    cfg_wr_sequence.register_number == 'h08;})
```

For Config commands:

- ◆ *Address* field must be the Base address of the DUT EP
- ◆ *Register number* field must be the offset

## 11.19 Programming Hints and Tips

### 11.19.1 PIPE Polarity

You can use the `svt_PCIE_PL_Configuration::invert_tx_polarity` configuration member to programs polarity inversion on all lanes. It is a 32-bit vector where bit 0 control polarity inversion on lane 0. When a bit is set, the corresponding lane will invert polarity on all outgoing data. Note that it only works in serial mode.

### 11.19.2 Calls For Analysis Port Set Up and Usage

The following configuration members help you setup analysis ports on the monitor.

- ❖ `rand int unsigned attribute svt_PCIE_DL_Configuration::received_dllp_interface_mode = 0.`  
Select DLLPs available at Receive DLLP analysis port. DLLPs are filtered based on th bits enabled in `received_dllp_interface_mode` bit vector. See `svt_PCIE_DL::received_dllp_observed_port` for accessing received DLLPs.

Bits are defined in `include/svt_PCIE_common_defines.v` as  
`SVT_PCIE_SENT_DLLP_INTERFACE_MODE_[sel]_BIT` where [sel] is defined as:

- `GOOD_PACKETS_BIT`
- `ERR_PACKETS_BIT`

- ❖ `rand int unsigned attribute svt_PCIE_DL_Configuration::received_tlp_interface_mode = 0`  
Select TLPs available at Receive TLP analysis port. TLPs are filtered based on the bits enabled in `received_tlp_interface_mode` bit vector. See `svt_PCIE_DL::received_tlp_observed_port` for accessing received TLPs.

Bits are defined in `include/svt_PCIE_common_defines.v` as  
`SVT_PCIE_RECEIVED_TLP_INTERFACE_MODE_[sel]_BIT` where [sel] is defined as:

- `GOOD_PACKETS_BIT`
- `ERR_PACKETS_BIT`

- ❖ `rand int unsigned attribute svt_PCIE_DL_Configuration::replay_timeout`  
Length of the replay timer in symbols. If called, timeout value is sticky. Setting to value = 0 will enable automatic updates.

- ❖ `rand int unsigned attribute svt_PCIE_DL_Configuration::sent_dllp_interface_mode = 0`  
Select DLLPs available at Sent DLLP analysis port. DLLPs are filtered based on the bits enabled in `sent_dllp_interface_mode` bit vector. See `svt_PCIE_DL::sent_dllp_observed_port` for accessing sent DLLPs.

Bits are defined in `include/svt_PCIE_common_defines.v` as  
`SVT_PCIE_SENT_DLLP_INTERFACE_MODE_[sel]_BIT` where [sel] is defined as:

- `ALL_PACKETS_BIT`

- ❖ `rand int unsigned attribute svt_PCIE_DL_Configuration::sent_tlp_interface_mode = SVT_PCIE_SENT_TLP_INTERFACE_MODE_DEFAULT`  
Select TLPs available at Sent TLP analysis port. TLPs are filtered based on the bits enabled in `sent_tlp_interface_mode` bit vector. See `svt_PCIE_DL::sent_tlp_observed_port` for accessing sent TLPs.

Bits are defined in `include/svt_PCIE_common_defines.v` as  
`SVT_PCIE_SENT_TLP_INTERFACE_MODE_[sel]_BIT` where [sel] is defined as:

◆ ALL\_PACKETS\_BIT.

You must set the sent\_tlp\_interface\_mode and received\_tlp\_interface\_mode members to enable the analysis ports--otherwise, no transactions appear.

The sent\_tlp\_interface\_mode parameter is for enabling the analysis port. The following code shows the enabling of the analysis ports:

```
// Enable analysis ports.
cust_cfg.root_cfg.pcie_cfg.dl_cfg.sent_tlp_interface_mode = 1;
cust_cfg.root_cfg.pcie_cfg.dl_cfg.received_tlp_interface_mode = 1;
cust_cfg.root_cfg.pcie_cfg.dl_cfg.sent_dllp_interface_mode = 1;
cust_cfg.root_cfg.pcie_cfg.dl_cfg.received_dllp_interface_mode = 1;
```

If these configuration variables (sent\_tlp\_interface\_mode and received\_tlp\_interface\_mode) are set to 1, then you can use the class svt\_PCIE\_DL\_DLLP\_MONITOR\_TRANSACTION to obtain sent and received TLPs using the analysis ports.

Following are the steps to set up the dl\_monitors:

1. Use these connections.

```
ep_agent_PCIE_agent.dl.sent_tlp_observed_port.connect(sent_tlp_port);
ep_agent_PCIE_agent.dl.received_tlp_observed_port.connect(received_tlp_port);
```

Refer to the following example file: ts.directed\_pipe\_test.sv

```
env.root_PCIE_agent.dl.sent_tlp_observed_port.connect(
    sent_tlp_subscriber.analysis_export );
env.root_PCIE_agent.dl.received_tlp_observed_port.connect(
    rcvd_tlp_subscriber.analysis_export );
env.root_PCIE_agent.dl.sent_dllp_observed_port.connect(
    sent_dllp_subscriber.analysis_export );
env.root_PCIE_agent.dl.received_dllp_observed_port.connect(
    rcvd_dllp_subscriber.analysis_export );
```

2. The following connections need to be enabled:

svt\_PCIE\_DEVICE\_CONFIGURATION -> svt\_PCIE\_CONFIGURATION -> svt\_PCIE\_DL\_CONFIGURATION

Use the following code:

```
root_cfg_PCIE_cfg.dl_cfg.sent_tlp_interface_mode = 1;
root_cfg_PCIE_cfg.dl_cfg.received_tlp_interface_mode = 1;
root_cfg_PCIE_cfg.dl_cfg.sent_dllp_interface_mode = 1;
root_cfg_PCIE_cfg.dl_cfg.received_dllp_interface_mode = 1;
```

### 11.19.3 Sequences and the uvm\_sequence::get\_response Task

The driver does not know at what time a transaction is queued, and what its tag ID will be. But for every request queued into the driver, the driver issues a unique command number. You access the command number by referring to svt\_PCIE\_DRIVER\_APP\_TRANSACTION::COMMAND\_NUM. The COMMAND\_NUM attribute is assigned when the transaction is queued.

Every sequence that is executed will generate a response, and thus uvm\_sequence::get\_response should always be called for every request that has been queued. For posted commands, it still needs to be called. For non-posted commands, if a block is called, then when you call uvm\_sequence::get\_response, you will have the completion information available.

If a block is set to '0', then you want to save the command\_num. You would pick up commands later on the source\_rx\_transaction\_out\_port. You can match the completion by checking command\_num. If you want to wait for a completion or check if a request has completed, then there are service calls for that, and

they all use command\_num. If you are using non-blocking VIP API commands, then you must invoke the following attributes so that the response gets generated successfully during sequence execution:

- ❖ set\_response\_queue\_error\_report\_disabled(1) : when UVM 1.1d or UVM 1.2 is selected
- ❖ set\_response\_queue\_error\_report\_enabled(0) : when IEEE UVM is selected

#### 11.19.4 Setting the TH and PH Bits Using the Driver Application Class

You can set the TH and PH bits using the Driver App interface class and transaction class: svt\_PCIE\_driver\_app\_transaction. Note the following members to implement this capability:

```
/**  
 * Transaction Hint bit, indicates presence of TLP Processing Hints.  
 */  
rand bit th      = 0;  
  
/**  
 * Processing Hints field.  
 */  
rand ph_enum     ph = BIDIRECTIONAL;  
  
/**  
Steering tag used when TLP processing hint is present. Bits [7:0] are part of the  
request header. If the TH bit is set, then the steering tag field will always be  
substituted for the tag field for memory writes. In addition, the steering tag field  
will always be substituted for the byte enables for memory reads/atomic operations.  
*/  
rand bit [7:0] st;
```

#### 11.19.5 Fast Link Training

A common way speed up link training is to decrease the number of training sets transmitted in Polling.Active. The VIP supports this option, which is controlled by the Physical Layer configuration member:

```
rand int unsigned attribute svt_PCIE_pl_configuration::num_tx_ts1_in_polling_active =  
SVT_PCIE_NUM_TX_S1_IN_POLLING_ACTIVE_DEFAULT
```

This member sets the number of training sets the LTSSM must transmit in Polling.Active before exiting this state. This parameter and all LTSSM timeout parameters should be set to match whatever values are used in the DUT in order to obtain valid results during abbreviated link training.

#### 11.19.6 When to Invoke Service Calls

You should not make any service calls until after the VIP is properly configured and initialized. For example, you should not call the hot unplug service call while the LTSSM is still in its initial state. The hot unplug call may immediately kick the LTSSM into detect before it has a chance to finish initializing.

#### 11.19.7 Exceptions and Scrambler Control Bits

The svt\_PCIE\_pl\_proxy code has been implemented so that if there is a svt\_PCIE\_symbol\_exception, then the svt\_PCIE\_symbol\_exception->scrambler\_control bits are used (except when error\_kind == "NO\_ERROR").

You must set the scrambler\_control bits for all symbols when using svt\_PCIE\_symbol\_exception class. The following table shows the values available to you with the scrambler\_control enum:

**Table 11-8 Values for Setting Control Bits of Scrambler**

| Name                     | Value | Description                                                                                                                                                     |
|--------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NONE                     | b'00  | Disables scrambler for the specified symbol.                                                                                                                    |
| FORCE_SCRAMBLE           | b'01  | Forces the scrambler to scramble the symbol to be transmitted (even if it is not supposed to be scrambled as per PCIe rules).                                   |
| INIT_SCRAMBLER           | b'10  | Resets and initializes scrambler. The specified symbol is not scrambled.                                                                                        |
| INIT_AND_FORCE_SCRAMBLER | b'11  | Resets, initializes scrambler and forces the scrambler to scramble the symbol to be transmitted (even if it is not supposed to be scrambled as per PCIe rules). |

Summary: when a symbol is changed then the scrambler\_control needs to reflect what you wants to occur for this symbol.

### 11.19.8 User TS1 Ordered Set Notes

User TS1s Ordered Sets can only be used in legitimate LTSSM states. You can formulate and send user TS OS only in those LTSSM states where it is legitimate to send a TS OS. The Ordered Set creation task would simply stop those default TS Ordered Sets, and let the user TS go on the bus.

Note the following:

- ❖ User TS1 OS replace outgoing TS1's, but they do not override all outgoing data.
- ❖ Users will never see a user TS1 OS in Recovery.Idle because the LTSSM is required to send idles.
- ❖ For users requiring TS1 to be sent in Recovery.Idle, the best way to do this is to start up the user TS in the state before Recovery.Idle (recovery.rcvrcfg), and turn on user TS2. The LTSSM will not make a state transition while the user TS are turned on.

```
`uvm_info(get_type_name(), $sformatf("Begin process set_tx_ts1_pattern_seq 2nd
time\n"), UVM_NONE);
  set_tx_ts1_pattern_seq.randomize() with {
    set_tx_ts1_pattern_seq.user_tx_ts_enable          == 1'b1;
    set_tx_ts1_pattern_seq.min_user_tx_ts_burst       == 1;
    set_tx_ts1_pattern_seq.max_user_tx_ts_burst       == 1;
    set_tx_ts1_pattern_seq.min_user_tx_ts_spacing     == 2;
    set_tx_ts1_pattern_seq.max_user_tx_ts_spacing     == 2;
  };
};
```

### 11.20 Up/Down Configure

As part of bandwidth management and means to optimize power consumption, PCIe protocol supports changing the link width even after the TLP traffic has started (that is, Up/Down configure implies changing link width when link\_up is 1). RC and EP VIP instances support this protocol feature and can act an initiator or target of the link width change request.

The following methods, service requests, and class variables are required to achieve the desired functionality. For more details, see HTML class reference documentation.

## Service Requests

```
svt_PCIE_pl_service
```

## Control Methods

```
svt_PCIE_pl_configuration::set_link_width_values( , , )
svt_PCIE_device_agent::reconfigure_via_task(). Alternatively one can use
svt_PCIE_device_agent_service requests with svt_PCIE_device_agent_service::service_type
= svt_PCIE_device_agent_service::REFRESH_CFG
```

## Control Properties

```
svt_PCIE_pl_configuration::upconfigure_capable
svt_PCIE_pl_configuration::enable_upconfigure_support
svt_PCIE_pl_configuration::link_width
svt_PCIE_pl_configuration::mpipe_turn_off_unused_lanes_after_initial_link_training
svt_PCIE_pl_configuration::turn_off_unused_lanes_on_downconfigure
svt_PCIE_pl_configuration::use_rx_elec_idle_to_turn_on_lanes_in_config_linkwidth_start
svt_PCIE_pl_service::service_type = svt_PCIE_pl_service::INITIATE_LINK_WIDTH_CHANGE
```

## Status Properties

```
svt_PCIE_pl_status::initial_negotiated_link_width
svt_PCIE_pl_status::negotiated_link_width
svt_PCIE_pl_status::configured_link_width
svt_PCIE_pl_status::current_link_width
svt_PCIE_pl_status::upconfigure_capable
```

## Use Model for SVT PHY Layer Service Request Initiate\_Link\_Width\_Change

The service request directs the LTSSM to change the link width of a link that is already in link up state. The VIP LTSSM shall service this request from states L0/TX\_L0\_Rx\_L0s/L1. Issuing the service request when VIP LTSSM is not in one of the above listed states will result in the service request being ignored. This service request must be used in conjunction with the properties in svt\_PCIE\_pl\_configuration class.

1. Set the desired link width, supported link width and expected link width properties using the method `set_link_width_values` provided in class `svt_PCIE_pl_configuration`.
2. Invoke `reconfigure_via_task` or issue `REFRESH_CFG` service request so that the values communicated via above step percolate to VIP's local copy of the configuration object.
3. Issue `svt_PCIE_pl_service::INITIATE_LINK_WIDTH` change service request and wait for the LTSSM to transition from L0/L1/RX.L0s -> Recovery ->Config -> L0.
4. In case the VIP instance is the target of link width change request initiated by its partner (that is, the DUT), the testbench can set the appropriate value of `expected_link_width` by using `set_link_width_values`.



If `set_link_width_values` method takes one input—that is, maximum width of the DUT, then VIP auto-computes supported and expected widths based on the value provided.

For correct setup, set the width to be attempted—that is, configured or number of physical lanes available and should not be changed during the simulation (supported link widths and the final expected width). The supported widths input has to be a superset of expected link width, otherwise VIP may issue link width not supported warnings as shown in the following example:

```
If set_link_width_values (16, 32'h0F, 12) // Here, maximum width is 16 and
supported link width vector 32'h0F (that is, 0000_1111 implies only supported upto link width 8)
and expected link width is 12.
```

```
UVM_WARNING @ 0.000 ns: reporter [is_valid] Invalid expected_link_width
of 12 provided, must be <= 8.
```

To avoid this warning, set `set_link_width_values` to 16, 32'h3F, 12.

## 11.21 Lane Reversal

The order of lanes in a multi-lane PCIe link may require a change as part of the physical link training. This feature is known as lane reversal and is traditionally verified by redoing the testbench connections between VIP instance and DUT instance thus adding a compile dependency. PCIe SVT VIP offers run time control to select the order of lanes.

### Control Properties

The `svt_PCIE_pl_configuration::lane_reversal_mode` can take any of the four enumerated values UNSUPPORTED, FORCED, SUPPORTED, FORCED\_AND\_SUPPORTED. For more details, see HTML class reference documentation.

### Status Properties

The `svt_PCIE_pl_status::lanes_reversed` which indicates lanes are revered either due to wiring, or FORCING lane reversal from the VIP.

### Use Model for Lane Reversal Feature

- ❖ `svt_PCIE_pl_configuration::lane_reversal_mode` must be modified while the VIP LTSSM is in DETECT state (before the training is initiated).
- ❖ `svt_PCIE_pl_configuration::lane_reversal_mode = FORCED_AND_SUPPORTED` is not applicable to EP VIP instance.
- ❖ Note that the lane number value passed to other VIP API (equalization coefficients control, receiver present control, lane polarity control, and so on) use logical lane number, therefore enabling lane reversal will not have any impact on the existing tests.

## 11.22 Lane Reversal with Different Link Width Configurations

Usage notes for supported link width with lane reversal enabled.

- ❖ Set the `MAX_SUPPORTED_DUT_LINK_WIDTH = <user_link_width>`

- ❖ Set svt\_PCIE\_pl\_configuration attribute lane\_reversal\_mode to FORCED.
- ❖ Call the set\_link\_width\_values function for changing the link width
  - The set\_link\_width\_values function accepts the following three inputs:
    - ◆ link\_width\_value (svt\_PCIE\_pl\_configuration: link\_width\_value)
    - ◆ supported\_link\_width\_vector\_value (svt\_PCIE\_pl\_configuration: supported\_link\_width\_vector\_value)
    - ◆ expected\_link\_width\_value (svt\_PCIE\_pl\_configuration: expected\_link\_width\_value)
      - ◆ The [link\\_width\\_value \(svt\\_PCIE\\_pl\\_configuration: link\\_width\\_value\)](#) must be same as DUT link width value.
      - ◆ The [supported\\_link\\_width\\_vector\\_value \(svt\\_PCIE\\_pl\\_configuration: supported\\_link\\_width\\_vector\\_value\)](#) must have all the possible link widths a VIP can support from 1 up to link\_width\_value value.
  - i. When unset (second argument) in the function call, it prompts VIP to set supported\_link\_width\_vector\_value to support all the possible link widths from 1 up to link\_width\_value value.

The controls for supported link width vector are as follows:

**Table 11-9 Controls for Supported Link Width Vector**

| Link Width | supported_link_width_vector |
|------------|-----------------------------|
| 1          | 32'h01                      |
| 2          | 32'h03                      |
| 4          | 32'h07                      |
| 8          | 32'h0F                      |
| 12         | 32'h1F                      |
| 16         | 32'h3F;                     |
| 32         | 32'h7F;                     |

- ◆ [expected\\_link\\_width\\_value \(svt\\_PCIE\\_pl\\_configuration: expected\\_link\\_width\\_value\)](#): The expected negotiated link width value. This value must be same as supported link width vector's link width value.
- i. When unset in the function call, it prompts VIP to set expected\_link\_width value same as the value of link\_width\_value argument.

#### Example 11-4 VIP-DUT Setup

- ❖ MAX\_SUPPORTED\_DUT\_LINK\_WIDTH = 16
- ❖ Set the set\_link\_width\_values (16, 32'h03, 2) for VIP // Here Supported link width vector 32'h03 and expected link width is 2
- ❖ Set the lane\_reversal\_mode to FORCED for VIP
- ❖ The link up happens at X2 on [Lane 3, Lane 2]

**Example 11-5 VIP-DUT Setup**

- ❖ MAX\_SUPPORTED\_DUT\_LINK\_WIDTH = 32
- ❖ Set the set\_link\_width\_values (32, 32'h01, 1) for VIP // Here Supported link width vector 32'h01 and expected link width is 1
- ❖ Set the lane\_reversal\_mode to FORCED for VIP
- ❖ The link up happens at X1 on [Lane 31].

**Example 11-6 VIP-DUT Setup**

- ❖ MAX\_SUPPORTED\_DUT\_LINK\_WIDTH = 8
- ❖ Set the set\_link\_width\_values (8, 32'h07, 4) for VIP // Here Supported link width vector 32'h04 and expected link width is 4
- ❖ Set the lane\_reversal\_mode to FORCED for VIP
- ❖ The link up happens at X4 [Lane7, Lane6, Lane5, Lane4]

**Example 11-7 VIP-VIP Setup or PHY-DUT Setup**

- ❖ MAX\_SUPPORTED\_DUT\_LINK\_WIDTH = 8
- ❖ Set the set\_link\_width\_values (8, 32'h01, 1) for VIP(RC) // Here Supported link width vector 32'h04 and expected link width is 1
- ❖ Set the lane\_reversal\_mode for VIP(RC) to FORCED
- ❖ Set set\_link\_width\_values (8, 32'h07, 4) for VIP(EP) // Here Supported link width vector 32'h04 and expected link width is 4
- ❖ Set the lane\_reversal\_mode for VIP(EP) to SUPPORTED
- ❖ The link up happens at X1 [Lane7]

**Example 11-8 VIP-VIP Setup or PHY-DUT Setup**

- ❖ MAX\_SUPPORTED\_DUT\_LINK\_WIDTH = 8, Lane Reversal ENABLED
- ❖ Set the set\_link\_width\_values (8) for VIP(RC) // Here Supported link width vector 32'h0F (depends upon the first Argument) and expected link width is 8(depends upon the first argument)
- ❖ Set the lane\_reversal\_mode for VIP(RC) to FORCED
- ❖ Set the set\_link\_width\_values (8) for VIP(EP) // Here Supported link width vector 32'h0F (depends upon the first Argument) and expected link width is 8 (depends upon the first argument)
- ❖ Set the lane\_reversal\_mode for VIP(EP) to SUPPORTED
- ❖ The link up happens at X8 [Lane7, Lane6, Lane5, Lane4, Lane3, Lane2, Lane1, Lane0]



- For detailed description of lane\_reversal\_mode and set\_link\_width\_values method, see svt\_PCIE\_pl\_configuartion class in the HTML class reference documentation.
- The description in the previous section shows the use of set\_link\_width\_values to control the initial link width (before physical link up transitions from 0 to 1). In subsequent course of simulation (that is, post link up is set to 1) if test intends to change the link width, then link\_width\_value (first argument of method set\_link\_width\_values) value must be modified and it is recommended to retain supported\_link\_width\_vector\_value as is by resupplying its current value as input to the method.

## 11.23 User-Supplied Memory Model Interface

The user-supplied memory interface allows you to direct the SVT PCIe VIP application layer to utilize an external memory model to store TLP payloads. This can be useful in systems where memory is allocated from a central resource.

The package class `svt_mem_backdoor_base` provides the base API between the `svt_pcie_mem_target` and a desired memory model. `svt_pcie_mem_target_gmem_model` (generic memory model) is the default implementation of this interface and provides the base memory model of the application layer `mem_target` component. The model provides an example of the currently utilized and required minimum features of the `svt_mem_backdoor_base` API by the `mem_target`.

You can extend this class to implement linkage to your memory model and map the interface through the `config_db` for `mem_target` use. Required functions to overload in the extended user memory interface class are `peek_base`, `poke_base` and `free_base`.

The `config_db` must be set during initial configuration in the build phase. Overrides of the user memory model will be ignored during subsequent phases and reconfiguration operations.

Perform the following steps to connect a user memory interface object:

1. Extend the model `svt_pcie_mem_target_gmem_model` and overload the functions `poke_base`, `peek_base` and `free_base` to communicate with your memory model.
2. In test `build_phase` of the test or environment class, construct an extended `mem` model object.
3. Pass the memory interface object handle to `mem_target` instance through `config_db` as `user_gmem_model`.

Example override code:

```
class user_gmem_model extends svt_pcie_mem_target_gmem_model;  
...  
endclass  
  
...  
virtual function void build_phase(uvm_phase phase);  
    // handle to the user's gmem implementation  
    user_gmem_model user_model;  
  
    // Build up default test and environment  
    super.build_phase(phase);  
  
    /*  
     * Create and assign a user override model IN BUILD PHASE  
     */  
    user_model = new("user_model", this);  
    svt_config_object_db#(svt_mem_backdoor_base)::set(this, "<relative path to pcie  
device>.mem_target", "user_gmem_model", user_model);  
  
endfunction
```

`mem_target` can return the memory interface object handle at any time with `svt_pcie_mem_target::get_backdoor()`:

```
memory interface handle = <svt_pcie_vip_instance>.mem_target.get_backdoor();
```

For more information about the API features of `svt_pcie_mem_target_gmem_model` and `svt_mem_backdoor_base`, see HTML class reference documentation.

## 11.24 External Clocking and Per Lane Clocking for Serial Interface

The PCIe VIP supports the following clocking modes:

- ❖ Internal transmit bit clock mode - VIP serial transmission depends on internally generated clock.
  - ◆ Common clock for all lanes - Internally generated clock is common for all lanes.
    - ✧ Enabled by setting `ENABLE_PER_LANE_CLOCKING = 0` and `TRANSMIT_BIT_CLOCK_MODE = 0`.
  - ◆ Per lane clocking - Internally generated clocks are on per lane basis.
    - ✧ Enabled by setting `ENABLE_PER_LANE_CLOCKING = 1` and `TRANSMIT_BIT_CLOCK_MODE = 0`.
- ❖ External transmit bit clock mode - VIP expects external bit clock at physical transmission rate fed to the VIP as input. In this mode, VIP assumes that the jitter if any present is applied to the externally supplied clock.
  - ◆ Common clock for all lanes - Externally provided clock is expected to be common for all lanes.
    - ✧ Enabled by setting `ENABLE_PER_LANE_CLOCKING = 0` and `TRANSMIT_BIT_CLOCK_MODE = 1`.
  - ◆ Per lane clocking - Externally provided clocks are expected to be on per lane basis.
    - ✧ Enabled by setting `ENABLE_PER_LANE_CLOCKING = 1` and `TRANSMIT_BIT_CLOCK_MODE = 1`.

### 11.24.1 Enabling External Clocking and Per Lane Clocking Modes

- ❖ External Clocking mode: External clocking is disabled by default in PCIe VIP. You can use the following Verilog parameter to enable external transmit bit clock mode.

| Attribute                            | Type              | Description                                                                                                                                                                                                                            | Comments                               |
|--------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| <code>TRANSMIT_BIT_CLOCK_MODE</code> | Verilog Parameter | Verilog parameter to specify clocking mode. <ul style="list-style-type: none"> <li>• 0 =&gt; internal bit clocks are used to transmit serial data.</li> <li>• 1 =&gt; external bit clocks are used to transmit serial data.</li> </ul> | Attribute is applicable for all lanes. |

For example,

Set up for configuring external clocking mode from RC:

```
spd_0.SVT_PCIE_UI_TRANSMIT_BIT_CLOCK_MODE = 1;
```

- ❖ External clocking signaling interface: The VIP model has per lane per link speed clocking speed inputs for external bit transmit clock mode. This gives you an option to connect to the VIP model in external transmit bit clock mode when you do not have link speed multiplexed clocking pin. If you have a single output wire per lane for gen1/gen2/gen3/gen4 link speed, then you can connect the VIP model per lane per link speed pin with the link speed multiplexed on per lane basis. You can use the following signals to connect for external clocking mode.

Table 11-10 Signals to connect for external clocking mode

| Attribute | Type | Description | Comments |
|-----------|------|-------------|----------|
|-----------|------|-------------|----------|

**Table 11-10 Signals to connect for external clocking mode**

|                                                    |       |                                                                                                                                                                                      |                                        |
|----------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| svt_PCIE_ext_clk_intf::logic [31:0]<br>tx_clk_2_5g | Input | Per lane external bit clock at Gen1(2.5GTS) rate. The interface signal is defined for all 32 lanes but you must connect the maximum number of physical lanes your design supports    | Attribute is applicable for each lane. |
| svt_PCIE_ext_clk_intf::logic [31:0]<br>tx_clk_5g   | Input | Per lane external bit clock at Gen2(5GTS) rate.<br>The interface signal is defined for all 32 lanes but you must connect the maximum number of physical lanes your design supports.  | Attribute is applicable for each lane. |
| svt_PCIE_ext_clk_intf::logic [31:0]<br>tx_clk_8g   | Input | Per lane external bit clock at Gen3(8GTS) rate.<br>The interface signal is defined for all 32 lanes but you must connect the maximum number of physical lanes your design supports.  | Attribute is applicable for each lane. |
| svt_PCIE_ext_clk_intf::logic [31:0]<br>tx_clk_16g  | Input | Per lane external bit clock at Gen4(16GTS) rate.<br>The interface signal is defined for all 32 lanes but you must connect the maximum number of physical lanes your design supports. | Attribute is applicable for each lane. |

For example,

Set up for configuring external clocking mode from RC:

```
spd_0.SVT_PCIE_UI_TRANSMIT_BIT_CLOCK_MODE = 1;
assign port_if_0.ext_clk_if.tx_clk_2_5g = spd_1.m_ser.port0.tx_bit_clk;
assign port_if_0.ext_clk_if.tx_clk_5g = spd_1.m_ser.port0.tx_bit_clk;
assign port_if_0.ext_clk_if.tx_clk_8g = spd_1.m_ser.port0.tx_bit_clk;
assign port_if_0.ext_clk_if.tx_clk_16g = spd_1.m_ser.port0.tx_bit_clk;
```

- ❖ Per lane clocking mode: Per lane clocking is disabled by default in PCIe VIP. You can use following Verilog parameter to enable per lane clocking in conjunction with enabling external clocking mode.

| Attribute                | Type              | Description                                                 | Comments                               |
|--------------------------|-------------------|-------------------------------------------------------------|----------------------------------------|
| ENABLE_PER_LANE_CLOCKING | Verilog Parameter | Verilog parameter to enable per lane clocking in vip model. | Attribute is applicable for all lanes. |

For example,

```
spd_0.SVT_PCIE_UI_ENABLE_PER_LANE_CLOCKING = 1;
spd_1.SVT_PCIE_UI_ENABLE_PER_LANE_CLOCKING = 1;
```



- If you are not running with external transmit bit clock mode, then it is not required to connect to the VIP model ext\_\*\_tx\_bit\_clk clocking signals.
- If per lane clocking is disabled and VIP is running in external clocking mode then you only need to connect to VIP lane 0 clock (tx\_clk\_2\_5g[0], tx\_clk\_8g[0], tx\_clk\_8g[0], tx\_clk\_16g[0]).
- VIP is required to have correct external clocks even in low power states where reference clock might be switched off, so the onus on providing the correct clock even in case of low power scenario is on the testbench.
- You must set the VIP model external clocks, tx\_clk\_2\_5g, tx\_clk\_5g, tx\_clk\_8g, and tx\_clk\_16g irrespective of the supported speed.

## 11.25 Callbacks

The callback used to alter transmitting symbols is pre\_symbol\_out\_put (svt\_PCIE\_p1 PL, svt\_PCIE\_symbol symbols[]). This symbol level callback is issued by the component at every symbol time after gathering all the symbols to be transmitted on the PCIe link. This is the last chance to the user to corrupt any symbol before it goes on the link. The events associated with this callback are as follows:

- ❖ TLP\_STARTED – TLP started with this symbol.
- ❖ DLLP\_STARTED – DLLP started with this symbol.
- ❖ SKP\_STARTED – SKP started with this symbol.
- ❖ TS1\_STARTED – TS1 started with this symbol.
- ❖ TS2\_STARTED – TS2 started with this symbol.
- ❖ EIOS\_STARTED – EIOS started with this symbol.
- ❖ EIEOS\_STARTED – EIEOS started with this symbol.
- ❖ SDS\_STARTED – SDS started with this symbol.
- ❖ EDS\_STARTED – EDS started with this symbol.
- ❖ EDB\_TOKEN\_STARTED – EDB token started with this symbol
- ❖ CTRL\_SKP\_STARTED – CTRL-SKP started with this symbol.

Note that all the above events are triggered when the symbol is ready to be transmitted and will not remain triggered while transmitting the related ordered set.

### Example 11-9 Usage Example

In the following example, a SKP-END of the transmitting Ctrl-SKP OS is being changed from 78h to FFh.

```

virtual function void pre_symbol_out_put(svt_PCIE_p1 pl, svt_PCIE_symbol symbols[]);
    if(error_count < 1) begin
        if(symbols[0].symbol_event == svt_PCIE_symbol::CTRL_SKP_STARTED &&
pl.status.current_speed == svt_PCIE_p1_status::SPEED_16_0G) begin
            `svt_xvm_note("TEST: pre_symbol_out_put_callback",$sformat("\n found event
svt_symbol::CTRL_SKP_STARTED.\n"))
            ctrl_skp_found = 1;
        end
        if(ctrl_skp_found) begin
            if((ordered_set_idx == 0 || ordered_set_idx == 0 || ordered_set_idx == 4 ||
ordered_set_idx == 8 || ordered_set_idx == 12 || ordered_set_idx == 16 ||
ordered_set_idx == 20) && symbols[0].data == 8'h78) begin // catching CTRL-SKP End 78h
                for(int i=0; i< symbols.size(); i++) begin
                    svt_PCIE_symbol_exception_list sym_exc_list = new();

```

```
        svt_PCIE_symbol_exception sym_exc = new();
        `svt_xvm_debug("TEST: pre_symbol_out_put_callback", $sformatf("\n Corrupting
Ctrl-SKp End in lane %0d.\n", ordered_set_idx))
        sym_exc.error_kind = svt_PCIE_symbol_exception::CORRUPT_DATA_VALUE_ONLY;
        sym_exc.corrupted_data = 'hFF;
        sym_exc.scrambler_control = svt_PCIE_symbol_exception::FORCE_SCRAMBLE;
        sym_exc_list.add_exception(sym_exc);
        symbols[i].exception_list = sym_exc_list;
    end
    error_count++;
end
ordered_set_idx++;
end
end
endfunction
```

### 11.25.1 Rx Symbol Callback

The callback used to get the received symbols information is `post_symbol_in_get` (`svt_PCIE_pl` PL, `svt_PCIE_symbol` `symbols[]`). This symbol level callback is issued by the component at every symbol time after gathering all the symbols being received on the PCIe link. The event associated with this callback are as follows:

- ❖ `SKP_ENDED` – SKP ended with this symbol.
- ❖ `TS1_ENDED` – TS1 ended with this symbol.
- ❖ `TS2_ENDED` – TS2 ended with this symbol.
- ❖ `EIOS_ENDED` – EIOS ended with this symbol.
- ❖ `EIEOS_ENDED` – EIEOS ended with this symbol.
- ❖ `SDS_ENDED` – SDS ended with this symbol.
- ❖ `CTRL_SKP_ENDED` – CTRL-SKP ended with this symbol.

Note that all the above events are triggered when the symbol is completely received and will not remain triggered while the related ordered set is being received.

#### Example 11-10 Usage Example

The following example increments a counter whenever a SKP OS and SDS OS is received.

```
virtual function void post_symbol_in_get(svt_PCIE_pl pl, svt_PCIE_symbol symbols[]);
    if(symbols[0].symbol_event == svt_PCIE_symbol::SKP_ENDED) begin
        skp_count++;
        `svt_xvm_debug("TEST: post_symbol_in_get_callback", $sformatf("\n Received SKP OS..
RCVD SKP OS count is %0d.\n", skp_count))
        $display("symbols.size() %0d", symbols.size());
    end
end
```

### 11.25.2 Framing Token Callback

The callback used to get the received framing token contents at 128/130b is `framing_token_in_get` (`svt_PCIE_pl` pl, `svt_PCIE_symbol` `symbol`). When this callback gets executed the `symbol_event` also gets populated with appropriate token type STP/EDS/EDB/SDP/IDL.

Therefore, at the execution of callback `framing_token_in_get` you can get framing token type in `symbol_event`, framing token contents in `rx_framing_token_data` and last byte of the received framing token in `data` variable. The event associated with this callback are as follows:

- ❖ STP\_FRAMING\_TOKEN\_ENDED - STP framing token ended with this symbol.
- ❖ EDS\_FRAMING\_TOKEN\_ENDED - EDS framing token ended with this symbol.
- ❖ EDB\_FRAMING\_TOKEN\_ENDED - EDB framing token ended with this symbol.
- ❖ SDP\_FRAMING\_TOKEN\_ENDED - SDP framing token ended with this symbol.
- ❖ IDL\_FRAMING\_TOKEN\_ENDED - IDL framing token ended with this symbol.

Note the framing tokens will be populated in the following manner in the register `rx_framing_token_data`:

```
* STP : 32'h{TLPLength[3:0], F, FP, TLPLength[10:4], FCRC, TLPSequenceNumber}
* EDS : 32'h1f809000
* EDB : 32'hc0c0c0c0
* SDP : 32'hf0ac0000
* IDL : 32'h00000000
```

### Example 11-11 Usage Example

The following example receives the framing tokens through callback in the test and compares them with the specification defined framing token encodings.

```
virtual function void framing_token_in_get(svt_PCIE_p1 p1, svt_PCIE_symbol symbol);
    if (symbol.symbol_event == svt_PCIE_symbol::EDS_FRAMING_TOKEN_ENDED)
        begin
            if (symbol.rx_framing_token_data != 32'h1f809000)
                `svt_xvm_error("rc_framing_token_in_callback", "RC received EDS with incorrect
EDS token data.");
            end
        else if (symbol.symbol_event == svt_PCIE_symbol::SDP_FRAMING_TOKEN_ENDED)
            begin
                if (symbol.rx_framing_token_data != 32'hf0ac0000)
                    `svt_xvm_error("rc_framing_token_in_callback", "RC received SDP with incorrect
SDP token data.");
                end
            else if (symbol.symbol_event == svt_PCIE_symbol::EDB_FRAMING_TOKEN_ENDED)
                begin
                    if (symbol.rx_framing_token_data != 32'hc0c0c0c0)
                        `svt_xvm_error("rc_framing_token_in_callback", "RC received EDB with incorrect
EDB token data.");
                    end
                else if (symbol.symbol_event == svt_PCIE_symbol::IDL_FRAMING_TOKEN_ENDED)
                    begin
                        if (symbol.rx_framing_token_data != 32'h00000000)
                            `svt_xvm_error("rc_framing_token_in_callback", "RC received IDL with incorrect
IDL token data.");
                        end
                    endfunction
```

## 11.26 Generating MSI/MSI<sub>x</sub> with PCIe VIP

An MSI/MSI-X is a MemWr targeting a specific address in the system.

### 11.26.1 Configuring EP VIP for MSI/MSIx Generation

The PCIe VIP as EP needs to send the transactions to the particular address specified in the Extended Capability Register. RC (DUT) is not required to configure the MSI capability of EP VIP. For a VIP model configured as the endpoint, you can refer to the following code snippet to generate MSI requests towards the RC DUT.

```
class pcie_device_msi_sequence extends svt_PCIE_driver_app_transaction_base_sequence;
  rand svt_PCIE_driver_app_transaction write_transaction;

  /**
   * Factory Registration.
   */
  `svt_xvm_object_utils(pcie_device_msi_sequence)

  // Constraints for MSI Write
  constraint c_msi_write {
    write_transaction.transaction_type == svt_PCIE_driver_app_transaction::MEM_WR;
    write_transaction.address == 'h1cff0000; // MSI write address, change this as per
    your system
    write_transaction.length == 1;
    write_transaction.first_dw_be == 4'b1111;
    write_transaction.last_dw_be == 4'b0000;
    write_transaction.payload[0] == 'hbaadbaad; // Message Vector
    write_transaction.address_translator == 0;

    write_transaction.ep == 0;
    write_transaction.block == 0;
  }

  extern virtual task body();

  extern function new(string name = "pcie_device_msi_sequence");
endclass : pcie_device_msi_sequence

function pcie_device_msi_sequence::new(string name);
  super.new(name);

  /** Set up the write transaction */
  `uvm_create(write_transaction)
endfunction : new

task pcie_device_msi_sequence::body();
  // Sending MSI
  `uvm_info("body", "Entered...", UVM_LOW)
  `uvm_send(write_transaction);
  `uvm_info("body", "Exiting...", UVM_LOW)
endtask
```

### 11.26.2 Configuring RC VIP for MSI/MSIx Generation

The PCIe VIP as RC does not have a default address. MSI interrupts are at the application level or system level, so the test needs to select an MSI address. The DUT has an MSI Capability Structure in the configuration space (location is specific to the DUT) that the PCIe VIP needs to transmit CfgWr to set the address that the DUT uses.

The RC VIP treats the MSI as a normal Memory Write. So, there is no configuration needed for RC VIP. Your test needs to be setup to look for the MSI address in MWr's to determine that the EP has sent the interrupt.

# 12 PCIe Device Agent

---

This chapter discusses the following topics:

- ❖ [Overview](#)
- ❖ [Configuration](#)
- ❖ [Status](#)
- ❖ [Sequencers](#)

## 12.1 Overview

The PCIe UVM VIP, at its highest level, is composed of the `svt_PCIE_device_agent` class, which encapsulates the PCIe Agent (Class `type=svt_PCIE_agent`)—an application layer that comprises of Driver Application, Requester Application, and Target Application (Memory, I/O, Configuration database).

**Figure 12-1 Block Diagram – PCIe UVM VIP**

- ❖ The Application Layer: The PCIe VIP has a layer on top of the PCIe stack representing the software layer in a real application of the PCIe bus. The application layer is responsible for generating and handling transactions. The application layer of the PCIe VIP is the layer that is typically programmed by the test to generate stimulus or respond to the incoming requests. The application layer of the PCIe VIP has the following blocks that perform specific functions:
  - ◆ Driver Application (Type=*svt\_PCIE\_driver\_app*, Instance=*driver[0]*): The Driver application provides a simple interface that can be used to quickly create PCIe transaction requests (memory read/write request, I/O read/write requests etc.). The application deals with driver application transaction objects (*svt\_PCIE\_driver\_app\_transaction*) which is an abstract description of the transaction layer packet.
  - ◆ Requester Application (Type=*svt\_PCIE\_requester\_app*, Instance=*requester*): The requester application can be used to generate PCIe memory/read transaction to a remote target. The application can be configured to choose addresses at random (constrained by

minimum/maximum configuration parameters) and have varying lengths (again, constrained by minimum/maximum configuration parameters) and generate traffic at a requested bandwidth (again, constrained by minimum/maximum configuration parameters). This application will be useful where a background exerciser of write/read request is required.

- ◆ Target Application (Type=svt\_PCIE\_target\_app, Instance=target[0]): The target application is the block that automatically responds to various inbound requests. Read transaction requests can be optionally broken up into multiple completions, potentially interleaved with other read completions by configuration. The target application has auxiliary blocks that represent the completion memory used while generating completions. These blocks include Memory Target, IO Target and Configuration Database. The blocks comprise of a sparse memory allowing a wide variety memory/IO addresses/registers to be accessed by a DUT.
- ◆ Memory Target (Type=svt\_PCIE\_mem\_target, Instance=mem\_target): The memory target is the PCIe VIP's sparse memory model used to store write data and return read data to the incoming memory requests. This sparse memory model responds to a wide variety of addresses (32-bit and 64-bit) when accessed by a requester. The memory target has APIs to write into its sparse memory via backdoor or read from its sparse memory via backdoor to meet different kinds of testing requirements.
- ◆ I/O Target (Type=svt\_PCIE\_io\_target, Instance=io\_target): The I/O target is the PCIe VIP's sparse memory model used to store write data and return read data to the incoming I/O requests. This sparse memory model responds to a wide variety of addresses (32-bit and 64-bit) when accessed by a requester. The I/O target has APIs to write into its sparse memory via backdoor or read from its sparse memory via backdoor to meet different kinds of testing requirements.
- ◆ Configuration Database (Type=svt\_PCIE\_cfg\_database, Instance=svt\_PCIE\_target\_app::cfg\_database): The configuration database is the PCIe VIP's sparse memory model used to store write data and return read data to the incoming configuration requests. This sparse memory model responds to a wide variety of addresses (type 0, type 1, extended capability registers, and so on) when accessed by a requester. The configuration database has APIs to write into its sparse memory via backdoor or read from its sparse memory via backdoor to meet different kinds of testing requirements.
- ❖ PCIe Agent: The PCIe Agent encapsulates the UVM drivers that represents the Transaction Layer, the Data-link Layer and the Physical Layer of the PCIe protocol stack. For more details, see [PCIe Agent](#).

## 12.2 Configuration

The PCIe Device Agent is configured using an object of class svt\_PCIE\_device\_configuration. This class has other class objects defined within it to form a hierarchy that corresponds to the hierarchy inside the PCIe Device Agent.



```

-----> tl_cfg (type=svt_PCIE_tl_configuration)
-----> dl_cfg (type=svt_PCIE_dl_configuration)
-----> pl_cfg (type=svt_PCIE_pl_configuration)

```

The PCIe Device Agent is configured using an object of `svt_PCIE_device_configuration` class. This class is comprised of direct variables and class objects that are used to configure other agents/drivers that are part of the device agent. For details about the attributes of this class, see HTML class description of the `svt_PCIE_device_configuration` class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_device_configuration.html`

## 12.2.1 Initial Configuration

The initial configuration of the PCIe Device Agent (and all of its sub-components) is established using the configuration database (`uvm_config_db`) class defined in UVM. The PCIe Device Agent—the recipient of the configuration object has a `uvm_config_db::get()` defined within the `build_phase()` and so the parent test/environment has to specify a `uvm_config_db::set()` in its `build_phase()`. Before calling the `uvm_config_db::set()`, the desired configuration attributes must be set to user-defined values. The example below illustrates the initial configuration step.

The `uvm_config_db::set()` in the illustration above will program the agent and all of its sub-components. In the [Example 12-1](#), only a few parameters from the different layers are shown as being modified and for the rest, a default value is assumed. For the complete list of the configuration attributes and their default values check the HTML class description of `svt_PCIE_device_configuration` at the following location:  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_device_configuration.html`

### Example 12-1

```

class pcie_device_unified_vip_env extends uvm_env;
  ...
  svt_PCIE_device_agent root;
  svt_PCIE_device_configuration root_cfg;
  ...
  function void build_phase( uvm_phase phase );
    super.build_phase( phase );
    ...
    root_cfg = new ("root_cfg");
    // Functions that programs values to different configuration parameter.
    setup_system_defaults(root_cfg);
    // Setting up the UVM agent with its Verilog counterpart.
    root_cfg.model_instance_scope = "test_top.root";
    // Setting the type of the device. In this example a root complex.
    root_cfg.device_is_root = 1;

    // Call the uvm_config_db::set() to set the configuration of the UVM agent.
    // Arg1 & Arg2: context & instance name. Hierarchical path to the object data
    // Arg3: Field name, "cfg" is the field name used by the agent class
    // Arg3: Object/Value being set
    uvm_config_db#(svt_PCIE_device_configuration)::set(this,"root", "cfg",  root_cfg);
    root = svt_PCIE_device_agent::type_id::create("root", this );
    ...
  endfunction

```

```
...
    function void setup_system_defaults (svt_PCIE_device_configuration cfg);
        cfg.pcie_spec_ver = svt_PCIE_device_configuration::PCIE_SPEC_VER_2_1;

        // Programming configuration attributes of the Applications
        cfg.driver_cfg[0].requester_id = 'h300;
        cfg.driver_cfg[0].percentage_use_tlp_digest = 50;

        cfg.target_cfg[0].completer_id = 'h300;
        cfg.target_cfg[0].percentage_use_tlp_digest = 50;
        cfg.target_cfg[0].max_read_cpl_data_size_in_bytes = 512;

        // Programming the configuration attributes of the PCIe protocol layers
        cfg.pcie_cfg.tl_cfg.credit_starvation_timeout = 8000;
        cfg.pcie_cfg.tl_cfg.completion_timeout = 400000;

        cfg.pcie_cfg.dl_cfg. updatefc_timeout_ns = 40000;

        cfg.pcie_cfg.pl_cfg.set_link_width_values(4);
        cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_2_5G);
        cfg.pcie_cfg.pl_cfg.skip_polling_active = 1;
    endfunction
endclass
```

## 12.2.2 Dynamic Configuration

The configuration set during the build of the UVM agent can be dynamically (during the `run_phase`) modified if the test requires a change in the VIP's configuration. The agent provides the following three ways to reconfigure the agent or its sub-components:

1. Using `svt_PCIE_device_agent::reconfigure_via_task()`: This task can be called and a new configuration object with the desired programming can be specified as an input to this task.
2. Using `svt_PCIE_device_agent::refresh_cfg()`: This task can be called to refresh the configuration of the agent or its sub-components based on a `uvm_config_db::set()` that is issued before calling `refresh_cfg()`.
3. Using the `REFRESH_CFG` service request: The PCIe Device Agent supports a service request interface via the service sequencer which is discussed under the sequencers sub-section. Using the service sequencer in the agent class a service request can be placed to refresh the configuration of the agent or sub-components based on a `uvm_config_db::set()` that is issued before requesting a `REFRESH_CFG` service.

It is important to note that before reconfiguring the driver application, you must make sure that the driver is idle. This will ensure the driver is not in the middle of a transaction request or waiting for the completion of a transaction request during the reconfiguration process. Also, the reconfiguration process should not be started when the model is in the reset state. The driver application (also the VIP or any of its sub-components) should not be reconfigured while the mode is in reset as defined in section [Resetting the PCIe VIP](#).

The targeted modification can be on a specific layer of the VIP or across multiple layers depending on what the test is trying to achieve. In the [Example 12-2](#), a typical use of dynamic reconfiguration is shown by using `reconfigure_vias_task()` task. In this example, the intent of reconfiguration is to cause the model to operate at a new PIPE width, PIPE clock rate and link speed after exiting HOT\_RESET.

**Example 12-2**

```
class pcie_pipe_speed_width extends uvm_test;
  `uvm_component_utils(pcie_pipe_speed)
  ...
  task run_phase (uvm_phase phase);
    svt_configuration temp_cfg = null;
    svt_pcie_device_configuration new_cfg = null;

    super.run_phase(phase);
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM gets operational at 2.5G and uses a PIPE model.
    // Link operates at default PCLK rate/PIPE width defined in the PL.
    // PCLK at 2.5G = 250MHz; PIPE width = 8-bits
    // PCLK at 5.0G = 500MHz; PIPE width = 8-bits
    // PCLK at 8.0G = 1000MHz; PIPE width = 8-bits
    // The test initiates a transition to take the LTSSM to HOT_RESET

    wait(env.root.status.pcie_status.pl_status.ltssm_state ==
          svt_pcie_types::HOT_RESET);
    // After a timeout the LTSSM is expected to be in DETECT
    wait(env.root.status.pcie_status.pl_status.ltssm_state ==
          svt_pcie_types::DETECT QUIET);

    // Wait for VIP to be idle before changing configuration
    wait(env.root.status.pcie_status.pl_status.is_pipe_idle == 1 );

    // Fetch the current configuration of the PCIe device agent
    env.root.get_cfg_via_task(temp_cfg);
    $cast(new_cfg, temp_cfg.clone());

    // Program the new values for PCLK rate and PIPE width.
    // Note: the configuration variables are defined in the PL
    // Indices 0, 1 and 2 PCLK rate/PIPE width at Gen1, Gen2 and Gen3
    new_cfg.pcie_cfg.pl_cfg.pclk_rate[0] = svt_pcie_pl_configuration::PCLK_1000_MHZ;
    new_cfg.pcie_cfg.pl_cfg.pclk_rate[1] = svt_pcie_pl_configuration::PCLK_1000_MHZ;
    new_cfg.pcie_cfg.pl_cfg.pclk_rate[2] = svt_pcie_pl_configuration::PCLK_1000_MHZ;
    new_cfg.pcie_cfg.pl_cfg.pipe_width[0] = svt_pcie_pl_configuration::PIPE_8_BITS;
    new_cfg.pcie_cfg.pl_cfg.pipe_width[1] = svt_pcie_pl_configuration::PIPE_8_BITS;
    new_cfg.pcie_cfg.pl_cfg.pipe_width[2] = svt_pcie_pl_configuration::PIPE_8_BITS;

    // Reconfigure the VIP with the newly defined configuration
    new_cfg.pcie_cfg.pl_cfg.set_link_speed_values(`SVT_PCIE_SPEED_8_0G |
      `SVT_PCIE_SPEED_5_0G | `SVT_PCIE_SPEED_2_5G);
    env.root.reconfigure_via_task(new_cfg);
  endtask
endclass
```

Similarly, a reconfiguration of the PCIe Device Agent or its sub-components can be performed using the `refresh_cfg()` function or by requesting a `REFRESH_CFG` service on the agent as illustrated in the [Example 12-3](#).

**Example 12-3**

```
class pcie_pipe_speed_width extends uvm_test;
  `uvm_component_utils(pcie_pipe_speed)
  ...
  task run_phase (uvm_phase phase);
    svt_configuration temp_cfg = null;
    svt_pcie_device_configuration new_cfg = null;
    svt_pcie_device_agent_service_sequence dev_agent_serv_seq;

    super.run_phase(phase);
  ...
  // Assumptions:
  // The UVM test has an instance of UVM environment named 'env'
  // The UVM environment has an instance of the PCIe device agent named 'root'

  // Did a number of things...

  // About to change the configuration of the PCIe VIP

  // Assumptions:
  //   VIP is in DETECT QUIET state
  //   pl_status.is_pipe_idle == 1

  // Fetch the current configuration of the PCIe device agent
  env.root.get_cfg_via_task(temp_cfg);
  $cast(new_cfg, temp_cfg.clone());

  // Modify members inside new_cfg
  // Call the uvm_config_db::set() to set the new configuration.
  uvm_config_db#(svt_pcie_device_configuration)::set(this,"env.root", "cfg",
new_cfg);

  // Refresh the agent with the new configuration (option 1)
  env.root.refresh_cfg();

  ... OR ...

  // Refresh the agent with the new configuration (option 2)
  dev_agent_serv_seq = new();
  dev_agent_serv_seq.service_type = svt_pcie_device_agent_service::REFRESH_CFG;
  dev_agent_serv_seq.start(env.root.device_agent_service_seqr);

  // Do other things
endtask
endclass
```

## 12.3 Status

The PCIe Device Agent provides a set of state values representing the status of its sub-components at anytime in the test simulation. And these state values are encapsulated within the `svt_pcie_device_status` class. The device agent class has an object of type `svt_pcie_device_status` instanced as `status`. For details about the attributes of this class, see HTML class description of the `svt_pcie_device_status` class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/status/class_svt_pcie_device_status.html`

A test can access the `status` object of the device agent in the following two ways:

1. Directly accessing object `svt_PCIE_device_agent::status` as illustrated in [Example 12-2](#) where the test check for the LTSSM state as a control variable.
2. The test can use the `svt_PCIE_device_agent::get_device_status()` function to retrieve the status of the agent and use a local copy of the status object as shown in [Example 12-4](#).



The `get_device_status` function takes an input which is passed by reference.

#### Example 12-4

```
class pcie_pipe_speed_width extends uvm_test;
  `uvm_component_utils(pcie_pipe_speed)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_device_status root_dev_status;
    super.run_phase(phase);
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'

    env.root.get_device_status(root_dev_status);

    // Use root_device_status to check the current status of any layer.
    // An example, LTSSM state value.

    // Do other things
  endtask
endclass
```

## 12.4 Sequencers

The PCIe Device Agent class (`svt_PCIE_device_agent`) has eight UVM sequencer objects to schedule transaction requests or service requests on any of its subcomponent Drivers. A UVM sequencer is an arbiter that controls the transaction flow from multiple stimulus generators. The sequencers communicate with drivers using the TLM interfaces.

**Figure 12-2 Block Diagram – Sequencers**

Blocks named Mem, I/O and CFG are service sequencers corresponding to memory target, I/O target and configuration database UVM drivers.

Sequencers in the PCIe VIP are broadly classified as service sequencers and transaction sequencers.

#### 12.4.1 Service Sequencers

A service sequencer is used to schedule sequences that are referred to as services on any UVM driver in the device agent class. An example of a service request can be a request on the memory target to write/read data in an attempt to load/store the completion memory of the VIP. Service sequences will not generate PCIe transactions on the PCIe bus but they are used to request a change in the behavior or sample a state value of the UVM driver. The device agent class includes the following seven service sequencer objects:

1. Configuration Database Service Sequencer (Type=svt\_pcie\_cfg\_database\_service\_sequencer, Instance=cfg\_database\_seqr): A sequencer used to schedule services such as, backdoor write/read services to configuration database. It feeds service transactions of type svt\_pcie\_cfg\_database\_service to Sequencer Item Pull Port (SIPP) uvm\_seq\_port of UVM driver svt\_pcie\_cfg\_database class.
2. PCIe Device Agent Service Sequencer (Type=svt\_pcie\_device\_agent\_service\_sequencer, Instance=device\_agent\_service\_seqr): A sequencer used to schedule services such as, refresh configuration of the agent. It feeds service transactions of type svt\_pcie\_device\_agent\_service to SIPP device\_agent\_service\_seq\_item\_port of UVM agent svt\_pcie\_device\_agent class.
3. Driver Application Service Sequencer (Type=svt\_pcie\_driver\_app\_service\_sequencer, Instance=driver\_seqr[0]): A sequencer used to schedule services such as, applying reset to the

driver application. It feeds service transactions of type `svt_PCIE_driver_service` to the SIPP `service_seq_item_port` of UVM driver `svt_PCIE_driver_app` class.

4. IO Target Service Sequencer (Type=`svt_PCIE_io_target_service_sequencer`, Instance=`io_target_seqr`): A sequencer used to schedule services such as, backdoor write/read services to the I/O completion space of the VIP. It feeds service transactions of type `svt_PCIE_io_target_service` to the SIPP `seq_item_port` of UVM driver `svt_PCIE_io_target` class.
5. Memory Target Service Sequencer (Type=`svt_PCIE_mem_target_service_sequencer`, Instance=`mem_target_seqr`): A sequencer used to schedule services such as, backdoor write/read services to the memory completion space of the VIP. It feeds service transactions of type `svt_PCIE_mem_target_service` to the SIPP `seq_item_port` of UVM driver `svt_PCIE_mem_target` class.
6. Requester Application Service Sequencer (Type=`svt_PCIE_requester_app_service_sequencer`, Instance=`requester_seqr`): A sequencer used to schedule services such as starting the requester application. It feeds service transactions of type `svt_PCIE_requester_app_service` to the SIPP `seq_item_port` of UVM driver `svt_PCIE_requester_app` class.
7. Target Application Service Sequencer (Type=`svt_PCIE_target_app_service_sequencer`, Instance=`target_seqr[0]`): A sequencer used to schedule services such as, starting the requester application. It feeds service transactions of type `svt_PCIE_requester_app_service` to the SIPP `seq_item_port` of UVM driver `svt_PCIE_requester_app` class.

[Example 12-5](#) shows how you can request a service on the driver application using the driver application service sequencer. The requested service is to wait for the idle state of the driver application.

#### Example 12-5

```
class my_PCIE_test extends uvm_test;
  `uvm_component_utils(my_PCIE_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_driver_app_service_wait_until_idle_sequence drv_app_serv_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
    // the test generated a number of transaction requests using the driver
    application
    drv_app_serv_seq = new();
    drv_app_serv_seq.start(env.root.driver_seqr[0]);
    // End of test. The driver app is idle and so all transaction requests are done.
  endtask
endclass
```

#### 12.4.2 Transaction Sequencers

A transaction sequencer is used to schedule sequences that cause PCIe transactions (TLPs and DLLPs) on the PCIe bus. There is only a single transaction sequencer object in the device agent class:

- ❖ Driver Application Transaction Sequencer  
(Type=svt\_PCIE\_driver\_app\_transaction\_sequencer,  
Instance=driver\_transaction\_seqr[0]): A sequencer used to schedule TLP transactions on the driver application of the VIP. It feeds transactions of type svt\_PCIE\_driver\_app\_transaction to the SIPP seq\_item\_port of UVM driver class svt\_PCIE\_driver\_app.

[Example 12-6](#) shows how you can send a transaction request to the driver using the driver application transaction sequencer.

#### Example 12-6

```
class my_PCIE_test extends uvm_test;
  `uvm_component_utils(my_PCIE_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_driver_app_transaction_mem_write_sequence mem_wr_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
    mem_wr_seq = new();
    mem_wr_seq.randomize with {
      address == 'h8000;
      length == 2;
      first_dw_be == 0;
      last_dw_be == 0;
      traffic_class == 0;
      address_translation == 2'b00;
      foreach(payload[i])
        payload[i] == 'hc0de_0000 + i;
    };
    mem_wr_seq.start(env.root.driver_transaction_seqr[0]);
    // Add end of test criteria.
    // End of test.
  endtask
endclass
```

#### 12.4.3 Virtual Sequencer

The device agent class has a virtual sequencer object of type svt\_PCIE\_device\_virtual\_sequencer instanced as virt\_seqr that connects to all sequencers that are defined under its hierarchy. The sequencer class object has a hierarchical structure that mirrors svt\_PCIE\_device\_agent class. Instead of having UVM drivers/agents as sub-components, it has the UVM sequencer of the corresponding UVM driver/agent.

**Figure 12-3 Block Diagram – Virtual Sequencer**

**Note** Blocks named Mem, I/O and CFG are service sequencers corresponding to memory target, I/O target and configuration database UVM drivers.

The example that illustrates the use of the driver application service sequencer and driver application transaction sequencer can alternatively access these sequencers via the virtual sequencer instance as illustrated in [Example 12-7](#) and [Example 12-8](#).

### Example 12-7

```

class my_pcie_test extends uvm_test;
  `uvm_component_utils(my_pcie_test)
  ...
  task run_phase (uvm_phase phase);
    svt_pcipciedeviceappservice_wait_until_idle_sequence drv_app_serv_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
    // the test generated a number of transaction requests using the driver
    application
    drv_app_serv_seq = new();
    drv_app_serv_seq.start(env.root.virt_seqr.driver_seqr[0]);
    // End of test. The driver app is idle and so all transaction requests are done.
  endtask

```

```
endclass
```

### Example 12-8

```
class my_PCIE_test extends uvm_test;
  `uvm_component_utils(my_PCIE_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_driver_app_transaction_mem_write_sequence mem_wr_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
    mem_wr_seq = new();
    mem_wr_seq.randomize with {
      address == 'h8000;
      length == 2;
      first_dw_be == 0;
      last_dw_be == 0;
      traffic_class == 0;
      address_translation == 2'b00;
      foreach(payload[i])
        payload[i] == 'hc0de_0000 + i;
    };
    mem_wr_seq.start(env.root.virt_seqr.driver_transaction_seqr[0]);
    // Add end of test criteria.
    // End of test.
  endtask
endclass
```

The examples above shows the virtual sequencer as an alternative mechanism for generating services and transactions on the driver application without showcasing its real value. The real value of the virtual sequencer is seen when the PCIe device agent is part of a test environment that has other agents that drive stimulus to other possible interfaces on the DUT. As an example, consider a system-level environment that has PCIe VIP being used to drive stimulus to the PCIe interfaces of the SoC. To simplify test writing, a system wide virtual sequencer class can be defined to access the PCIe VIP sequencers. And this system wide sequencer can be defined in the system environment and connected to the PCIe VIP agents as shown in the [Example 12-9](#).

### Example 12-9

```
class my_system_virtual_sequencer extends uvm_sequencer;
  ...
  svt_PCIE_device_virtual_sequencer pcie_dev_virt_seqr;
  ...
  function new(...);
  ...
  endfunction
endclass
class my_system_env extends uvm_env;
  svt_PCIE_device_agent root;
  my_system_virtual_sequencer sys_virt_seqr;
  ...

```

```
function void build_phase(uvm_phase phase);
    super.build_phase(phase);

    ...
    this.sys_virt_seqr = my_system_virtual_sequencer::create("sys_virt_seqr", this);

endfunction

function void connect_phase(uvm_phase phase);
    super.connect_phase(phase);
    this.sys_virt_seqr.pcie_dev_virt_seqr = root.virt_seqr;

    ...
endfunction
endclass
```

With this system-level sequencer defined, the UVM test will have a single reference to all sequencers that are part of the system. The test can drive stimulus to the PCIe interface by being oblivious to the agents or the hierarchies under them.

### Example 12-10

```
class my_PCIE_test extends uvm_test;
    `uvm_component_utils(my_PCIE_test)
    ...
    task run_phase (uvm_phase phase);
        svt_PCIE_driver_app_transaction_mem_write_sequence pcie_wr_seq;
        ...

        pcie_wr_seq = new();
        pcie_wr_seq.randomize with {
            address == 'h8000;
            length == 2;
            first_dw_be == 4'b1111;
            last_dw_be == 4'b1111;
            traffic_class == 0;
            address_translatiion == 2'b00;
            foreach(payload[i])
                payload[i] == 'hc0de_0000 + i;
        };

        fork
        pcie_wr_seq.start(env.sys_virt_seqr.pcie_dev_virt_seqr.driver_transaction_seqr[0]);
        join
        // Add end of test criteria.
        // End of test.
    endtask
endclass
```

# 13 PCIe Agent

This chapter discusses the following topics:

- ❖ [Overview](#)
- ❖ [Configuration](#)
- ❖ [Status](#)
- ❖ [Sequencers](#)

## 13.1 Overview

The PCIe Agent encapsulates the UVM drivers that represent the layered stack specified in the PCIe specification. Class `svt_PCIE_agent` represents this encapsulation in the PCIe VIP. The PCIe agent class is instanced as `pcie_agent` within `svt_PCIE_device_agent`. The agent class consists of the following layers:

1. The Transaction Layer (`Type=svt_PCIE_t1, Instance=pcie_t1`): Class `svt_PCIE_t1` defines the functions of the transaction layer (TL) in the PCIe VIP. The applications transfer transaction requests to the TL for transmission. The TL composes the transaction layer packet (TLP) and hands it down to the data-link layer located below it. The transaction layer also receives TLPs from the data-link layer which gets routed up to the correct application. It is also possible for the test to interface directly with the TL to generate TLPs. But it is recommended to use the application layers.
2. The Data-link Layer (`Type=svt_PCIE_d1, Instance=pcie_d1`): Class `svt_PCIE_d1` defines the functions of the data-link (DL) layer in the PCIe VIP. The TL transfers TLPs to the DL to be framed with a sequence number and a CRC and ensure the remote receiver receives the packet without any errors. The DL also performs the other standard functions of link management using data-link layer packets (DLLPs).
3. The Physical Layer (`Type=svt_PCIE_p1, Instance=pcie_p1`): Class `svt_PCIE_p1` defines the functions of the physical layer (PL) in the PCIe VIP. The PL breaks down packets it receives (from the DL) into symbols and encodes them as per the specification before transmission. It also composes packets from data received on the receive data lanes and sends them back to the DL. It also performs other functions to maintain the link such as the LTSSM and functions for low power and so on.

**Figure 13-1 Block Diagram – PCIe Agent**

## 13.2 Configuration

The PCIe Agent is configured using an object of class type `svt_PCIE_configuration`. An object of this type with an instance name of `pcie_cfg` is defined in `svt_PCIE_device_configuration` class. This class is comprised of data members and class object members. The object members represent the configuration of sub-components of the PCIe Agent class.

```

svt_PCIE_device_configuration
  |
  +----> driver_cfg[]   (type=svt_PCIE_driver_app_configuration)
  +----> requester_app  (type=svt_PCIE_requester_app_configuration)
  +----> target_cfg[]   (type=svt_PCIE_target_app_configuration)
  +----> pcie_cfg        (type=svt_PCIE_configuration)
    |
    +----> t1_cfg  (type=svt_PCIE_t1_configuration)
    +----> d1_cfg  (type=svt_PCIE_d1_configuration)
    +----> pl_cfg  (type=svt_PCIE_pl_configuration)
  
```

The `svt_PCIE_configuration` class also has data members that define the behavior of the agent. For example, `svt_PCIE_configuration::enable_cov` is a configuration variable that enables functional coverage.



`svt_PCIE_configuration::enable_cov` is a 6-bit variable and each bit enables a specific kind of coverage. For details about this variable and other variables, see HTML class description of the `svt_PCIE_configuration` class available at the following location:  
`$DESIGNWARE_HOME/vip/svt_PCIE_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_configuration.html`

### 13.2.1 Initial Configuration

The initial configuration of the `svt_PCIE_agent` or its sub-components is set as illustrated in “[Initial Configuration](#)” of the PCIe Device Agent section. The configuration attributes defined within the `svt_PCIE_device_configuration::pcie_agent` and its sub-configuration objects can be programmed before the `uvm_config_db::set()` call illustrated in [Example 12-2](#).

### 13.2.2 Dynamic Configuration (reconfiguration)

Dynamic configuration changes to the configuration of the `svt_PCIE_agent` or its sub-components can be made as defined in the “[Dynamic Configuration](#)” of the PCIe Device Agent section. The members of `svt_PCIE_device_agent::pcie_cfg` can be modified before the calls to reconfigure the configuration of the device agent as illustrated in [Example 12-2](#) and [Example 12-3](#).

## 13.3 Status

The PCIe Agent has a set of state values representing the status of its constituent blocks at any given time in the test simulation. And these state values are encapsulated within the `svt_PCIE_status` class. The `svt_PCIE_device_status` class has an object of type `svt_PCIE_status` instanced as `pcie_status`. For details about the attributes of this class, see HTML class description of the `svt_PCIE_status` class available at the following location:

`$DESIGNWARE_HOME/vip/svt_PCIE_svt/latest/doc/pcie_svt_uvm_class_reference/html/status/class_svt_PCIE_status.html`

The test can access these state variables as described by the status section of the PCIe device agent class. [Example 12-2](#) referenced by that section uses

`svt_PCIE_device_status::status.pl_status.ltssm_state` as a control variable.

## 13.4 Sequencers

The PCIe Agent class (`svt_PCIE_agent`) has six UVM sequencer objects to schedule transaction requests or service requests on any of its subcomponent drivers. A UVM sequencer is an arbiter that controls the transaction flow from multiples stimulus generators. The sequencers communicate with drivers using TLM interfaces.

**Figure 13-2 Block Diagram – Sequencers**

Sequencers in the PCIe Agent are broadly classified as service sequencers and transaction sequencers.

### 13.4.1 Service Sequencers

A Service Sequencer is used to schedule sequences that are referred to as services on any UVM driver in the PCIe Agent class. An example of a service request can be a request on the Physical layer to initiate a link width change. Service sequences will not generate PCIe transactions on the PCIe bus, but they are used to request a change in the behavior or sample a state value of the UVM driver. The PCIe Agent class includes the following three service sequencer objects:

1. Data-link Layer Service Sequencer (Type=`svt_pcie_dl_service_sequencer`, Instance=`dl_seqr`): A sequencer used to schedule services such as enabling of the Data-link layer driver. It feeds service transactions of type `svt_pcie_dl_service` to SIPP (Sequencer Item Pull port) `seq_item_port` of UVM driver `svt_pcie_dl` class.
2. Physical Layer Service Sequencer (Type=`svt_pcie_pl_service_sequencer`, Instance=`pl_seqr`): A sequencer used to schedule services such as speed change on the Physical layer driver. It feeds service transactions of type `svt_pcie_pl_service` to SIPP (Sequence Item Pull Port) `seq_item_port` of UVM driver `svt_pcie_pl` class.
3. Transaction Layer Service Sequencer (Type=`svt_pcie_tl_service_sequencer`, instance=`tl_seqr`): A sequencer used to schedule services such as setting up a traffic class map. It feeds service transactions of type `svt_pcie_tl_service` to the SIPP (Sequence Item Pull Port) `service_seq_item_port` of UVM driver `svt_pcie_tl` class.

**Example 13-1** shows how you can request a service on the TL via the TL service sequencer. The requested service is to map a given traffic class to a VC.

#### Example 13-1

```

class my_PCIE_test extends uvm_test;
    `uvm_component_utils(my_PCIE_test)
    ...
    task run_phase (uvm_phase phase);
        svt_pcie_tl_service_set_tc_map_sequence tl_serv_seq;
        ...
        // Assumptions:
        // The UVM test has an instance of UVM environment named 'env'

```

```
// The UVM environment has an instance of the PCIe device agent named 'root'  
tl_serv_seq = new();  
  
// Enable TC value 1. By default only TC=0 is enabled and mapped to VC0  
// Map TC=1 to VC1  
tl_serv_seq.tc_enable = 1;  
tl_serv_seq.tc_num = 1;  
tl_serv_seq.vc_num = 1;  
tl_serv_seq.start(env.root.pcie_agent.tl_seqr);  
  
// Map TC=2 to VC2  
tl_serv_seq.tc_enable = 1;  
tl_serv_seq.tc_num = 2;  
tl_serv_seq.vc_num = 2;  
tl_serv_seq.start(env.root.pcie_agent.tl_seqr);  
  
// Map TC=2 to VC2  
tl_serv_seq.tc_enable = 1;  
tl_serv_seq.tc_num = 3;  
tl_serv_seq.vc_num = 3;  
tl_serv_seq.start(env.root.pcie_agent.tl_seqr);  
  
Etc.,  
  
// Generate transaction requests.  
  
// End of test. Check for an idle state of testbench blocks before ending test.  
endtask  
endclass
```

### 13.4.2 Transaction Sequencers

A transaction sequencer is used to schedule sequences that cause PCIe transactions (TLPs, DLLPs) on the PCIe bus. The two transaction sequencers in the PCIe Agent class are as follows:

1. TLP Transaction Sequencer (Type=`svt_PCIE_tlp_sequencer`, Instance=`tlp_seqr`): A sequencer used to schedule TLP transactions on the transaction layer of the VIP. It feeds transactions of type `svt_PCIE_tlp` to the SIPP (Sequence Item Pull Port) `seq_item_port` of UVM driver class `svt_PCIE_tlp`.
2. DLLP Transaction Sequencer (Type=`svt_PCIE_dllp_sequencer`, Instance=`dllp_seqr`): A sequencer used to schedule DLLP transactions on the data-link layer of the VIP. It feeds transactions of type `svt_PCIE_dllp` to the SIPP (Sequence Item Pull Port) `seq_item_port` of UVM driver class `svt_PCIE_dl`.

[Example 13-2](#) shows how you can schedule a TLP transaction request to the TL using the TLP sequencer.

#### Example 13-2

```
class my_PCIE_test extends uvm_test;  
  `uvm_component_utils(my_PCIE_test)  
  ...  
  task run_phase (uvm_phase phase);  
    svt_PCIE_tlp_mem_request_sequence mem_tlp_seq;  
    ...  
    // Assumptions:  
    // The UVM test has an instance of UVM environment named 'env'  
    // The UVM environment has an instance of the PCIe device agent named 'root'
```

```
// VIP's DL is enabled.  
// LTSSM is in L0  
mem_tlp_seq = new();  
mem_tlp_seq.randomize with {  
    address == 'h8000;  
    length == 2;  
    requester_id == 'h100;  
    tlp_type == svt_PCIE_TLP::MEM_REQ;  
    fmt == svt_PCIE_TLP::WITH_DATA_3_DWORD;  
    // Program other header fields.  
    ...  
    foreach(payload[i])  
        payload[i] == 'hc0de_0000 + i;  
};  
mem_tlp_seq.start(env.root_PCIE_agent.tlp_seqr);  
// Add end of test criteria.  
// End of test.  
endtask  
endclass
```



Testbench should constrain the `tlp_type` as per device configuration. If a sequencer requests for TLP from Root Complex, then testbench must generate only those transactions which are valid from Root Complex based on the value of `device_is_root` variable in `svt_PCIE_device_configuration` object. And same rule should also apply for Endpoint.

### 13.4.3 Virtual Sequencer

The PCIe Agent class has a virtual sequencer object of type `svt_PCIE_virtual_sequencer` instanced as `virt_seqr` that connects to all sequencers that are defined under its hierarchy. The sequencer class object has a hierarchical structure similar to the `svt_PCIE_agent` class. Instead of having UVM drivers/agents as subcomponents, it has the UVM sequencer of the corresponding UVM drivers/agents.

**Figure 13-3 Block Diagram – Virtual Sequencer**

The example that illustrates the use of the TL service sequence and TLP transaction sequencer can alternatively access these sequencers via the virtual sequencer instance as illustrated in [Example 13-3](#) and [Example 13-4](#).

**Example 13-3**

```
class my_pcie_test extends uvm_test;
  `uvm_component_utils(my_pcie_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_TL_SERVICE_SET_TC_MAP_SEQUENCE tl_serv_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    tl_serv_seq = new();

    // Enable TC value 1. By default only TC=0 is enabled and mapped to VC0
    // Map TC=1 to VC1
    tl_serv_seq.tc_enable = 1;
    tl_serv_seq.tc_num    = 1;
    tl_serv_seq.vc_num    = 1;
    tl_serv_seq.start(env.root.pcie_agent.virt_seqr.tl_seqr);

    // Map TC=2 to VC2
    tl_serv_seq.tc_enable = 1;
    tl_serv_seq.tc_num    = 1;
    tl_serv_seq.vc_num    = 1;
    tl_serv_seq.start(env.root.pcie_agent.virt_seqr.tl_seqr);

    // Map TC=2 to VC2
    tl_serv_seq.tc_enable = 1;
    tl_serv_seq.tc_num    = 1;
    tl_serv_seq.vc_num    = 1;
    tl_serv_seq.start(env.root.pcie_agent.virt_seqr.tl_seqr);
```

```

Etc.,

// Generate transaction requests.

// End of test. Check for an idle state of testbench blocks before ending test.
endtask
endclass

```

**Example 13-4**

```

class my_PCIE_test extends uvm_test;
  `uvm_component_utils(my_PCIE_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_tlp_mem_request_sequence mem_tlp_seq;
    ...
    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
    mem_tlp_seq = new();
    mem_tlp_seq.randomize with {
      address == 'h8000;
      length == 2;
      requester_id == 'h100;
      tlp_type == svt_PCIE_tlp::MEM_REQ;
      fmt == svt_PCIE_tlp::WITH_DATA_3_DWORD;
      // Program other header fields.
      ...
      foreach(payload[i])
        payload[i] == 'hc0de_0000 + i;
    };
    mem_tlp_seq.start(env.root_PCIE_agent.virt_seqr.tlp_seqr);
    // Add end of test criteria.
    // End of test.
  endtask
endclass

```

[Example 13-3](#) and [Example 13-4](#) illustrate the use of the `svt_PCIE_agent::virt_seqr` to access sequencers that are part of `svt_PCIE_agent` class. But it finds practical usage in cases where the PCIe VIP agent is part of a test environment that has other agents that drive stimulus to other possible interfaces on the DUT. With such a system-level testbench, a system wide virtual sequencer class can be defined to access both PCIe VIP and sequencers that are part of other VIP agents. And this system wide sequencer can be defined in the system environment and connected to the sequencers of the PCIe VIP and sequencers of other VIP agents. [Example 13-5](#) shows the typical usage.

**Example 13-5**

```

class my_system_virtual_sequencer extends uvm_sequencer;
  ...
  svt_PCIE_device_virtual_sequencer pcie_dev_virt_seqr;

  function new(...);
  ...
  endfunction
endclass

```

```
class my_system_env extends uvm_env;
    svt_pcie_device_agent root;
    my_system_virtual_sequencer sys_virt_seqr;

    ...

    function void build_phase(uvm_phase phase);
        super.build_phase(phase);

        ...
        this.sys_virt_seqr = my_system_virtual_sequencer::create("sys_virt_seqr", this);

    endfunction

    function void connect_phase(uvm_phase phase);
        super.connect_phase(phase);
        this.sys_virt_seqr.pcie_dev_virt_seqr = root.virt_seqr;

        ...
    endfunction
endclass

class my_pcie_test extends uvm_test;
    `uvm_component_utils(my_pcie_test)
    ...

    task run_phase (uvm_phase phase);
        svt_pcie_tlp_mem_request_sequence mem_tlp_seq;
        ...

        mem_tlp_seq = new();
        mem_tlp_seq.randomize with {
            address == 'h8000;
            length == 2;
            requester_id == 'h100;
            tlp_type == svt_pcie_tlp::MEM_REQ;
            fmt == svt_pcie_tlp::WITH_DATA_3_DWORD;
            // Program other header fields.
            ...
            foreach(payload[i])
                payload[i] == 'hc0de_0000 + i;
        };
        fork
            mem_tlp_seq.start(env.sys_virt_seqr.pcie_dev_virt_seqr.pcie_virt_seqr.tlp_seqr);
        join
            // Add end of test criteria.
            // End of test.
    endtask
endclass
```



**Note** Example 13-5 accesses the TLP sequencer using the device agent virtual sequencer PCIe Device agent (`svt_pcie_device_agent`) class `svt_pcie_device_agent::virt_seqr.pcie_virt_seqr.tlp_seqr`. And this is same as accessing the TLP sequencer via the virtual sequencer defined inside `svt_pcie_agent` class `svt_pcie_agent::virt_seqr.tlp_seqr`. The latter is illustrated in [Example 13-4](#).



# 14 Using the Transaction Layer

---

## 14.1 Transaction Layer

The Transaction Layer, TL, is implemented as a uvm\_driver, svt\_PCIE\_tl. The TL contains a configuration object, svt\_PCIE\_tl\_configuration (see “[Transaction Layer Configuration](#)”), a service sequencer (see “[Transaction Layer Sequencer and Sequences](#)”), which work together to setup and control the behavior of the TL. Additionally, the TL offers callbacks with exception capability (see “[Transaction Layer Callbacks and Exceptions](#)”), as well as a status object “[Transaction Layer Status](#)”.

### ⚠ Attention

The descriptions for the classes and applications shows the most important and often used members/features. See the [PCIe UVM HTML Class Reference](#) document for the complete listing of the members and their data types.

Consult the following to get information on TLP related programming tasks.

- ❖ [SolvNetPlus PCIe VIP Articles](#)
- ❖ [PCIe SVT FAQ](#)

A block diagram of the Transaction Layer elements is shown in [Figure 14-1](#).

**Figure 14-1 Transaction Layer block diagram**

The VIP TL layer is analogous to that of the transaction Layer of the PCIe specification. The Transaction Layer encapsulates transactions generated by an application into TLPs. It also performs traffic class (TC) to virtual channel (VC) mapping, utilizes a credit-based flow control with the remote link, and checks and enforces TLP ordering rules. VC0 is automatically initialized with default credits.



**Note** If you use Virtual Channels other than VC0, those Virtual Channels must be initialized. To initialize VC1-VC7, credits must be initialized. Use `svt_pcie_tl_configuration::init*_tx_credits` followed by a call to `svt_pcie_tl_service_tl_set_vc_en_sequence` to set up the VCs.

## 14.2 Transaction Layer Configuration

The transaction layer configuration class is `svt_pcie_device_configuration.pcie_cfg.tl_cfg`. The members within the class control the settings of the Transaction Layer, TL.

The class is accessed via the following instance hierarchy:

*instance name of svt\_pcie\_device\_configuration.pcie\_cfg.tl\_cfg*

For details about the attributes of this class, see HTML class description of the `svt_pcie_tl_configuration` class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_pcie_tl_configuration.html`

## 14.2.1 Verilog Configuration Parameters

Not all configuration items are currently controlled from within the UVM interface. At this time the items in “[Compile-time Verilog Parameters](#)” and “[Runtime-changeable Verilog Parameters](#)” are controlled only via Verilog.

### 14.2.1.1 Compile-time Verilog Parameters

Parameters that are only changeable when instantiating the TL as part of the instantiation model are listed in [Table 14-1](#).

**Table 14-1 Transaction Layer runtime Verilog parameters**

| Parameter Name                | Type    | Range           | Default Value | Description                                                                                      |
|-------------------------------|---------|-----------------|---------------|--------------------------------------------------------------------------------------------------|
| DEFAULT_ROUTE_AT_APPL_ID      |         |                 |               |                                                                                                  |
|                               | Integer | 0 - large value | 0             | Default Application ID to route Address Translation requests to.                                 |
| NUM_APPL_ID                   |         |                 |               |                                                                                                  |
|                               | Integer | 8-128           | 8             | Max number of unique Application IDs. IDs assigned to applications must be less than this value. |
| RID_APPLID_TABLE_SIZE         |         |                 |               |                                                                                                  |
|                               | Integer | 4-4096          | 64            | Number of unique RID to Appl_id map entries.                                                     |
| RID_MSGCODE_APPLID_TABLE_SIZE |         |                 |               |                                                                                                  |
|                               | Integer | 4-4096          | 64            | Number of unique {RID,msgcode} to Appl_id map entries.                                           |
| MEM_ADDR_ADDPLID_TABLE_SIZE   |         |                 |               |                                                                                                  |
|                               | Integer | 4-4096          | 64            | Number of unique Mem Address to Appl_id map entries.                                             |
| IO_ADDR_ADDPLID_TABLE_SIZE    |         |                 |               |                                                                                                  |
|                               | Integer | 4-4096          | 64            | Number of unique I/O Address to Appl_id map entries.                                             |
| AT_ADDR_ADDPLID_TABLE_SIZE    |         |                 |               |                                                                                                  |
|                               | Integer | 4-4096          | 64            | Number of unique AT Address to Appl_id map entries.                                              |

### 14.2.1.2 Runtime-changeable Verilog Parameters

Transaction Layer parameters that are changeable at runtime are listed in [Table 14-2](#).

**Table 14-2 Transaction Layer runtime Verilog parameters**

| Parameter Name                     | Type    | Range | Default Value | Description                                        |
|------------------------------------|---------|-------|---------------|----------------------------------------------------|
| <b>MAX_NUM_END_TO_END_PREFIXES</b> |         |       |               |                                                    |
|                                    | Integer |       | 4             | Max number of prefixes allowed.<br>Version 3 only. |

## 14.3 Transaction Layer Data Flow

The transaction layer is responsible for accepting TLP data from the application layer or user's test. It generates a full TLP from the data along with the header and ECRC calculation, if enabled.

### 14.3.1 Flow Diagram

Figure 14-2 highlights the key components of data flow through the VIP's Transaction Layer. Available TLMs and callbacks (cb) are shown in the diagram.

**Figure 14-2 Flow Diagram – TL Layer**

### 14.3.2 Transaction Layer Sequencer and Sequences

The transaction layer supports both service and transaction sequences. All TL sequences run on the svt\_PCIE\_TL\_service\_sequencer. The TL sequencer is accessed through one of the following paths:

#### Virtual Sequencer:

This is the path through the virtual sequencer, virt\_seqr. The virtual sequencer contains references to all of the nonvirtual sequencers. This is made available to enable the development of a high level virtual sequence that coordinates between all the nonvirtual sequencers. The path is

*instance name of svt\_PCIE\_agent.virt\_seqr.tl\_seqr*

**Sequencer:**

This is the instantiated path to the nonvirtual sequencer:

*instance name of svt\_pcie\_agent.tl\_seqr*



The non-virtual and virtual sequencers both are valid access points to the TL sequencer. Either may be used, though the virtual version is recommended when coordinating between multiple non-virtual sequencers.

Services are commands to give the model that are related to behavior or configuration. They are not transaction items that are to be sent across the bus. For the TL there is a base service, `svt_pcie_tl_service`, and there is a base service sequence, `svt_pcie_tl_service_base_sequence`.

The service, `svt_pcie_tl_service`, is a sequence\_item that supports all the transaction types supported by the TL. A service is selected by constraining the `service_type_enum` of the class to one of the enumerated service types.

Alternatively, the model provides several sequences that contain the base `svt_pcie_tl_service` that can be used for test development.

**Example 14-1**

```
svt_pcie_tl_check_final_credits_sequence fc_seq;  
...  
`uvm_do_on (fc_seq, p_sequencer.root_virt_seqr.pcie_virt_seqr.tl_seqr);  
...
```

For details about the service sequences of this class, see tab 'TL\_SERVICE\_SEQUENCES' under HTML class description available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html`

In addition to the sequence library, the Transaction Layer provides the `svt_pcie_tl_service`, which is a sequence item that can be used to build custom sequences. Enumerated values of the service type and their associated attributes are listed in [Table 14-3](#).

**Table 14-3 Service type enumerated parameters**

| Parameter                                       | Attributes           | I/O | Attribute Description                                 |
|-------------------------------------------------|----------------------|-----|-------------------------------------------------------|
| ADD_MEM_ADDR_APPL_ID_MAP_ENTRY                  |                      |     |                                                       |
| Used to map memory addresses to an application. |                      |     |                                                       |
|                                                 | memory_addr [63:0]   | I   | Base address of the memory range.                     |
|                                                 | memory_window [63:0] | I   | Window of addresses that will cause a match of entry. |
|                                                 | appl_id [31:0]       | I   | Application ID to map TLP to.                         |
|                                                 | error [1]            | O   | Indication that addition of new entry failed.         |
| ADD_IO_ADDR_APPL_ID_MAP_ENTRY                   |                      |     |                                                       |
| Used to map I/O addresses to an application.    |                      |     |                                                       |

**Table 14-3 Service type enumerated parameters (Continued)**

|                                                                                                                                                                                                         |                      |   |                                                                                                           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---|-----------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                         | memory_addr [63:0]   | I | Base address of the memory range .                                                                        |
|                                                                                                                                                                                                         | memory_window [63:0] | I | Window of addresses that will cause a match of entry.                                                     |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |
| <b>ADD_IO_ADDR_APPL_ID_MAP_ENTRY</b>                                                                                                                                                                    |                      |   |                                                                                                           |
| Used to map memory addresses that need address translation to an application.                                                                                                                           |                      |   |                                                                                                           |
|                                                                                                                                                                                                         | memory_addr [63:0]   | I | Base address of the memory range.                                                                         |
|                                                                                                                                                                                                         | memory_window [63:0] | I | Window of addresses that will cause a match of entry.                                                     |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |
| <b>ADD_AT_ADDR_APPL_ID_MAP_ENTRY</b>                                                                                                                                                                    |                      |   |                                                                                                           |
| Used to map memory addresses that need address translation to an application.                                                                                                                           |                      |   |                                                                                                           |
|                                                                                                                                                                                                         | memory_addr [63:0]   | I | Base address of the memory range.                                                                         |
|                                                                                                                                                                                                         | memory_window [63:0] | I | Window of addresses that will cause a match of entry.                                                     |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |
| <b>ADD_CFG_BDF_APPL_ID_MAP_ENTRY</b>                                                                                                                                                                    |                      |   |                                                                                                           |
| Used to map Config Request {Bus, Device, Function} to applications. Used when the VIP is the upstream port of a link. This mapping is enabled via the ENABLE_ROUTE_CFG_TYPE[0 1]_TO_FUNCTION parameter. |                      |   |                                                                                                           |
|                                                                                                                                                                                                         | config_type [1]      | I | If true, the configuration is a Type 1 request. If false, the configuration is a Type 0 request..         |
|                                                                                                                                                                                                         | bdf [15:0]           | I | {bus, device, function} of the request.                                                                   |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |
| <b>ADD RID_APPL_ID_MAP_ENTRY</b>                                                                                                                                                                        |                      |   |                                                                                                           |
| Used to map Requester IDs to applications. This table is automatically populated when TLPs are sent by the Transaction Layer. This mapping is always enabled.                                           |                      |   |                                                                                                           |
|                                                                                                                                                                                                         | requester_id [15:0]  | I | Requester ID to map.                                                                                      |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |
| <b>ADD RID_MSG_CODE_APPL_ID_MAP_ENTRY</b>                                                                                                                                                               |                      |   |                                                                                                           |
| Used to map {Requester Ids, msgcode} of MSG TLPs to applications.                                                                                                                                       |                      |   |                                                                                                           |
|                                                                                                                                                                                                         | requester_id [15:0]  | I | Requester ID to map.                                                                                      |
|                                                                                                                                                                                                         | msgcode [7:0]        | I | Msgcode of TLP. Same value as msgcode field in TLP header. See Include/pciesvc_parms.vp file for defines. |
|                                                                                                                                                                                                         | appl_id [31:0]       | I | Application ID to map TLP to.                                                                             |
|                                                                                                                                                                                                         | error [1]            | O | Indication that addition of new entry failed.                                                             |

**Table 14-3 Service type enumerated parameters (Continued)**

|                                  |                                                                                                                                                                                                                                                                                           |   |                                                                              |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------|
| DISPLAY_MEM_ADDR_APPL_ID_MAP     | Displays all memory addresses.                                                                                                                                                                                                                                                            |   |                                                                              |
| DISPLAY_IO_ADDR_APPL_ID_MAP      | Displays all I/O address to application ID map entries.                                                                                                                                                                                                                                   |   |                                                                              |
| DISPLAY_AT_ADDR_APPL_ID_MAP      | Displays all memory address to application ID map entries that require address translation.                                                                                                                                                                                               |   |                                                                              |
| DISPLAY_CFG_BDF_APPL_ID_MAP      | Displays all configuration Type 0 and Type 1 {Bus, Device, Function} to application ID map entries. Use when the VIP is the upstream port of a link.                                                                                                                                      |   |                                                                              |
| DISPLAY RID_APPL_ID_MAP          | Displays all Requester ID to application ID map entries. Use when the VIP is the upstream port of a link.                                                                                                                                                                                 |   |                                                                              |
| DISPLAY RID_MSG_CODE_APPL_ID_MAP | Displays all {Requester ID, MsgCode} to application ID map entries.                                                                                                                                                                                                                       |   |                                                                              |
| DISPLAY_STATS                    | Displays all stats in the Transaction Layer.                                                                                                                                                                                                                                              |   |                                                                              |
| CLEAR_STATS                      | Clears all stats in the Transaction Layer.                                                                                                                                                                                                                                                |   |                                                                              |
| CHECK_FINAL_CREDITS              | Compares initial allocated credits to final allocated – received credit values.<br>Compares initial Limit credits to final limit – consumed credit values. Warnings are issued if any credits are lost.                                                                                   |   |                                                                              |
| SET VC_ENABLE                    | Enable or disable a virtual channel. Called for each VC to enable. VC0 is enabled by default.                                                                                                                                                                                             |   |                                                                              |
|                                  | rand bit vc_enable                                                                                                                                                                                                                                                                        | I | Enable or disable the VC.                                                    |
|                                  | rand bit[31:0] vc_num                                                                                                                                                                                                                                                                     | I | Virtual channel number.                                                      |
| IS_TL_IDLE                       | Indicates whether the Transaction Layer is currently idle.<br><b>Note:</b> IS_TL_IDLE will be deprecated in a future release. The preferred way to check whether the TL is idle is to use the status object at shown in “ <a href="#">Determining if the Transaction Layer is Idle</a> ”. |   |                                                                              |
|                                  | rand bit tl_idle                                                                                                                                                                                                                                                                          | O | Returns the TL status: tl_idle == 0 means not idle, tl_idle == 1 means idle. |

### 14.3.3 Transaction Layer Callbacks and Exceptions

The Transaction Layer provides a callback class, `svt_PCIE_TL_CALLBACK`, for applying exceptions to TLP transactions. Refer to the [Flow Diagram – TL Layer](#) where the TX and RX callbacks are applied. For more information on the TL callbacks and exceptions, see [Chapter 19.6](#).

### 14.3.4 Transaction Layer TLMs

The `svt_PCIE_TL` provides TLMs for access to the received TLPs. There is a `uvm_blocking_put_port` and a `uvm_blocking_peek_imp`, which are `rx_tlp_out_port` and `rx_ltp_peek_port`, respectively. You can connect to those ports for access to all received TLPs.

Additionally, there is a `uvm_seq_item_pull_port`, `service_seq_item_port` that is used for service requests and user applications.

## 14.4 Transaction Layer Status

The transaction layer provides a status class that provides statistics regarding the TL layer. The class is accessed using the following instance hierarchy:

*instance name of svt\_PCIE\_agent.status.tl\_status*

Refer to the HTML Reference for a full listing of status members.

### 14.4.0.1 Determining if the Transaction Layer is Idle

The TL provides the `svt_PCIE_tl_status::is_idle` member for determining if the Transaction Layer is idle (that is, all queues are empty). This is useful for determining end-of-test.

#### Example 14-2

```
svt_PCIE_device_status root_status = p_sequencer.get_root_shared_status(this);  
wait(root_status.pcie_status.tl_status.is_idle);
```

Additionally, you can use the `svt_PCIE_tl_service` to run a service to check on the status. See `IS_TL_IDLE` in [Table 14-3](#).



**Note** In a future release the `IS_TL_IDLE` parameter will be deprecated. The preferred way to check whether the Transaction Layer is idle is to use the status object as shown in [Example 14-2](#).

## 14.5 Transaction Layer Verilog Interface

The Verilog component of the TL is instantiated within the MAC. It can be found at:

*path to instantiation model.port0.tl0*

The signals at this level are useful for debugging. A few of the signals are highlighted in the following sections.

### 14.5.0.1 Transaction Layer Module IOs

The Transaction Layer module I/O signals listed in [Table 14-4](#) are the Verilog module port connections to the TL layer. These are useful for browsing the VIP reset and checking if a particular VC is initialized.

**Table 14-4 Transaction Layer Module IOs**

| Name      | I/O      | Description                                                                                                                                                                                                                                                                  |
|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reset     | I [1]    | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.                                                                                                                                                                                     |
| dl_status | I [31:0] | Bits (use predefined parameters for access):<br>[0] = link_up.<br>[8] = VC0 initialized<br>[9] = VC1 initialized<br>[10] = VC2 initialized<br>[11] = VC3 initialized<br>[12] = VC4 initialized<br>[13] = VC5 initialized<br>[14] = VC6 initialized<br>[15] = VC7 initialized |



# 15 Data Link Layer Features and Classes

## 15.1 Classes and Applications for Using the VIP's Data Link Layer

The following classes have members and tasks to implement Data Link Layer features and operation.

- ❖ **Component Class `svt_PCIE_DL`.** Describes power management at DL Layer.
- ❖ **Component Class `svt_PCIE_DL`.** A uvm\_component which implements the PCIe Data Link Layer. This class is included in the `svt_PCIE_agent`. When you instantiate the PCIe UVM agent, you will also instantiate this component.
- ❖ **Configuration class `svt_PCIE_DL_Configuration`.** This class contains class members to configure the behavior of the Data Link Layer. For example, the class has the member `svt_PCIE_DL_Configuration::replay_timeout` which you would use to configure the length of the replay timer in symbols.
- ❖ **Status class `svt_PCIE_DL_Status`** Used for returning status and statistics back to your testbench.
- ❖ **Service Class `svt_PCIE_DL_Service`.** Service transactions for Link layer module. For example, if you want to initiate a transition to the L0 state from the PM low power state, then you would use the member `INITIATE_PM_EXIT(10)`.

The following section lists and describes the members and tasks of the major classes to implement various features for your testbench.



The descriptions for the classes and applications show the most important and often used members/features. See the [PCIe UVM HTML Class Reference](#) document for the complete listing of the members and their data types.

## 15.2 Additional Documentation on DL Programming Tasks

Consult the following to get information on DL related programming tasks.

- ❖ [SolvNetPlus PCIe VIP Articles](#).
- ❖ [PCIe SVT FAQ](#)

## 15.3 Class Elements of the Link Layer

The following illustration shows the classes making up the Link Layer. They will be discussed in various sections of the chapter.



## 15.4 Datalink Layer Data Flow

The Datalink layer is responsible for TLP and DLP traffic. Regarding the TLPs, the layer accepts formed TLPs from the Transaction Layer, appends sequence and LCRC information and then frames and stripes into lane data before passing to the Physical Layer. For DLPs, a generator creates flow control and ack/nak DLPs which are then framed and striped per lane. Additionally, user-defined DLPs may be mixed in. On the RX side, lanes are de-striped and unframed for both DLPs and TLPs. Protocol checks are validated and eventually the DLP is passed out a TLM and TLPs removed of sequence and LRCR before being passed to the Transaction layer.

### 15.4.1 Flow Diagram

Figure 15-1 highlights the key components of data flow through the VIP's Datalink Layer. Available TLMs, analysis ports (ap), and callbacks (cb) are shown in the diagram.

**Figure 15-1 Flow Diagram – Datalink Layer**



## 15.4.2 Service Class `svt_PCIE_DL_SERVICE`

The Data Link Layer service class is responsible for the implementing the following major tasks and features.

- ❖ Initiating transitions for the VIP to enter low power states:
  - ◆ ASPM Tx L0s
  - ◆ ASPM L1 low power state.
  - ◆ PM L1
  - ◆ PM L2/L3
  - ◆ Back to L0 from ASPM
  - ◆ Back to L0 from PM
- ❖ Setting ACKFactor value
- ❖ Displaying DLL statistics
- ❖ Allowing DLCMSM to transition out of Disabled state.
- ❖ Enabling and disabling gating
- ❖ Gating FC type of INITFC frames
- ❖ Setting the Virtual channel of the INITFC frames to be gated
- ❖ Getting Status information about the current processing state

For details about the service sequences of this class, see tab 'DL\_SERVICE\_SEQUENCES' under HTML class description available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html`

### 15.4.3 Datalink Layer TLMs

The svt\_PCIE\_DL provides TLMs for access to the received DLLPs. There is a uvm\_blocking\_put\_port and a uvm\_blocking\_peek\_imp, which are rx\_dllp\_out\_put and rx\_dllp\_peek\_port, respectively. You can connect to those ports for access to all received DLLPs. Additionally, there is a uvm\_seq\_item\_pull\_port, tx\_dllp\_in\_port for user-defined DLLPs.

### 15.4.4 Datalink Layer Callbacks and Exceptions

The Datalink Layer provides a callback class, svt\_PCIE\_DL\_callback, for observation and application of exceptions to both incoming and outbound transactions. Refer to the [Flow Diagram – Datalink Layer](#) where the TX and RX callbacks are applied. For more information on the DL callbacks and exceptions, see [Chapter 19.6](#).

### 15.4.5 Datalink Layer Analysis Ports

The Datalink Layer provides analysis ports for the all outbound and inbound TLPs and DLLPs. For more details see pcie\_svt\_DL\_monitor in the HTML class reference and [Flow Diagram – Datalink Layer](#).

## 15.5 Component Class svt\_PCIE\_DL

The UVM component class svt\_PCIE\_DL is responsible for the following features:

- ❖ Implements Link layer module
- ❖ Implements static and dynamic configuration. Dynamic configuration is the ability of the model to configure and re-configure at run time. Static configuration is done before at time zero (simulation time). The following table shows the members supporting dynamic and static configuration and general status monitoring.
- ❖ Responsible for reconfigure PCIE
- ❖ Provides status of the application.
- ❖ Provides a SIPP [Sequence Item Pull Port] to cater to services of type svt\_PCIE\_DL\_service.
- ❖ Provides classes and members for error injection

Following table lists significant functions and data members.

**Table 15-1 Members and Features for svt\_PCIE\_DL**

| Member                                                 | Feature                                                                                                                         |
|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| <b>Functions</b>                                       |                                                                                                                                 |
| post_tlp_framed_in_get(...)                            | Called by the component after recognizing a TLP Transaction received on the link.                                               |
| pre_dllp_out_putt(...)                                 | Callback issued by the component just prior to putting a Vendor Specific DLLP transaction received on the link on the put port. |
| pre_dllp_transmission_svc_callback t(...)              | Method used to apply TX DLLP exceptions.                                                                                        |
| pre_phy_pkt_w_framing_transmission_svc_callback t(...) | Method used to apply PHY packet framing exceptions.                                                                             |

**Table 15-1 Members and Features for svt\_PCIE\_DL (Continued)**

| Member                                   | Feature                                                                                                                                    |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| pre_tlp_framed_out_put t(...)            | Callback issued by the component after scheduling a TLP transaction for transmission on the link, just prior to framing.                   |
| pre_tlp_transmission_svc_callback t(...) | Method used to apply TX TLP exceptions.                                                                                                    |
| rx_dllp_post_deframed_callback t(...)    | Called from the SVC Link Layer to report an inbound DLLP for callback.                                                                     |
| rx_dllp_startedt(...)                    | Callback issued by the component immediately after receiving a User DLLP transaction on the set_item_port prior to its further processing. |
| rx_tlp_post_deframed_callback t(...)     | Called from the SVC Link Layer to report an inbound TLP for callback.                                                                      |
| tx_dllp_pre_framed_callback t(...)       | Called from the SVC Link Layer to report an outbound DLLP for callback.                                                                    |
| tx_dllp_startedt(...)                    | Called by the component after building a DLLP Transaction just prior to its further processing.                                            |
| tx_tlp_pre_framed_callbackt(...)         | Called from the SVC Link Layer to report an outbound TLP for callback.                                                                     |
| get_cfg t(...)                           | Overrides the base method to generate an error.                                                                                            |
| reconfigurt(...)                         | Overrides the base method to generate an error.                                                                                            |
| set_err_checkt(...)                      | Used to set the err_check object and to fill in all of the local checks.                                                                   |

**Following are derived from various base classes for port tracking and error injection**

|                                                              |                                                                                                            |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| svt_PCIE_DL_TLP_EXCEPTION dl_tlp_xact_rx_exception           | Randomization factory to create RX TLP exception (error etc.) to be inserted in transaction                |
| svt_PCIE_DL_TLP_EXCEPTION_LIST dl_tlp_xact_rx_exception_list | Randomization factory to create RX TLP exception list for a TLP transaction                                |
| svt_PCIE_DL_TLP_EXCEPTION dl_tlp_xact_tx_exception = null;   | Randomization factory to create TX TLP exception list for a TLP transaction                                |
| svt_PCIE_DL_TLP_EXCEPTION_LIST dl_tlp_xact_tx_exception_list | Randomization factory to create TX TLP exception list for a TLP transaction                                |
| svt_PCIE_DLLP_EXCEPTION dllp_xact_exception                  | Randomization factory to create TX DLLP exception list for a TLP transaction                               |
| svt_PCIE_DLLP_EXCEPTION_LIST dllp_xact_exception_list        | Randomization factory to create TX DLLP exception list for a TLP transaction                               |
| svt_PCIE_PHY_TRANSACTION_EXCEPTION phy_xact_exception        | Randomization factory to create TX PHY transaction framing exception (error etc.) to be inserted in packet |

**Table 15-1 Members and Features for svt\_PCIE\_DL (Continued)**

| Member                                                                        | Feature                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| phy_xact_exception_list                                                       | Randomization factory to create TX PHY transaction framing exception list for a packet                                                                                                                                               |
| svt_debug_opts_analysis_port<br>received_dllp_observed_port                   | Analysis port for received DLLPs. This port is generally used for scoreboarding. The DLLPs observed via this analysis port are controlled by svt_PCIE_DL_configuration :: received_dllp_interface_mode                               |
| svt_debug_opts_analysis_port received_tlp_observed_port                       | Analysis port for received TLPs. This port is generally used for scoreboarding. The TLPs observed via this analysis port are controlled by svt_PCIE_DL_configuration :: received_tlp_interface_mode.                                 |
| svt_debug_opts_blocking_put_port rx_dllp_out_port                             | RX DLLP Put Port Provides a mechanism for external components to receive vendor specific DLLPs from the Data Link Layer. The handle to this DLLP put port can be set or obtained through the driver's public member rx_dllp_out_port |
| svt_debug_opts_blocking_peek_imp_port<br>rx_dllp_peek_port RX DLLP Peek port. | Provides a mechanism for external components to retrieve Vendor Specific DLLPs from the Data Link Layer. The handle to this DLLP peek port can be set or obtained through the driver's public member rx_dllp_peek_port .             |
| svt_debug_opts_analysis_port sent_dllp_observed_port                          | Analysis port for sent DLLPs. This port is generally used for scoreboarding. The DLLPs observed via this analysis port are controlled by svt_PCIE_DL_configuration :: sent_dllp_interface_mode.                                      |
| svt_debug_opts_analysis_port sent_tlp_observed_port                           | Analysis port for sent TLPs. This port is generally used for scoreboarding. The TLPs observed via this analysis port are controlled by svt_PCIE_DL_configuration :: sent_tlp_interface_mode.                                         |

## 15.6 Configuration class svt\_PCIE\_DL\_Configuration

Use the svt\_PCIE\_DL\_Configuration to define the overall behavior of the Data Link Layer. You can define the following behaviors for over 88 different features. In addition, note that most configurable attributes are defined as SystemVerilog RAND types. This allows your testbench to randomize them following predefined constraints provided by Synopsys. Consult the PCIe HTML Class Reference on declared data types.

### 15.6.1 Members and Features

For details about the attributes of this class, see HTML class description of the svt\_PCIE\_DL\_Configuration class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_DL_Configuration.html`

### 15.6.2 Calculating Ack/Nak Latency Values

Ack/Nak latency values are calculated as shown in the following example:

- ❖ attached\_acknak\_latency\_timer\_limit

```
attached_acknak_latency_timer_limit
                                = attached_max_nak_latency +
                                   attached_internal_delay +
                                   internal_delay +
                                   internal_phy_delay +
                                   attached_internal_phy_delay
```

- ❖ acknak\_latency\_timer\_limit

acknak\_latency\_timer\_limit is a random value between min\_acknak\_latency and max\_acknak\_latency.

- ❖ acknak\_latency

```
acknak_latency
                = ((MAX_PAYLOAD_SIZE_VAR + TLP_OVERHEAD) * ack_factor) / smallest_width) +
                   internal_delay
```

- ❖ attached\_acknak\_latency

```
attached_acknak_latency
                = ((MAX_PAYLOAD_SIZE_VAR + TLP_OVERHEAD) * ack_factor) / smallest_width) +
                   attached_internal_delay
```

## 15.7 Status class `svt_PCIE_DL_STATUS`

This class makes available the specific status information as it relates to the Data Link Layer. For example you can get the number of:

- ❖ NACK DLLPs received and sent
- ❖ TLPs and DDLPs received and sent with errors
- ❖ Tx alignment errors injected with two STPs per symbol.
- ❖ Tx DLLP code violation errors injected.
- ❖ Tx DLLPs with non-zero reserved bits injected.
- ❖ Number of packets that had to be retransmitted.
- ❖ Number of credits on every virtual channel.

For details about the attributes of this class, see HTML class description of the `svt_PCIE_DL_STATUS` class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/status/class_svt_PCIE_DL_Status.html`

# 16 Physical Layer Features and Classes

## 16.1 Classes and Applications for Using the VIP's PHY Layer

The following classes have members and tasks to implement Physical Layer features and operation.

- ❖ Service Class [svt\\_PCIE\\_pl\\_service](#).
- ❖ UVM Component Class [svt\\_PCIE\\_pl](#)
- ❖ PHY Layer Configuration Class

The following section lists and describes the members and tasks of the major classes to implement various features for your testbench.



The descriptions for the classes and applications shows the most important and often used members/features. See the *PCIe UVM HTML Class Reference* document for the complete listing of the members and their data types.

## 16.2 Additional Documentation on PHY Programming Tasks

Consult the following to get information on PHY related programming tasks.

- ❖ [SolvNetPlus PCIe VIP Articles](#)
- ❖ [PCIe SVT FAQ](#)

## 16.3 PHY Layer Data Flow

The Physical layer of the VIP performs scrambling and encoding of TLP, DLLP, and control/idle commands into OS/TS/OS/symbols to be driven on the PIPE original/LPC/SerDes Arch or SERDES. Similarly, it can receive data on one of the interfaces, decode and de-scramble and pass to the Datalink Layer.

### 16.3.1 Flow Diagram

[Figure 16-1](#) highlights the key components of data flow through the VIP's Physical Layer. Available TLMs and callbacks (cb) are shown in the diagram.

**Figure 16-1 Flow Diagram – PHY Layer**

### 16.3.2 Service Class `svt_PCIE_pl_service`

This transaction class supports all of the Service requests which can be processed by the PHY Layer.

**Table 16-1 Class `svt_PCIE_pl_service`**

| Member                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>assert_clkreq_n</code>               | Controls whether the VIP will assert bidirectional signal <code>clkreq_n</code> or not. Note there is a soft pullup if <code>clkreq</code> is not asserted. When '1' <code>clkreq_n</code> will be asserted (ie driven to 'b0'). When '0' <code>clkreq_n</code> will not be asserted by the VIP.                                                                                                                                                 |
| <code>corrupt_disparity_byte_wt[16]</code> | Automatic OS corruption weight, Tx OS Bytes 0-15.                                                                                                                                                                                                                                                                                                                                                                                                |
| <code>corrupt_lane_mask</code>             | Automatic OS corruption and <code>FORCE_LANE_TX_ELEC_IDLE</code> lane mask.                                                                                                                                                                                                                                                                                                                                                                      |
| <code>corrupt_tx_idle_data_enable</code>   | Automatic EIOS corruption percentage.                                                                                                                                                                                                                                                                                                                                                                                                            |
| <code>corrupt_tx_os_percentage</code>      | Automatic OS corruption percentage. Following is the list of service types that gets affected by this parameter: <ul style="list-style-type: none"> <li>• <code>SET_TX_EIOS_CORRUPTION</code></li> <li>• <code>SET_TX_EIEOS_CORRUPTION</code></li> <li>• <code>SET_TX_FTS_CORRUPTION</code></li> <li>• <code>SET_TX_SKP_CORRUPTION</code></li> <li>• <code>SET_TX_SDS_CORRUPTION</code></li> <li>• <code>SET_TX_EDS_CORRUPTION</code></li> </ul> |

**Table 16-1 Class svt\_PCIE\_pl\_service (Continued)**

| Member                                  | Description                                                                                                                                        |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| cursor_coeff                            | Cursor value for an equalization request.                                                                                                          |
| direction_change_response               | Direction change response.                                                                                                                         |
| ei_bytenum                              | User Task Tx TS EI Byte Number.                                                                                                                    |
| ei_code                                 | User Task Tx TS EI Code.                                                                                                                           |
| ei_tx_phy_data_bit_flip_weight          | Tx Data Pattern Bit Flip weighting - weighting to replace outgoing data with an invalid codeword when an error is injected. 2.5G/5G only.          |
| ei_tx_phy_data_corrupt_data_weight      | Tx Data Pattern Corrupt Data weighting - weighting to replace outgoing data with random data when an error is injected.                            |
| ei_tx_phy_data_corrupt_disparity_weight | Tx Data Pattern Corrupt Disparity weighting - weighting to replace outgoing data with an invalid codeword when an error is injected. 2.5G/5G only. |
| ei_tx_phy_data_invalid_codeword_weight  | Tx Data Pattern Invalid Codeword weighting - weighting to replace outgoing data with an invalid codeword when an error is injected. 2.5G/5G only.  |
| ei_tx_phy_data_lane_mask                | Tx Data Pattern Lane mask- Each bit corresponds to a lane. Lanes with a 'b0 will not have errors injected.                                         |
| ei_tx_phy_data_pattern_enable           | Tx Data Pattern Enable - enable the phy data error pattern.                                                                                        |
| eq_lane_num                             | Programs the lane number for equalization information.                                                                                             |
| expect_reject                           | Reject response from link partner.                                                                                                                 |
| figure_of_merit                         | Figure Of Merit response.                                                                                                                          |
| hot_plug_mode                           | This attribute controls Hot plug mode. <a href="#">Table 16-2</a> shows the various hot plug modes.                                                |
| hot_reset_mode                          | This attribute controls Hot reset mode. Refer to <a href="#">Table 16-3</a> for a listing of hot reset modes.                                      |
| internal_condition                      | Type of internal condition. Refer to <a href="#">Table 16-4</a> for a listing of internal conditions.                                              |
| invalid_codeword_byte_wt[16]            | Automatic OS corruption weight, Tx OS Bytes 0-15.                                                                                                  |
| invalid_data_byte_wt[16]                | Automatic OS corruption weight, Tx OS Bytes = 0-15.                                                                                                |
| lane_enabled                            | Set to enable the association.                                                                                                                     |
| lane_num                                | Lane Number.                                                                                                                                       |
| loopback_enable                         | Initiate Loopback Enable.                                                                                                                          |
| max_ei_tx_phy_data_pattern_burst        | Max Tx Data Pattern Burst - maximum number of symbols in an error burst.                                                                           |

**Table 16-1 Class svt\_PCIE\_pl\_service (Continued)**

| <b>Member</b>                      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| max_ei_tx_phy_data_pattern_spacing | Max Tx Data Pattern Spacing - max number of symbols between error bursts.                                                                                                                                                                                                                                                                                                                                                           |
| max_user_tx_ts_burst               | User Task Max Tx TS Burst.                                                                                                                                                                                                                                                                                                                                                                                                          |
| max_user_tx_ts_spacing             | User Task Max Tx TS Spacing.                                                                                                                                                                                                                                                                                                                                                                                                        |
| min_ei_tx_phy_data_pattern_burst   | Min Tx Data Pattern Burst - minimum number of symbols in an error burst.                                                                                                                                                                                                                                                                                                                                                            |
| min_ei_tx_phy_data_pattern_spacing | Min Tx Data Pattern Spacing - min number of symbols between error bursts.                                                                                                                                                                                                                                                                                                                                                           |
| min_user_tx_ts_burst               | User Task Min Tx TS Burst.                                                                                                                                                                                                                                                                                                                                                                                                          |
| min_user_tx_ts_spacing             | User Task Min Tx TS Spacing.                                                                                                                                                                                                                                                                                                                                                                                                        |
| phy_enable                         | When clear the LTSSM will attempted to enter the DISABLED state. This is not the same thing as turning off the LTSSM!!! To completely disable the LTSSM the hot_plug_mode should be set to HOT_PLUG_UNPLUG.                                                                                                                                                                                                                         |
| phy_id                             | Phy number to configure.                                                                                                                                                                                                                                                                                                                                                                                                            |
| phy_response_code                  | Reject response from link partner.                                                                                                                                                                                                                                                                                                                                                                                                  |
| postcursor_coeff                   | Post Cursor value for an equalization request.                                                                                                                                                                                                                                                                                                                                                                                      |
| precursor_coeff                    | Pre Cursor value for an equalization request.                                                                                                                                                                                                                                                                                                                                                                                       |
| preset_valid                       | Preset valid for an equalization request.                                                                                                                                                                                                                                                                                                                                                                                           |
| preset_value                       | Preset value for an equalization request.                                                                                                                                                                                                                                                                                                                                                                                           |
| reject_coefficient_preset_requests | For the side that is receiving requests during equalization, setting this will force rejection of incoming requests. clearing this bit will allow requests to once again be accepted.                                                                                                                                                                                                                                               |
| service_type                       | Transaction command. For a complete listing of all the service requests supported by the VIP, see tab 'PL_SERVICE_SEQUENCES' under HTML class description available at the following location:<br><a href="http://\$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html">http://\$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html</a> |
| status                             | Status information about the current processing state.                                                                                                                                                                                                                                                                                                                                                                              |
| symbol<0-15>                       | User Task Tx TS Symbol <0-15>                                                                                                                                                                                                                                                                                                                                                                                                       |
| tx_deemph                          | Tx Deemphasis Value                                                                                                                                                                                                                                                                                                                                                                                                                 |
| user_tx_ts_enable                  | User Task Tx TS Enable.                                                                                                                                                                                                                                                                                                                                                                                                             |
| pipe_get_local_preset_coefficients | Enables MPIPE VIP to assert GetLocalPresetCoefficients signal for one PCLK.                                                                                                                                                                                                                                                                                                                                                         |

**Table 16-1 Class svt\_PCIE\_pl\_service (Continued)**

| Member                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| go_to_l1ss                     | Directs VIP's LTSSM to go to the specified L1 sub-state (L1.0/L1.1/L1.2). This service request is effective only when LTSSM is in L1.Entry state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| pipe_change_l1ss_powerstate    | Drives additional user-specific PowerDown value(s) in L1.1/L1.2.Idle LTSSM sub-states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| pipe_eject_reset               | De-asserts PIPE_Reset# signal prior to PCLK getting ON from PHY (toggling of PCLK) and after VIP reset is complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| training_control_lane_vector   | <p>Indicates on which lanes VIP will set the Training Control bit to 1 while transmitting TS1 OS in Loopback, Disabled, and HotReset LTSSM states when it entered these states from Recovery.Idle.</p> <p>Each bit of this configuration corresponds to a lane. Bit 0 corresponds to lane 0, bit 1 corresponds to lane 1 and so on.</p> <ul style="list-style-type: none"><li>• If a bit is set to 1 on a lane, then VIP will set the training control bit 0, 1 or 2 to 1 in TS1 OS on that particular lane.</li><li>• If a bit is set to 0 on a lane, then VIP will set the training control bit 0, 1 or 2 to 0 in TS1 OS on that particular lane.</li></ul> <p>The default value of this configuration is 32'hffff_ffff. This configuration will be reset to its default value of 32'hffff_ffff each time the LTSSM state is changed from Loopback, Disabled, and HotReset to the next LTSSM state.</p> <p><b>Note:</b> This configuration should only be used when VIP is going to Loopback, Disabled, and HotReset from Recovery.Idle and should not be used when going to these states from ConfigLwStart.</p> |
| directed_ltssm_state           | <p>Defines the directed LTSSM state transition combinations. This can be used along with INITIATE_DIRECTED_LTSSM_TRANSITION service type to direct the VIP to next spec defined LTSSM state. Currently, it only supports Recovery.Idle to Config.Lw.Start directed transition.</p> <p><b>Note:</b> INITIATE_DIRECTED_LTSSM_TRANSITION service type along with RECOVERY_TO_CONFIGURATION must not be used to do link width up/down sizing. For link width up/down sizing, use the INITIATE_LINK_WIDTH_CHANGE service type.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| enable_loopback_w_equalization | <p>This bit directs the VIP which is acting as loopback Master to enter Equalization from Loopback.Entry.</p> <p><b>Note:</b> This is applicable for Gen5 devices only.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| loopback_lane_under_test       | <p>This control defines the physical lane under test on which the 32 GT/s equalization procedure will be performed before entering loopback.active.</p> <p><b>Note:</b> This is applicable for Gen5 devices only.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

**Table 16-1 Class svt\_PCIE\_pl\_service (Continued)**

| Member                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set_ts_transmit_modified_compliance_pattern_in_loopback | <p>This bit sets the value of the transmit_modified_compliance_pattern_in_loopback bit in the training control field of transmitted training sets. This is for use by the loopback Master only in the case where loopback equalization will be performed.</p> <p><b>Note:</b> This is applicable for Gen5 devices only.</p>                                                                  |
| upstream_port_loopback_tx_preset_in_eq_ts1              | <p>Specifies the transmitter preset(symbol 6 bit[6:3]) value of EQ TS1 OS that gets transmitted by VIP(Upstream Port) as Loopback Master in Loopback Entry at 2.5G and 5G.</p> <p><b>Note:</b> This is applicable only for Upstream Port active VIP, that is – when VIP acts as a Loopback Master and the value of enable_eq_ts1_in_loopback_state configuration variable is set to 1.</p>   |
| upstream_port_loopback_rx_preset_hint_in_eq_ts1         | <p>Specifies the receiver preset hint(symbol 6 bit[2:0]) value of EQ TS1 OS that gets transmitted by VIP(Upstream Port) as Loopback Master in Loopback Entry at 2.5G and 5G.</p> <p><b>Note:</b> This is applicable only for Upstream Port active VIP, that is – when VIP acts as a Loopback Master and the value of enable_eq_ts1_in_loopback_state configuration variable is set to 1.</p> |
| upstream_port_tx_preset_in_loopback_state               | <p>Specifies the transmitter preset(symbol 6 bit[6:3]) value of TS1 OS that gets transmitted by Upstream Port(EP) as Loopback Master in Loopback Entry at 8G.</p> <p><b>Note:</b> This is applicable only for active VIP, that is – when VIP acts as a Loopback Master and it is configured as an Endpoint.</p>                                                                              |
| upstream_port_tx_preset_in_loopback_state_16g           | <p>Specifies the transmitter preset(symbol 6 bit[6:3]) value of TS1 OS that gets transmitted by Upstream Port(EP) as Loopback Master in Loopback Entry at 16G.</p> <p><b>Note:</b> This is applicable only for active VIP, that is – when VIP acts as a Loopback Master and it is configured as an Endpoint.</p>                                                                             |
| upstream_port_tx_preset_in_loopback_state_32g           | <p>Specifies the transmitter preset(symbol 6 bit[6:3]) value of TS1 OS that gets transmitted by Upstream Port(EP) as Loopback Master in Loopback Entry at 32G.</p> <p><b>Note:</b> This is applicable only for active VIP, that is – when VIP acts as a Loopback Master and it is configured as an Endpoint.</p>                                                                             |

The following table shows the various types of hot plug modes. The member “[hot\\_plug\\_mode](#)” sets the mode type.

**Table 16-2 Hot Plug Modes**

| Mode             | Description                                                      |
|------------------|------------------------------------------------------------------|
| HOT_PLUG_UNPLUG  | Hot plug mode is unplug. Only applicable to VIP in active mode.  |
| HOT_PLUG_MONITOR | Hot plug mode is monitor. Only applicable to VIP in active mode. |
| HOT_PLUG_WAIT    | Hot plug mode is wait. Only applicable to VIP in active mode.    |

**Table 16-2 Hot Plug Modes (Continued)**

| Mode            | Description                                                     |
|-----------------|-----------------------------------------------------------------|
| HOT_PLUG_DETECT | Hot plug mode is detect. Only applicable to VIP in active mode. |

The following table lists the various hot reset modes. The member “[hot\\_reset\\_mode](#)” sets the reset mode.

**Table 16-3 Hot Reset Modes**

| Mode               | Description                                                                                                                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HOT_RESET_INACTIVE | LTSSM is not instructed to enter reset. If LTSSM initiated the hot reset and is in the hot reset state, setting to inactive will direct the LTSSM out of hot reset.                                                                |
| HOT_RESET_FORCE    | Instruct the LTSSM to enter hot reset and remain in this state.                                                                                                                                                                    |
| HOT_RESET_WAIT     | Instruct the LTSSM to enter hot reset, then wait for the attached link to enter hot reset. Once the attached link has shut down its transmitters LTSSM will automatically exit to detect and reset the hot reset mode to INACTIVE. |

The following table lists various internal conditions. The member “[internal\\_condition](#)” sets these conditions.

**Table 16-4 Internal Condition States**

| Internal Condition                           | Description                                   |
|----------------------------------------------|-----------------------------------------------|
| INT_COND_RX_PATH_BLOCK_ALIGNMENT_ACHIEVED    | Indicates Block alignment status on RX path.  |
| INT_COND_TX_PATH_BLOCK_ALIGNMENT_ACHIEVED    | Indicates Block alignment status on TX path.  |
| INT_COND_RX_PATH_8G_SPEED_FIRST_PKT_RECEIVED | Received first packet on RX path at 8G speed. |
| INT_COND_TX_PATH_8G_SPEED_FIRST_PKT_RECEIVED | Received first packet on TX path at 8G speed  |

For details about the service sequences of this class, see tab ‘PL\_SERVICE\_SEQUENCES’ under HTML class description available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html`

### 16.3.3 Physical Layer Callbacks and Exceptions

The Datalink Layer provides a callback class, `svt_PCIE_pl_callback`, for observation and application of exceptions to both incoming and outbound transactions. Refer to the [Flow Diagram – PHY Layer](#) where the Tx and Rx callbacks are applied. For more information on the PL callbacks and exceptions, see [Chapter 19.6](#).

## 16.4 UVM Component Class `svt_PCIE_pl`

This class is UVM Driver that implements Physical layer module. The class is responsible to reconfigure PCIE SVC Physical layer module. It is also responsible to provide status of the application. It provides a

SIPP [Sequence Item Pull Port] to cater to services of type svt\_PCIE\_pl\_service. Note, the class supports all UVM phases.

**Table 16-5 Class svt\_PCIE\_pl**

| Member                    | Description                                                                                                                                                                                                                                           |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pre_symbol_out_put        | Called by the component after gathering all the symbols to be transmitted on the PCIe link. This is the last chance to the user to corrupt any symbol before it goes on the link.                                                                     |
| reconfigure_via_task      | Depreciated.                                                                                                                                                                                                                                          |
| tx_os_started             | Called by the component after building an OS Transaction. The callback gives user a chance to attach exception list to the OS transaction prior to its transmission on the link.                                                                      |
| tx_ts_os_started          | Called by the component after building a TS OS Transaction. The callback gives user a chance to attach exception list to the TS OS transaction prior to its transmission on the link.                                                                 |
| os_xact_exception         | Randomization factory to create TX OS exception (error etc.) to be inserted in transaction.                                                                                                                                                           |
| os_xact_exception_list    | Randomization factory to create TX OS exception list for an OS transaction.                                                                                                                                                                           |
| svc_in_port               | PL Service TLM Sequence Item Pull Port. Provides a mechanism for submitting PL Service transactions recognized by the PL Layer. The handle to this TLM sequence item pull port can be set or obtained through the driver's public member svc_in_port. |
| symbol_exception          | Randomization factory to create TX symbols exception (error etc.) to be inserted in symbols.                                                                                                                                                          |
| symbol_exception_list     | Randomization factory to create TX symbols exception list for symbols to be transmitted.                                                                                                                                                              |
| ts_os_xact_exception      | Randomization factory to create TX TS OS exception (error etc.) to be inserted in transaction.                                                                                                                                                        |
| ts_os_xact_exception_list | Randomization factory to create TX TS OS exception list for a TS OS transaction.                                                                                                                                                                      |

## 16.5 PHY Layer Configuration Class

For details about the attributes of this class, see HTML class description of the svt\_PCIE\_pl\_configuration class available at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_pl_configuration.html`

## 16.6 External Tx Bit Clk Use Model

This is a special use model which can be used in common ref clk mode. In this mode, the VIP is capable of transmitting serial data with respect to serial bit clocks provided from the Test Bench. To enable this model VIP has to be configured in following manner from the Test Bench.

```
defparam <vip_top_level_inst_path>.port0.USE_EXTERNAL_BIT_CLK = 1;
assign <vip_top_level_inst_path>.ext_bit_clk_gen1 =
endpoint0.port0.SVC_CLKGEN4_INST.clkgen_txclk0.bit_clk;clk;
assign <vip_top_level_inst_path>.ext_bit_clk_gen2 =
endpoint0.port0.SVC_CLKGEN4_INST.clkgen_txclk0.bit_clk;clk;
assign <vip_top_level_inst_path>.ext_bit_clk_gen3 =
endpoint0.port0.SVC_CLKGEN4_INST.clkgen_txclk0.bit_clk;clk;
assign <vip_top_level_inst_path>.ext_bit_clk_gen4 =
endpoint0.port0.SVC_CLKGEN4_INST.clkgen_txclk0.bit_clk;clk;
```

Where root0 is the top level instantiation absolute path in the Test Bench.

If a device does not support Gen2/Gen3/Gen4, then leave following wires open:

- ❖ ext\_bit\_clk\_gen2
- ❖ ext\_bit\_clk\_gen3
- ❖ ext\_bit\_clk\_gen4





# 17 Using the Driver Application

---

This chapter discusses the following topics:

- ❖ [Introduction](#)
- ❖ [Driver Application Configuration](#)
- ❖ [Driver Application Data Flow](#)
- ❖ [Status](#)

## 17.1 Introduction

The driver application is an abstraction layer that allows a test to generate PCIe transactions with an abstract description of a PCIe transaction request. The driver application is modeled using class `svt_PCIE_driver_app` and is instanced inside the `svt_PCIE_device_agent` class as `driver[0]`. The `svt_PCIE_driver_app` class inherits the properties of the UVM driver and so it can initiate transaction requests.

**Figure 17-1 Block Diagram – PCIe UVM VIP**

Apart from the obvious convenience of abstraction provided for test writing, the driver application also provides the following features:

- ❖ Data-integrity checks: The driver application has self-checks to ensure that the data returned for a memory read is the expected value.
- ❖ Compliance checks: The driver application has checks to ensure the completions returned by the link partner for requests generated by the driver conforms to the specification. It tracks requests from start to completion and ensures all requests receive a successful completion.
- ❖ Automatic error recovery: The driver application has a pre-defined set of errors that can be injected by a test. The driver application recovers from those errors by suppressing the related errors and also checks for the correctness in the behavior of the DUT in response to the error.

The driver application constructs Transaction Layer Packets (TLP) from the abstract description provided to it by the test and transmits these TLPs to the Transaction Layer (TL). The TL then processes these TLPs as per the specification before handing them down to the layer below it. It is also possible to bypass the driver application and directly queue TLPs on the TL. To do this, you require a more descriptive TLP class, `svt_PCIE_TLP`. With this approach, a test will end up being much longer and it would need to perform the task of tracking and checking the related completions. And so it is highly recommended to use the driver application as the testing interface for generating TLPs.

## 17.2 Driver Application Configuration

The Driver Application is configured using an object of class type `svt_PCIE_DRIVER_APP_CONFIGURATION`.

```

svt_PCIE_DEVICE_CONFIGURATION
|-----> driver_cfg[0]  (type=svt_PCIE_DRIVER_APP_CONFIGURATION)
|-----> requester_cfg (type=svt_PCIE_REQUESTER_APP_CONFIGURATION)
|-----> target_cfg[0]  (type=svt_PCIE_TARGET_APP_CONFIGURATION)

```



The configuration object of the driver application resides inside `svt_PCIE_device_configuration`, the configuration class of the PCIe Device Agent class. The class object is instanced as `driver_cfg[0]`.

For more details, such as members, class inheritance UML, list of tasks, list of constraints and so on, see the HTML class description of `svt_PCIE_driver_app_configuration` at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/configuration/class_svt_PCIE_driver_app_configuration.html`

### 17.2.1 Initial Configuration

The initial configuration of the driver application is established using the configuration database (`uvm_config_db`) class defined in UVM. The driver gets configured when the PCIe device agent gets configured by the test as illustrated in [Example 12-1](#). The configuration attributes defined inside `svt_PCIE_device_configuration::driver_cfg[0]` can be programmed to user-desired values before calling `uvm_config_db::set()`.

### 17.2.2 Dynamic Configuration

The configuration of the driver application set during the `build_phase()` can be dynamically (during the `run_phase`) modified if the test requires a change. This dynamic change can be made using any of the three mechanisms which is described in section [Dynamic Configuration](#).

## 17.3 Driver Application Data Flow

The Driver Application is responsible for accepting transaction items which are converted into TLP data. On the receive side, it will accumulate completions for the end user.

### 17.3.1 Flow Diagram

[Figure 17-2](#) highlights the key components of data flow through the VIP's Driver. Available TLMs, events (e), and callbacks (cb) are shown in the diagram.

**Figure 17-2 Flow Diagram – Driver Application**

### 17.3.2 Sequencer Ports

Sequencer ports relevant to the driver have already been discussed in chapter [PCIe Device Agent](#).

### 17.3.3 Sequences

The main purpose of the driver application is the generation of PCIe TLP traffic. And so it deals with the sequencing transaction layer packets, a function which is facilitated by the UVM sequencers of the driver application. The sequencers of the driver application will accept sequences queued on it by the UVM test and will arbitrate the driving of these sequences. The driver has two kinds of sequences:

1. **Transaction sequencers:** A transaction sequencer is used to schedule sequences that result in PCIe transactions (TLPs) on the PCIe bus. The transaction sequencer of the driver application is defined inside `svt_PCIE_device_agent` class. It is of class type `svt_PCIE_driver_app_transaction_sequencer` and is instanced as `driver_transaction_seqr[0]`. The transaction sequencer feeds transactions of type `svt_PCIE_driver_app_transaction` to the SIPP (sequence item Pull Port) `seq_item_port` of UVM driver `svt_PCIE_driver_app` class.
2. **Service sequencers:** A service sequencer is used to schedule sequences that are referred to as services on the driver application. An example of a service request would be a request to reset the driver application, which would drop all queued or outstanding transactions. The service sequencer is of class type `svt_PCIE_driver_app_service_sequencer` and is instanced as `driver_seqr`. The sequencer feeds transactions of type `svt_PCIE_driver_service` to the SIPP (sequence item Pull Port) `service_seq_item_port` of UVM driver `svt_PCIE_driver_app` class.

The tests can use these sequencers to generate a desired pattern of traffic or seek a service of the kinds supported by the driver application. The subsequent sections will discuss these in detail.

### 17.3.3.1 Transaction Sequences

The driver application of the PCIe VIP is the recommended testing interface while developing TLP traffic tests. The transaction sequences are sequenced via

`svt_PCIE_DeviceAgent::driver_transaction_seqr[0]`. The application understands a description of the transaction layer packet as described by transaction class `svt_PCIE_DriverAppTransaction`.

To view the complete list of members and constraints in class `svt_PCIE_DriverAppTransaction` and their definitions, see the HTML class reference documentation at the following location:

`DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/transaction/class_svt_PCIE_DriverAppTransaction.html`

**Table 17-1 Transaction Fields**

| Transaction Type    | address | length | first_dw_be | last_dw_be | traffic_class | address_translation | ep | payload | exception_list | block | Config only | Message only | Responses only |
|---------------------|---------|--------|-------------|------------|---------------|---------------------|----|---------|----------------|-------|-------------|--------------|----------------|
| MEM_RD              | x       | x      | x           | x          | x             | x                   |    |         | x              | x     |             |              |                |
| MEM_RD_LK           | x       | x      | x           | x          | x             | x                   |    |         | x              | x     |             |              |                |
| MEM_WR              | x       | x      | x           | x          | x             | x                   | x  | x       | x              | x     |             | x            | x              |
| IO_RD               | x       |        | x           |            |               |                     |    |         | x              | x     |             |              | x              |
| IO_WR               | x       |        |             |            |               |                     |    | x       | x              |       |             |              |                |
| CFG_RD              | x*      |        | x           |            |               |                     |    |         | x              | x     | x           | x            | x*             |
| CFG_WR              | x*      |        |             |            |               |                     | x  | x*      | x              | x     | x           | x            | x              |
| MSG                 |         |        |             |            | x             |                     | x  |         | x              | x     |             | x            | x              |
| ATOMIC_OP_FETCH_ADD | x       | x      | x           | x          | x             | x                   | x  | x       | x              | x     |             |              | x              |
| ATOMIC_OP_SWAP      | x       | x      | x           | x          | x             | x                   | x  | x       | x              | x     |             |              | x              |
| ATOMIC_OP_CAS       | x       | x      | x           | x          | x             | x                   | x  | x       | x              | x     |             |              | x              |

\*CFG types: address is {B,D,F}, payload is payload[0] only

The `svt_PCIE_DriverAppTransaction` class is used to create UVM sequences that are then scheduled on the transaction sequencer (`svt_PCIE_DeviceAgent::driver_transaction_seqr[0]`) of the driver application. Synopsys delivers a library of predefined sequences that can be readily used.

The list of these sequences can be found at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/sequencepages.html`

To get the list of all driver application transaction sequences, navigate to the following sequence:

| Group                             | Subgroup            |
|-----------------------------------|---------------------|
| DRIVER_TRANSACTION_PRIMITIVE_TYPE | DRIVER_TRANSACTIONS |

To view the complete list of constraints in each of the above sequence classes and the constraint definitions, see the [HTML class reference documentation](#).

[Example 12-8](#) illustrates the usage of the predefined sequence `svt_PCIE_driver_app_transaction_mem_write_sequence`.

### 17.3.3.2 User-Defined Transaction Sequences

You can also define custom UVM sequences and create a library of sequences of your own. [Example 17-1](#) shows the definition of a sequence that generates a constrained random sequence that issues a memory write followed by a memory read TLP.

#### Example 17-1

```
// Extend from VIP's base sequence class
class pcie_device_pseudo_random_sequence extends
svt_PCIE_driver_app_transaction_base_sequence;
    rand svt_PCIE_driver_app_transaction write_transaction;
    rand svt_PCIE_driver_app_transaction read_transaction;

    `svt_xvm_object_utils(pcie_device_pseudo_random_sequence)

// Constraints to ensure write TLP and read TLP requests are similar
constraint c_read_follows_write {
    write_transaction.transaction_type == svt_PCIE_driver_app_transaction::MEM_WR;
    read_transaction.transaction_type == svt_PCIE_driver_app_transaction::MEM_RD;
    write_transaction.address == read_transaction.address;
    write_transaction.length == read_transaction.length;
    write_transaction.first_dw_be == read_transaction.first_dw_be;
    write_transaction.last_dw_be == read_transaction.last_dw_be;
    write_transaction.traffic_class == read_transaction.traffic_class;
    write_transaction.address_translation == read_transaction.address_translation;

    write_transaction.ep == 0;
    read_transaction.ep == 0;
    write_transaction.block == 1;
    read_transaction.block == 1;
}

extern virtual task body();
extern function new(string name = "pcie_device_pseudo_random_sequence");

endclass: pcie_device_pseudo_random_sequence

function pcie_device_pseudo_random_sequence::new(string name);
    super.new(name);

// Construct/create transactions
`uvm_create(write_transaction)
```

```
    `uvm_create(read_transaction)
endfunction: new

task pcie_device_pseudo_random_sequence::body();
  // send the write followed by a read
  `uvm_info("body", "Entered...", UVM_LOW)

  // Issue the write transaction followed by a read
  `uvm_send(write_transaction);
  `uvm_send(read_transaction);

  `uvm_info("body", "Exiting...", UVM_LOW)
endtask
```

#### 17.3.3.2.1 Using Transaction Sequences in UVM Tests

You can use any of the predefined sequences or user-defined sequences to generate TLP traffic from the driver application in the UVM tests. [Example 17-2](#) illustrates an example test that generates TLP traffic using the sequence that is defined in [Example 17-1](#).

#### Example 17-2

```
class pseudo_random_serdes_test extends uvm_test;

  /** UVM Component Utility macro */
  `uvm_component_utils(pseudo_random_serdes_test)

  /** Class Constructor */
  function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
    super.new(name, parent);
  endfunction: new

  virtual task run_phase(uvm_phase phase);
    pcie_device_pseudo_random_sequence p_rand_seq;
    svt_PCIE_driver_app_service_wait_until_idle_sequence
    wait_until_driver_idle_service_seq;

    `uvm_info("run_phase", "Entered...", UVM_LOW)

    // Raise UVM objection
    phase.raise_objection(this);

    ...
  endtask

  // Assumptions:
  // The UVM test has an instance of UVM environment named 'env'
  // The UVM environment has an instance of the PCIe device agent named 'root'
  // VIP's DL is enabled.
  // LTSSM is in L0
  p_rand_seq = new();
  p_rand_seq.cfg = env.endpoint_cfg;
  p_rand_seq.write_transaction.cfg = env.endpoint_cfg;
  p_rand_seq.read_transaction.cfg = env.endpoint_cfg;
```

```

// Randomize the UVM sequence
    p_rand_seq.randomize with {
        write_transaction.address == 'h0000_0000;
        write_transaction.length == 2;
        write_transaction.first_dw_be == 4'b1111;
        write_transaction.last_dw_be == 4'b1111;
        write_transaction.traffic_class == 0;
        write_transaction.address_translation == 2'b00;
        foreach(write_transaction.payload[i])
            write_transaction.payload[i] == 'hbaadbaad;
    };
// Start the UVM sequence
    p_rand_seq.start(env.endpoint.driver_transaction_seqr[0]);
    wait_until_driver_idle_service_seq = new();
// Check for the driver is idle before ending test.
    wait_until_driver_idle_service_seq.start(env.endpoint.driver_seqr[0]); // End of
Test

// Drop UVM objection
    phase.drop_objection(this);
    `uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test

```

In [Example 17-2](#), the user-defined sequence `pcie_device_pseudo_random_sequence` is explicitly sequenced via the driver using the `svt_PCIE_Device_Agent::driver_seqr[0]`. An alternative way to run the sequence is to configure the UVM sequencer to execute the `pcie_device_pseudo_random_sequence` as a `default_sequence` at the beginning of its `main_phase()`. This approach is illustrated in [Example 17-3](#).

### Example 17-3

```

class pseudo_random_serdes_test extends uvm_test;
    /** UVM Component Utility macro */
    `uvm_component_utils(pseudo_random_serdes_test)

/** Class Constructor */
    function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
        super.new(name,parent);
    endfunction: new

    virtual function build_phase(uvm_phase phase);
        pcie_device_pseudo_random_sequence p_rand_seq;
        `uvm_info("build_phase", "Entered...", UVM_LOW)

// Sets the default_sequence of the driver transaction sequencer
        uvm_config_db#(uvm_object_wrapper)::set(this,
"env.endpoint.driver_transaction_seqr[0].main_phase", "default_sequence",
pcie_device_pseudo_random_sequence::type_id::get());

```

```
    `uvm_info("build_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test
```

### 17.3.3.3 Service Sequences

Service sequences, unlike transaction sequences, will not generate transactions on the PCIe bus and are used to request a change in the behavior or sample a state value of the driver application. The service sequences are sequenced via `svt_PCIE_DeviceAgent::driver_seqr[0]`. The requested service is described by service transaction class `svt_PCIE_DriverAppService`.

To view the complete list of members and constraints in class `svt_PCIE_DriverAppService` and their definitions, see the HTML class reference documentation at the following location:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/class_svt_PCIE_DriverAppService.html`

The `svt_PCIE_DriverAppService` class is used to create UVM sequences that can then be scheduled on the service sequencer (`svt_PCIE_DeviceAgent::driver_seqr[0]`) of the driver application. Synopsys delivers a library of predefined sequences that can be readily used.

Because the predefined library of driver application service sequences cover all of the possible service types, you can meet all of the testing needs with the predefined driver application service sequences without having to develop a custom service sequence that is built using `svt_PCIE_DriverAppService`.

[Example 17-2](#) illustrates the use of `svt_PCIE_DriverAppServiceWaitUntilIdleSequence` to wait for the driver application to be idle as an end criterion for the test. Similarly, [Example 17-4](#) shows the usage of `svt_PCIE_DriverAppServiceWaitForComplSequence`.

#### Example 17-4

```
// A custom sequence that generates a fairly random sequence of MemWr followed by a MemRd.
// Note: the sequence is non-blocking, the sequence will not wait for the completion of the posted MemRd.

class pcie_device_pseudo_random_non_blocking_sequence extends
svt_PCIE_DriverAppTransactionBaseSequence;
    rand svt_PCIE_DriverAppTransaction write_transaction;
    rand svt_PCIE_DriverAppTransaction read_transaction;

    `svt_XVM_object_Utils(pcie_device_pseudo_random_non_blocking_sequence)

// Constraints to ensure write TLP and read TLP requests are similar
constraint c_read_follows_write {
    write_transaction.transaction_type == svt_PCIE_DriverAppTransaction::MEM_WR;
    read_transaction.transaction_type == svt_PCIE_DriverAppTransaction::MEM_RD;
    write_transaction.address == read_transaction.address;
    write_transaction.length == read_transaction.length;
    write_transaction.first_dw_be == read_transaction.first_dw_be;
    write_transaction.last_dw_be == read_transaction.last_dw_be;
    write_transaction.traffic_class == read_transaction.traffic_class;
    write_transaction.address_translation == read_transaction.address_translation;

    write_transaction.ep == 0;
    read_transaction.ep == 0;
    write_transaction.block == 0;
    read_transaction.block == 0;
}
```

```
extern virtual task body(); //Same implementation as in Example 17-1
extern function new(string name = "pcie_device_pseudo_random_non_blocking_sequence");
endclass: pcie_device_pseudo_random_non_blocking_sequence

function pcie_device_pseudo_random_non_blocking_sequence::new(string name);
    super.new(name);

// Construct/create transactions
`uvm_create(write_transaction)
`uvm_create(read_transaction)
endfunction: new

task pcie_device_pseudo_random_non_blocking_sequence::body();
    // send the write followed by a read
    `uvm_info("body", "Entered...", UVM_LOW)

    // Issue the write transaction followed by a read
    `uvm_send(write_transaction);
    `uvm_send(read_transaction);

    `uvm_info("body", "Exiting...", UVM_LOW)
endtask

class pseudo_random_serdes_test extends uvm_test;
    /** UVM Component Utility macro */
    `uvm_component_utils(pseudo_random_serdes_test)

    /** Class Constructor */
    function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
        super.new(name,parent);
    endfunction: new

    virtual task run_phase(uvm_phase phase);
        pcie_device_pseudo_random_non_blocking_sequence p_rand_seq;
        svt_PCIE_driver_app_service_wait_for_compl_sequence wait_for_compl_service_seq;

        `uvm_info("run_phase", "Entered...", UVM_LOW)

        // Raise UVM objection
        phase.raise_objection(this);

        ...
    endtask: run_phase

    // Assumptions:
    // The UVM test has an instance of UVM environment named 'env'
    // The UVM environment has an instance of the PCIe device agent named 'root'
    // VIP's DL is enabled.
    // LTSSM is in L0
endclass: pseudo_random_serdes_test
```

```
p_rand_seq = new();
p_rand_seq.cfg = env.endpoint_cfg;
p_rand_seq.write_transaction.cfg = env.endpoint_cfg;
p_rand_seq.read_transaction.cfg = env.endpoint_cfg;

// Randomize the UVM sequence
p_rand_seq.randomize with {
    write_transaction.address == 'h0000_0000;
    write_transaction.length == 2;
    write_transaction.first_dw_be == 4'b1111;
    write_transaction.last_dw_be == 4'b1111;
    write_transaction.traffic_class == 0;
    write_transaction.address_translation == 2'b00;
    foreach(write_transaction.payload[i])
        write_transaction.payload[i] == 'hbaadbaad;
};

// Start the UVM sequence
p_rand_seq.start(env.endpoint.driver_transaction_seqr[0]);

wait_for_compl_service_seq = new();
wait_for_comple_service_seq.command_number =
p_rand_seq.read_transaction.command_num;

// Start the service sequence.
// The sequence will block until the completion of the MemRd transaction of the pseudo random sequence to complete.
wait_for_compl_service_seq.start(env.endpoint.driver_seqr[0]); // End of Test

// Drop UVM objection
phase.drop_objection(this);
`uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test
```

### 17.3.4 Callbacks and Events

As discussed in the [Introduction](#) section, the driver application is used to generate PCIe transaction requests targeting the link partner from a UVM test. The driver application tracks a transaction request from start to end and checks the completion of the transaction request for compliance to the PCIe specification. The application uses UVM callbacks and events to communicate the completion of a request. These UVM callbacks and events can be used for purposes such as functional coverage or scoreboarding.

#### 17.3.4.1 Driver Application Callbacks

The driver application has a single callback function, which is issued by the driver application after the completion of every transaction request queued on the driver application.

`transaction-ended (svt_PCIE_driver_app driver, svt_PCIE_driver_app_transaction transaction):` Callback issued by the driver application once the transaction request is completed. The completion information (for non-posted reads: payload[], completion\_status) returned by the link partner will be available inside transaction.

In UVM, callbacks are generally used to augment the UVM component behavior. Based on the implementation of the component, a callback could allow you to modify parameters of a transaction

presented in the callback. Typical use of such augmentation would be an error injection. However, the callback in the driver only allows you to sample the end event of a transaction request along with completion status and data. And so the `transaction-ended()` callback can be used to capture transactions to be sent to a functional coverage model or a testbench scoreboard.

### Steps to implement a driver callback

1. Define the callback class.

The first step to implementing a callback in UVM is to define a callback that extends from the base `uvm_callback` class and implement the desired callback function. In case of the driver application callback the class would need to extend from `svt_PCIE_driver_app_callback`, which falls under the `uvm_callback` inheritance hierarchy. [Example 17-5](#) shows an example callback definition with `transaction-ended()` implemented to push the transaction into the queues of a scoreboard.

#### Example 17-5

```
class svt_PCIE_driver_sb_callback extends svt_PCIE_driver_app_callback;

  // Factory registration
  `svt_xvm_object_utils(svt_PCIE_driver_sb_callback)

  // Testbench Scoreboard
  test_sb sb;

  function new(string name = "svt_PCIE_driver_sb_callback");
    super.new();
  endfunction

  //
  virtual function void transaction-ended(svt_PCIE_driver_app driver,
  svt_PCIE_driver_app_transaction transaction);
    `uvm_info("transaction-ended", $psprintf("driver transaction command number %0d has
    ended - Queuing to scoreboard", transaction.command_num), UVM_MEDIUM)
    sb.driver_tx_queue.push_back(transaction); // Assuming the scoreboard has a smart queue to hold all
    transmit packets from the driver
  endfunction

endclass
```

2. Register the callback.

Once the callback class is implemented, one or more instances of the callback can be registered with the component, which in this case is the driver application. [Example 17-6](#) shows an example test that illustrates how an instance of the callback defined in [Example 17-5](#) is registered with the driver application.

#### Example 17-6

```
class pseudo_random_serdes_test extends uvm_test;

  /** UVM Component Utility macro */
  `uvm_component_utils(pseudo_random_serdes_test)
  svt_PCIE_driver_sb_callback driver_sb_cb;
```

```
/** Class Constructor */

function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
    super.new(name,parent);
endfunction: new

virtual function void connect_phase (uvm_phase phase);
    super.connect_phase(phase);

    driver_sb_cb = new();
    //Assign the scoreboard instance inside the callback with a reference to the scoreboard in the testbench env
    driver_sb_cb.sb = this.env.sb;
    svt_pcie_driver_app_callback::add(env.root.driver[0], driver_sb_cb);
endfunction

...
endclass
```

#### 17.3.4.2 Driver Events

The driver application triggers the following events that can be sampled by the testbench for controlling test sequences.

- ❖ `svt_pcie_driver_app::EVENT_DRIVER_APP_TRANSACTION_ENDED`: A `uvm_event` that is triggered when the transaction is completed by the driver application.
- ❖ `svt_pcie_driver_app::EVENT RECEIVED_TLP`: A `uvm_event` that is triggered when a transaction is received by the driver application when configured as an application agent.
- ❖ `svt_pcie_driver_app::EVENT_SENT_TLP`: A `uvm_event` that is triggered when a transaction is sent by the driver application when configured as an application agent.

All of the UVM events listed in this section are of type `uvm_event` and hence they derive all the methods and features of the UVM event class. [Table 17-2](#) lists the user methods and describes each of them.

**Table 17-2 User Methods From the UVM Event Class**

| Method Name                             | Purpose       | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>task wait_on(bit delta=0)</code>  | Wait on event | This task waits for the event to be turned "on". This tasks will return immediately if the event has already been triggered. If 'delta=1', the caller will be forced to wait a single delta (#0) before returning. This prevents the caller from returning before previously waiting processes have had a chance to resume. Once an event is triggered, it will remain "on" until the event is <code>reset()</code> . |
| <code>task wait_off(bit delta=0)</code> |               | This task waits for the event to be tuned "off" via a call to <code>reset()</code> . This task will return immediately if the event has already been triggered. If 'delta=1', the caller will be forced to wait a single delta (#0) before returning. This prevents the caller from returning before previously waiting processes have had a chance to resume.                                                        |
| <code>task wait_trigger()</code>        |               | This task waits for the event to be triggered. If one process calls the <code>wait_trigger()</code> as another process, a race condition occurs. If the call to the <code>wait_trigger()</code> occurs after the trigger, this method will not return until the next trigger, which may never occur and thus cause a deadlock.                                                                                        |
| <code>task wait_ptrigger()</code>       |               | This task waits for a 'persistent' trigger of the event. Unlike <code>wait_trigger()</code> , this task views the trigger as persistent within a given time-slice and thus avoids certain race conditions. If this method is called after the trigger but within the same time-slice, the caller returns immediately.                                                                                                 |

**Table 17-2 User Methods From the UVM Event Class**

| Method Name                                                | Purpose                  | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| function uvm_object get_trigger_data()                     | Get trigger information  | This function returns the transaction for which the event was triggered. This function would return an object of type <code>svt_PCIE_driver_app_transaction</code> if called after the event <code>trigger()</code> .                                                                                                                                                                                |
| function time get_trigger_time()                           |                          | This function indicates the time when the event was last triggered. If the event has not been triggered, or the event has been reset, then the trigger time returned will be 0.                                                                                                                                                                                                                      |
| function is_on()                                           | Sample/Reset state value | This function indicates whether the event has been triggered since it was last reset. A value 1 indicates the event has triggered.                                                                                                                                                                                                                                                                   |
| function is_off()                                          |                          | This function indicates whether the event has not been triggered or been reset. A value 1 indicates that the event has not been triggered.                                                                                                                                                                                                                                                           |
| function reset(bit wakeup=0)                               |                          | This function resets the event to its off state. If <code>wakeup=1</code> , then all processes currently waiting for the even are activated before the reset.                                                                                                                                                                                                                                        |
| function add_callback(uvm_event_callback cb, bit append=1) | Attach/Detach callback   | This function registers a callback object (type <code>uvm_event_callback</code> ), <code>cb</code> , with the event. The callback object includes a <code>pre_trigger</code> and <code>post_trigger</code> functionality. If <code>append=1</code> , the default, <code>cb</code> is added to the back of the callback list. Otherwise, <code>cb</code> is placed at the front of the callback list. |
| function delete callback(uvm_event_callback cb)            |                          | This function unregisters the given callback, <code>cb</code> , from the event.                                                                                                                                                                                                                                                                                                                      |
| function void cancel()                                     | Get/Set list of waiters  | This function decrements the number of waiters on the event. This is used if a process that is waiting on an event is disabled or activated by some other means.                                                                                                                                                                                                                                     |
| function int get_num_waiters()                             |                          | This function returns the number of processes waiting on the event.                                                                                                                                                                                                                                                                                                                                  |

**Example 17-7** illustrates how to wait for a trigger on event `EVENT_DRIVER_APP_TRANSACTION_ENDED` and collect trigger data post the event trigger. The test issues a non-blocking driver application transaction sequence before waiting on a trigger from the event and collecting the trigger data.

### Example 17-7

```
class my_PCIE_test extends uvm_test;
  `uvm_component_utils(my_PCIE_test)
  ...
  task run_phase (uvm_phase phase);
    svt_PCIE_driver_app_mem_write_sequence mem_wr_seq;
    svt_PCIE_driver_app_mem_read_sequence mem_rd_seq;
    svt_configuration temp_cfg = null;
  ...

```

```
// Assumptions:  
// The UVM test has an instance of UVM environment named 'env'  
// The UVM environment has an instance of the PCIe device agent named 'root'  
// VIP's DL is enabled.  
// LTSSM is in L0  
  
mem_wr_seq = new();  
mem_rd_seq = new();  
  
env.root.get_cfg_via_task(temp_cfg);  
$cast(mem_wr_seq.cfg, temp_cfg.clone());  
$cast(mem_rd_seq.cfg, temp_cfg.clone());  
  
mem_wr_seq.randomize with {  
    transaction_type == svt_PCIE_driver_app_transaction::MEM_WR;  
    address == 'h8000;  
    length == 2;  
    first_dw_be == 4'b1111;  
    last_dw_be == 4'b1111;  
    traffic_class == 0;  
    address_translation == 2'b00;  
    ep == 0;  
    foreach(write_payload[i])  
        write_payload[i] == 'hc0de_0000 + i;  
    block == 0;  
};  
mem_wr_seq.start(env.root.driver_transaction_seqr[0]);  
  
// Wait for a trigger on EVENT_DRIVER_APP_TRANSACTION_ENDED  
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.wait_trigger();  
`uvm_info("run_phase", $psprintf("EVENT_DRIVER_APP_TRANSACTION_ENDED just triggered at %0t.",  
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_time()), UVM_MEDIUM)  
  
// Get data transaction object associated with the latest trigger of  
EVENT_DRIVER_APP_TRANSACTION_ENDED  
get_trg_uvm_obj =  
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_data();  
$cast(get_trg_drv_trans_obj, get_trg_uvm_obj);  
// We expect the following print() function to print MEM_WR transaction initiated by the test.  
get_trg_drv_trans_obj.print();  
  
mem_rd_seq.randomize with {  
    transaction_type == svt_PCIE_driver_app_transaction::MEM_RD;  
    address == 'h8000;  
    length == 2;  
    first_dw_be == 4'b1111;  
    last_dw_be == 4'b1111;  
    traffic_class == 0;  
    address_translation == 2'b00;  
    ep == 0;  
    block == 0;  
};  
mem_rd_seq.start(env.root.driver_transaction_seqr[0]);
```

```

//Wait for a trigger on EVENT_DRIVER_APP_TRANSACTION_ENDED
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.wait_trigger();
`uvm_info("run_phase", $psprintf("EVENT_DRIVER_APP_TRANSACTION_ENDED just
triggered at %0t.", env.endpoint.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_time()), UVM_MEDIUM)

//Get data transaction object associated with the latest trigger of
EVENT_DRIVER_APP_TRANSACTION_ENDED
get_trg_uvm_obj =
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_data();
$cast(get_trg_drv_trans_obj, get_trg_uvm_obj);
//We expect the following print() function to print MEM_RD transaction initiated by the test.
get_trg_drv_trans_obj.print();

//End of Test
endtask
endclass

```

The UVM event class has a built-in callback mechanism that can be used by the testbench for performing additional book-keeping functions with each trigger of any of the events. Class `uvm_event_callback` is the base callback class which can be extended for user-defined purposes. The callback functions provided are:

1. `pre_trigger (uvm_event e, uvm_object data)`: This callback is called just before triggering the associated event. In a derived class, this method should be overridden with an implement of a user desired pre-trigger functionality. If the implementation of the function returns 1, then the event will not trigger and the post-trigger callback will not be called. This provides a way for a callback to prevent the event from triggering. In the function, `e` is the `uvm_event` that is being triggered, and `data` is the transaction object associated with the event being triggered.
2. `post_trigger (uvm_event e, uvm_object data)`: This callback is called after triggering the associated event. In a derived class, this method should be overridden with an implement of a user desired post-trigger functionality. In the function, `e` is the `uvm_event` that is being triggered, and `data` is the transaction object associated with the event being triggered.

[Example 17-8](#) illustrates how a `post_trigger()` callback is used to sample the data object associated with the event. The sampling of data object in this example can be compared to the sampling of the data object in [Example 17-7](#), which does an in-line sample of the data object using `uvm_event::get_trigger_data()`.

### Example 17-8

```

//Define the UVM event callback class extending from uvm_event_callback
class event_driver_app_transaction_ended_callback extends uvm_event_callback;
  `svt_xvm_object_utils(event_driver_app_transaction_ended_callback)

  function new(string name = "event_driver_app_transaction_ended_callback");
    super.new(name);
  endfunction

//Implementing post_trigger function for processing the related data object post-trigger of the UVM event
  virtual function void post_trigger (uvm_event e, uvm_object data);
    `uvm_info("post_trigger", "EVENT_DRIVER_APP_TRANSACTION_ENDED has triggered",
    UVM_LOW)
  endfunction

```

```
// Printing the data associated with the event that is about to be triggered.  
// Here we only print the object. This object could be posted to a coverage model to sample functional coverage or a scoreboard to check against data received at the remote receiver.  
    data.print();  
  
    return;  
endfunction  
  
endclass  
  
class my_pcie_test extends uvm_test;  
    `uvm_component_utils(my_pcie_test)  
    event_driver_app_transaction_ended_callback transaction_ended_cb;  
    ...  
    function void connect_phase(uvm_phase phase);  
        super.connect_phase(phase);  
  
    // Construct and register the event callback with EVENT_DRIVER_APP_TRANSACTION_ENDED  
    transaction_ended_cb = new("transaction_ended_cb");  
  
    env.endpoint.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.add_callback(transaction_ended_cb);  
endfunction  
  
task run_phase (uvm_phase phase);  
    svt_pcie_driver_app_mem_write_sequence mem_wr_seq;  
    svt_pcie_driver_app_mem_read_sequence mem_rd_seq;  
    svt_configuration temp_cfg = null;  
    ...  
    // Assumptions:  
    // The UVM test has an instance of UVM environment named 'env'  
    // The UVM environment has an instance of the PCIe device agent named 'root'  
    // VIP's DL is enabled.  
    // LTSSM is in L0  
  
    mem_wr_seq = new();  
    mem_rd_seq = new();  
  
    env.root.get_cfg_via_task(temp_cfg);  
    $cast(mem_wr_seq.cfg, temp_cfg.clone());  
    $cast(mem_rd_seq.cfg, temp_cfg.clone());  
  
    mem_wr_seq.randomize with {  
        transaction_type == svt_pcie_driver_app_transaction::MEM_WR;  
        address == 'h8000;  
        length == 2;  
        first_dw_be == 4'b1111;  
        last_dw_be == 4'b1111;  
        traffic_class == 0;  
        address_translation == 2'b00;  
        ep == 0;  
        foreach(write_payload[i])  
            write_payload[i] == 'hc0de_0000 + i;  
        block == 0;  
    };
```

```

    mem_wr_seq.start(env.root.driver_transaction_seqr[0]);

    //Wait for a trigger on EVENT_DRIVER_APP_TRANSACTION_ENDED
    env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.wait_trigger();
    `uvm_info("run_phase", $psprintf("EVENT_DRIVER_APP_TRANSACTION_ENDED just
triggered at %0t.",,
env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_time()), UVM_MEDIUM)
    //post_trigger() callback for EVENT_DRIVER_APP_TRANSACTION_ENDED of MEM_WR is expected to occur
at this point in time.

    mem_rd_seq.randomize with {
        transaction_type == svt_pcie_driver_app_transaction::MEM_RD;
        address == 'h8000;
        length == 2;
        first_dw_be == 4'b1111;
        last_dw_be == 4'b1111;
        traffic_class == 0;
        address_translation == 2'b00;
        ep == 0;
        block == 0;
    };
    mem_rd_seq.start(env.root.driver_transaction_seqr[0]);

    //Wait for a trigger on EVENT_DRIVER_APP_TRANSACTION_ENDED
    env.root.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.wait_trigger();
    `uvm_info("run_phase", $psprintf("EVENT_DRIVER_APP_TRANSACTION_ENDED just
triggered at %0t.",,
env.endpoint.driver[0].EVENT_DRIVER_APP_TRANSACTION_ENDED.get_trigger_time()), UVM_MEDIUM)
    //post_trigger() callback for EVENT_DRIVER_APP_TRANSACTION_ENDED of MEM_RD is expected to occur
at this point in time.

    //End of Test
endtask
endclass

```

### 17.3.5 Exceptions

The PCIe VIP provides a mechanism to create error scenarios with the use of a methodology that includes:

- ❖ Exception Object: An object that encapsulates the error information such as kind, corrupted data value (if applicable), error weights (for injection based on statistics) and so on. In the driver application, class `svt_pcie_driver_app_transaction_exception` models the exception.

To view the complete list of constraints in class `svt_pcie_driver_app_transaction_exception` and their definitions, see the HTML class reference documentation:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_pcie_driver_app_transaction_exception.html`

Class `svt_pcie_driver_app_transaction_exception` has functions that you can use to query/modify the exception object. The most commonly used ones are:

- ◆ `has_*_error()`: A group of functions to query if the exception object has a specific kind of error. For example, `has_auto_corrupt_lcrc_error()` indicates if the exception object has

AUTO\_CORRUPT\_LCRC error. The function returns a bit value, 1 indicates that error is present and 0 indicates error is not present.



To view the full list or predefined error types supported by the driver application, see the HTML class reference documentation:

[http://\\$DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/exception/class\\_svt\\_PCIE\\_driver\\_app\\_transaction\\_exception.html#item\\_error\\_kind\\_enum](http://$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_PCIE_driver_app_transaction_exception.html#item_error_kind_enum)

- ◆ `reasonable_constraint_mode (bit on_off)`: A function that can be used to turn OFF/ON the reasonable constraints defined in `svt_PCIE_driver_app_transaction_exception` class. By default, all reasonable constraints are ON. The function will return a value -1 if it failed to perform the operation of turning the constraint ON/OFF, else it would return a value same as the input bit `on_off`.
- ◆ `set_constraint_weights (int new_weight)`: A function that can be used to set the relative weight distribution for all exception kinds as a block. Sets the specified weight for all `_wt` attributes except `NO_ERROR_wt`.

This is not an exhaustive list. For the full list, see HTML description of the `svt_PCIE_driver_app_transaction_exception` class:

[http://\\$DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/exception/class\\_svt\\_PCIE\\_driver\\_app\\_transaction\\_exception.html](http://$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_PCIE_driver_app_transaction_exception.html)

- ❖ Exception List Object: An object that encapsulates an instance/multiple instances of exception object/objects and other information such as number of errors, exception factory (for randomized error injection), and so on. In the driver application, class `svt_PCIE_driver_app_transaction_exception_list` models the exception list. Class `svt_PCIE_driver_app_transaction_exception_list` extends from `svt_exception_list`, a SVT base class.

To view the complete list of members and constraints in class `svt_PCIE_driver_app_transaction_exception_list` and their definitions, see HTML class reference documentation:

[http://\\$DESIGNWARE\\_HOME/vip/svt/pcie\\_svt/latest/doc/pcie\\_svt\\_uvm\\_class\\_reference/html/exception/class\\_svt\\_PCIE\\_driver\\_app\\_transaction\\_exception\\_list.html](http://$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_PCIE_driver_app_transaction_exception_list.html)

Class `svt_PCIE_driver_app_transaction_exception_list` has a number of user functions, which finds use in writing exception tests. The most commonly used ones are:

- ◆ `setup_randomized_exception (svt_PCIE_device_configuration cfg, svt_PCIE_driver_app_transaction xact)`: A function used to adjust the object reference `xact`, an instance of type `svt_PCIE_driver_app_transaction`, inside `svt_PCIE_driver_app_transaction_exception` to make it point to the transaction which is being injected with an error/exception. This function should be called if exception is being injected using the factory object `randomized_exception` and it should be called before the call to randomize the exception list object.
- ◆ `num_exception_first_randomize()`: A function used to randomize the exception list. The function is different from a simple SystemVerilog `randomize()` since it first randomizes `num_exceptions` first and then rest of the exception list class, populating the list with an array of random exceptions. The function returns a bit value indicating the result of the randomization. A value indicates a success and a value 0 indicates failure.

- ◆ `reasonable_constraint_mode(bit on_off)`: A function that can be used to turn OFF/ON the reasonable constraints defined in `svt_PCIE_driver_app_transaction_exception_list` class. By default, all reasonable constraints are ON. The function will return a value -1 if it fails to perform the operation of turning the constraint ON/OFF, else it would return a value same as the input bit `on_off`.
- ◆ `set_constraint_weights (int new_weight)`: A function that can be used to set the relative weight distribution for all exception kinds of every exception object in the array of exception objects that are part of the exception list class. Sets the specified weight for all `_wt` attributes except `NO_ERROR_wt`.

Note: This is not an exhaustive list. For the full list, see HTML descriptions of `svt_PCIE_driver_app_transaction_exception_list` class:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_PCIE_driver_app_transaction_exception_list.html`

`svt_exception_list` class:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/exception/class_svt_exception_list.html#item_add_exception`

The following diagram shows how an exception list is related to an exception object and how a transaction object relates to an exception list object.

**Figure 17-3 Exception List, Exception, Transaction**



The exception methodology in the PCIe VIP as a whole allows three different methods to inject errors:

1. Exception in stimulus: This method involves the implementation of a test that attaches a list of errors, or exceptions as they are known in the VIP, to a transaction while it is being queued on the VIP.
2. Exception via Callbacks: This method involves the implementation of a callback method to attach errors/exceptions to a transaction that is transiting via the callback method. As discussed in the driver application callbacks section, the driver application has a single callback function `transaction_ended()`, which is issued after a transaction ends, so it cannot serve the purpose of error/exception injection. Thus, this mechanism is not applicable to the driver application. However, other layers/application such as the DL, PL, target application, and so on, have callbacks that can be used for the purpose of injecting error/exceptions.

3. Exception via Component (Driver Application) Factory: This method involves the implementation of a user-defined exception list class with constraints that will cause constrained random pattern of errors and the setting of the exception list factory object inside the VIP to the user-defined exception list.

**Figure 17-4 Error Injection Methods**



### 17.3.5.1 Exception in Stimulus

One of the two mechanisms of introducing errors or exceptions in packets generated by the driver application is to attach an exception list object to the driver application transaction being queued on the driver application. [Example 17-9](#), a modified form of [Example 17-2](#), illustrates the injection of a directed error (LCRC corruption) into the memory read transaction of the UVM sequence.

#### Example 17-9

```
class pseudo_random_serdes_test extends uvm_test;  
  
  /** UVM Component Utility macro */  
  `uvm_component_utils(pseudo_random_serdes_test)  
  
  /** Class Constructor */  
  function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);  
    super.new(name,parent);  
  endfunction: new  
  
  virtual task run_phase(uvm_phase phase);  
    pcie_device_pseudo_random_sequence p_rand_seq;
```

```
svt_PCIE_driver_app_service_wait_until_idle_sequence
wait_until_driver_idle_service_seq;

// Declare an exception list object for error injection.
svt_PCIE_driver_app_transaction_exception_list my_rand_exc_list;

`uvm_info("run_phase", "Entered...", UVM_LOW)

// Raise UVM objection
phase.raise_objection(this);

...
// Assumptions:
// The UVM test has an instance of UVM environment named 'env'
// The UVM environment has an instance of the PCIe device agent named 'root'
// VIP's DL is enabled.
// LTSSM is in L0

p_rand_seq = new();
p_rand_seq.cfg = env.endpoint_cfg;
p_rand_seq.write_transaction.cfg = env.endpoint_cfg;
p_rand_seq.read_transaction.cfg = env.endpoint_cfg;

// Randomize the UVM sequence

p_rand_seq.randomize with {
    write_transaction.address == 'h0000_0000;
    write_transaction.length == 2;
    write_transaction.first_dw_be == 4'b1111;
    write_transaction.last_dw_be == 4'b1111;
    write_transaction.traffic_class == 0;
    write_transaction.address_translation == 2'b00;
    foreach(write_transaction.payload[i])
        write_transaction.payload[i] == 'hbaadbaad;
};

// Construct the exception list object

my_rand_exc_list = new();

// Initialize the exception list inside the read transaction, the transaction targeted for error injection

p_rand_seq.read_transaction.exception_list = my_rand_exc_list;

// Populate the exceptions[] array inside the exception list object.

// The VIP will create a single element inside exceptions[] by virtue of the
svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions being initialized to 1.

// Set svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions to a higher value if more than a single
error is desired.

p_rand_seq.read_transaction.exception_list.populate_exceptions();

// Specify the desired error kind.

p_rand_seq.read_transaction.exception_list.exceptions[0].error_kind =
svt_PCIE_driver_app_transaction_exception::AUTO_CORRUPT_LCRC;

// Inject the specified error.

p_rand_seq.read_transaction.exception_list.inject_exceptions();
```

```
// Start the UVM sequence
    p_rand_seq.start(env.root.driver_transaction_seqr[0]);
    wait_until_driver_idle_service_seq = new();
// Check for the driver is idle before ending test.
    wait_until_driver_idle_service_seq.start(env.root.driver_seqr[0]); // End of Test

// Drop UVM objection
    phase.drop_objection(this);
    `uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask
endclass //pseudo_random_serdes_test
```

The simulation log will print the following messages while it injects the LCRC corruption error and as part of the error handling:

```
UVM_INFO @ 17565152.50 ps: uvm_test_top.env.endpoint.driver0 [report_message]
SetEiCodeForNextTransaction: EI - 'TX_TLP_EI_CORRUPT_LCRC' requested with corrupted_data
= 0
...
UVM_INFO @ 17585152.50 ps: uvm_test_top.env.endpoint.port0.d10 [report_message]
GenerateTxTLPEI: EI - Injecting LCRC violation. Expect DUT to send NAK.
...
UVM_INFO @ 17765152.50 ps: uvm_test_top.env.endpoint.port0.d10 [report_message]
ProcessReceivedDLLP: EI - Received NAK as expected.
```

The transaction log will tag the error packet as shown below. The retry following the error packet is also tagged.

| Reporter  | Time (ns) | Start Time (ns) | End Time (ns) | I R   | TLP Type  | R_ID/Tag ST DLLP Type | Seq Num ....                  | Prefix / Header / Data (All values in Hex) | E P | ECRC       | LCRC CRC | TX/RX Status |
|-----------|-----------|-----------------|---------------|-------|-----------|-----------------------|-------------------------------|--------------------------------------------|-----|------------|----------|--------------|
| ...       |           |                 |               |       |           |                       | ---                           | ---                                        | --- | ---        | ---      | ---          |
| endpoint0 | 17589.000 | 17613.000       | T             | MWr32 | 0x0001/12 | 1 ....                | H40000002 H000112ff H00000000 | ---                                        | 0   | 0x7f477092 |          |              |
| ...       |           |                 |               |       |           | ....                  | baadbaad baadbaad ---         | ---                                        | --- |            |          |              |
| endpoint0 | 17621.000 | 17637.000       | T             | MRd32 | 0x0001/1b | 2 ....                | H00010002 H00011b34 H00000003 | ---                                        |     | 0xda8d515d | LCRC     |              |
| endpoint0 | 17733.000 | 17765.000       | R             | NAK   | 0x0001/1b | 1 ....                |                               |                                            |     |            | 0xf91e   |              |
| ...       |           |                 |               |       |           |                       |                               |                                            |     |            |          |              |
| endpoint0 | 17805.000 | 17821.000       | T             | MRd32 | 0x0001/1b | 2 ....                | H00010002 H00011b34 H00000003 | ---                                        |     | 0xda8d515c | Retry    |              |
| ...       |           |                 |               |       |           |                       |                               |                                            |     |            |          |              |
| endpoint0 | 17921.000 | 17973.000       | R             | CplD  | 0x0001/1b | 1 ....                | H4a000002 H01000008 H00011b00 | ---                                        | 0   | 0xedaf072c |          |              |
| ...       |           |                 |               |       |           | ....                  | baadbaad baadbaad ---         | ---                                        | --- |            |          |              |



The error handling in the VIP will vary for different error kinds. The log snippets shown above are specific to the AUTO\_CORRUPT\_LCRC error kind. Error injection related VIP messages are generally tagged with "EI -".

In Example 17-9, the error\_kind is set to a specific value, making the test a very directed one. A more randomized approach can also be used by using the randomized\_exception\_factory object inside the exception list class, and setting the relative weight distribution variables provided in the exception class.

**Example 17-10**, a modified form of example, illustrates the injection of an error (LCRC corruption) using randomized\_exception object in the exception list class.

**Example 17-10**

```
class pseudo_random_serdes_test extends uvm_test;  
  
  /** UVM Component Utility macro */  
  `uvm_component_utils(pseudo_random_serdes_test)  
  
  /** Class Constructor */  
  function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);  
    super.new(name, parent);  
  endfunction: new  
  
  virtual task run_phase(uvm_phase phase);  
    pcie_device_pseudo_random_sequence p_rand_seq;  
    svt_PCIE_driver_app_service_wait_until_idle_sequence  
    wait_until_driver_idle_service_seq;  
  
    // Declare an exception list object for error injection.  
    svt_PCIE_driver_app_transaction_exception_list my_rand_exc_list;  
  
    `uvm_info("run_phase", "Entered...", UVM_LOW)  
  
    // Raise UVM objection  
    phase.raise_objection(this);  
  
    ...  
  
    // Assumptions:  
    // The UVM test has an instance of UVM environment named 'env'  
    // The UVM environment has an instance of the PCIe device agent named 'root'  
    // VIP's DL is enabled.  
    // LTSSM is in L0  
  
    p_rand_seq = new();  
    p_rand_seq.cfg = env.endpoint_cfg;  
    p_rand_seq.write_transaction.cfg = env.endpoint_cfg;  
    p_rand_seq.read_transaction.cfg = env.endpoint_cfg;  
  
    // Randomize the UVM sequence  
    p_rand_seq.randomize with {  
      write_transaction.address == 'h0000_0000;  
      write_transaction.length == 2;  
      write_transaction.first_dw_be == 4'b1111;  
      write_transaction.last_dw_be == 4'b1111;  
      write_transaction.traffic_class == 0;  
      write_transaction.address_translation == 2'b00;  
      foreach(write_transaction.payload[i])  
        write_transaction.payload[i] == 'hbaadbaad;  
    };
```

```
my_rand_exc = new();
// Set the constraint weight of all error kinds & NO_ERROR_wt to 0
my_rand_exc.set_constraint_weights(0);
my_rand_exc.NO_ERROR_wt = 0;
// Set the constraint weight of AUTO_CORRUPT_LCRC to a non-zero value
my_rand_exc.AUTO_CORRUPT_LCRC_wt = 100;

my_rand_exc_list = new();
// Set the factory exception inside my_rand_exc_list with the my_rand_exc
my_rand_exc_list.randomized_exception = my_rand_exc;
// Associate the transaction and the exception object. Note: configuration of the device must also be provided.
my_rand_exc_list.setup_randomized_exception(env.cfg.endpoint_cfg,
p_rand_seq.read_transaction);

// Randomize 'num_exceptions' first, this will result in num_exceptions will result in a random value.
// By default the constraints sets a cap of 1 by virtue of
svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions being set to 1
// If a higher count of errors are required program
svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions to a higher value before
// calling num_exceptions_first_randomize()

void'(my_rand_exc_list.num_exceptions_first_randomize());
// Note: num_exceptions_first_randomize() could result in num_exception = 0 or 1 (default constraints), causing a
random possibility of error.

`uvm_info("run_phase", $psprintf("num_exceptions_first_randomize() resulted in
my_rand_exc_list.num_exceptions = %0d", my_rand_exc_list.num_exceptions), UVM_LOW)
//p_rand_seq.read_transaction.exception_list = my_rand_exc_list;

// Start the UVM sequence
p_rand_seq.start(env.root.driver_transaction_seqr[0]);
wait_until_driver_idle_service_seq = new();
// Check for the driver is idle before ending test.
wait_until_driver_idle_service_seq.start(env.root.driver_seqr[0]); // End of Test

// Drop UVM objection
phase.drop_objection(this);
`uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test
```

In [Example 17-10](#), the relative weight distribution of errors is set to resolve to AUTO\_CORRUPT\_LCRC error kind always. The weights can be modified to pick and choose from different error kinds.

The VIP also provides a predefined set of driver application transaction sequences that can be readily used to generate all error kinds supported by the driver application. [Table 17-3](#) lists these sequence classes.

**Table 17-3 : Predefined UVM Sequences with Built-in Exceptions**

| Sequence class name                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| svt_PCIE_driver_app_mem_request_exception_sequence | <p>This sequence is used to generate error injected <code>MemRd</code> and <code>MemWr</code> transactions from the driver application.</p> <p>The UVM sequence has the following members that users can use to program the number of errors and the kind of error:</p> <ul style="list-style-type: none"> <li>• <code>svt_PCIE_driver_app_transaction_exception::error_kind_enum transaction_error_kind</code>: A <code>rand</code> type variable, which can be constrained to generate any of the error kinds listed in <code>svt_PCIE_driver_app_transaction_exception</code> class, will determine the kind of error that will be introduced into the memory transaction.</li> <li>• <code>int num_exceptions</code>: A <code>rand</code> type variable that will determine the number of errors to be introduced into the memory transaction.</li> </ul> <p>The UVM sequence has the following members that users can use to program the type of the memory transaction:</p> <ul style="list-style-type: none"> <li>- <code>rand svt_PCIE_driver_app_transaction::transaction_type_enum transaction_type</code></li> <li>- <code>rand bit[63:0] address</code></li> <li>- <code>rand bit[9:0] length</code></li> <li>- <code>rand bit[31:0] write_payload[]</code></li> <li>- <code>rand bit[3:0] first_dw_be</code></li> <li>- <code>rand bit[3:0] last_dw_be</code></li> <li>- <code>rand bit[2:0] traffic_class</code></li> <li>- <code>rand bit[1:0] address_translation</code></li> <li>- <code>rand bit ep</code></li> <li>- <code>rand bit block</code></li> <li>- <code>rand bit th = 0</code></li> <li>- <code>rand bit ln = 0</code></li> <li>- <code>rand svt_PCIE_driver_app_transaction::ph_enum ph</code></li> <li>- <code>rand bit [7:0] st</code></li> <li>- <code>int command_num</code></li> <li>- <code>rand int unsigned pkt_delay_ns</code></li> <li>- <code>rand bit reserved_byte1_bit7</code></li> <li>- <code>rand bit reserved_byte1_bit1</code></li> <li>- <code>rand bit reserved_byte1_bit3</code></li> <li>- <code>rand bit reserved_byte1_bit0</code></li> <li>- <code>rand bit[1:0] reserved_byte11_bit1_to_bit0</code></li> <li>- <code>rand bit[1:0] reserved_byte15_bit1_to_bit0</code></li> </ul> <p>For description of each of these data members, see class <code>svt_PCIE_driver_app_transaction</code> in the HTML class reference documentation. Also note that most of these data members are all <code>rand</code> type. To find out the constraints that govern the randomization of these data members check lookup the definition of the class in file: <code>svt_PCIE_driver_app_transaction_sequence_collection.sv</code> in the installation area.</p> |

**Table 17-3 : Predefined UVM Sequences with Built-in Exceptions**

| <b>Sequence class name</b>                            | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| svt_PCIE_driver_app_io_cfg_request_exception_sequence | <p>This sequence is used to generate error injected IO (IO_WR, IO_RD) and Config (CFG_WR, CFG_RD) transactions from the driver application.</p> <p>The UVM sequence has the following members that users can use to program the number of errors and the kind of error:</p> <ul style="list-style-type: none"> <li>• svt_PCIE_driver_app_transaction_exception::error_kind_enum transaction_error_kind: A rand type variable, which can be constrained to generate any of the error kinds listed in svt_PCIE_driver_app_transaction_exception class, will determine the kind of error that will be introduced into the memory transaction.</li> <li>• int num_exceptions: A rand type variable that will determine the number of errors to be introduced into the memory transaction.</li> </ul> <p>The UVM sequence has the following members that users can use to program the type of the memory transaction:</p> <ul style="list-style-type: none"> <li>- rand bit[63:0] address</li> <li>- rand bit[31:0] write_payload</li> <li>- rand bit[3:0] first_dw_be</li> <li>- rand bit ep</li> <li>- rand bit blockint command_num</li> <li>- rand int unsigned pkt_delay_ns</li> <li>- rand bit [9:0] register_number</li> <li>- rand bit cfg_type</li> <li>- rand bit reserved_byte1_bit7</li> <li>- rand bit reserved_byte1_bit1</li> <li>- rand bit reserved_byte1_bit3</li> <li>- rand bit reserved_byte1_bit0</li> <li>- rand bit[1:0] reserved_byte11_bit1_to_bit0</li> </ul> <p>For description of each of these data members, see class svt_PCIE_driver_app_transaction in the HTML class reference documentation. Also note that most of these data members are all rand type. To find out the constraints that govern the randomization of these data members check lookup the definition of the class in file: svt_PCIE_driver_app_transaction_sequence_collection.sv in the installation area.</p> |

Example 17-11 illustrates the use of svt\_PCIE\_driver\_app\_mem\_request\_exception\_sequence to generate a memory read transaction with a corrupted LCRC.

### Example 17-11

```

class pseudo_random_serdes_test extends uvm_test;

  /** UVM Component Utility macro */
  `uvm_component_utils(pseudo_random_serdes_test)

  /** Class Constructor */
  function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
    super.new(name,parent);
  endfunction: new

  virtual task run_phase(uvm_phase phase);
    // Pre-defined Driver App transaction sequence with built-in exception.

```

```
svt_PCIE_driver_app_mem_request_exception_sequence mem_req_exc_seq
svt_PCIE_driver_app_service_wait_until_idle_sequence
wait_until_driver_idle_service_seq;

`uvm_info("run_phase", "Entered...", UVM_LOW)

// Raise UVM objection
phase.raise_objection(this);

...
// Assumptions:
// The UVM test has an instance of UVM environment named 'env'
// The UVM environment has an instance of the PCIe device agent named 'root'
// VIP's DL is enabled.
// LTSSM is in L0

mem_req_exc_seq = new();
mem_req_exc_seq.cfg = env.cfg.endpoint_cfg;

mem_req_exc_seq.randomize with {
    // Programming the transaction type to a memory read TLP.
    transaction_type == svt_PCIE_driver_app_transaction::MEM_RD;
    // Selecting the exception kind to AUTO_CORRUPT_LCRC to corrupt the LCRC
    transaction_error_kind ==
svt_PCIE_driver_app_transaction_exception::AUTO_CORRUPT_LCRC;
    // Selecting the number of exceptions to 1
    num_exceptions == 1;
    address == 'h0000_0000;
    length == 2;
    first_dw_be == 4'b1111;
    last_dw_be == 4'b1111;
    traffic_class == 0;
    address_translation == 2'b00;
    block == 1;
};

// Start the UVM sequence
mem_req_exc_seq.start(env.root.driver_transaction_seqr[0]);

wait_until_driver_idle_service_seq = new();
// Check for the driver is idle before ending test.
wait_until_driver_idle_service_seq.start(env.root.driver_seqr[0]); // End of Test

// Drop UVM objection
phase.drop_objection(this);
`uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test
```

### 17.3.5.2 Exception via Component Factory

In the previous section, we discussed the injection of exception directly on the stimulus stream. While this option provides a fine-grain control that allows you to pick and choose transactions for error/exception injection, it doesn't allow a purely random selection of transactions for error/exception injection. For tests cases that target a purely random selection of tests, the UVM VIP has a factory object defined inside the driver application, which can be initialized with a user-defined (constraints) to enable not just a pure random selection but also a random pattern of errors.

#### Example 17-12

```
// Define an exception class to define error weights of desired choice
class my_driver_app_transaction_exception_list extends
svt_PCIE_driver_app_transaction_exception_list;

    svt_PCIE_driver_app_transaction_exception xact_exc = new("xact_exc");

    function new(string name = "dl_tlp_exception_list_via_factory",
svt_PCIE_driver_app_transaction_exception xact_exc = null);
        super.new(name,xact_exc);
        xact_exc = this.xact_exc;
    endfunction

    // Set all error weights to 0
    xact_exc.set_constraint_weights(0);
    // Setting NO_ERROR weight to 4 and AUTO_TX_CORRUPT weight to 1
    // 20% error (corrupted LCRC) and 80% no error packets
    xact_exc.NO_ERROR_wt = 4;
    xact_exc.AUTO_CORRUPT_LCRC_wt = 1;
    // Set the exception factory of the exception list class
    this.randomized_exception = xact_exc;
endfunction
endclass

// UVM Test
class pseudo_random_serdes_test extends uvm_test;

    /** UVM Component Utility macro */
    `uvm_component_utils(pseudo_random_serdes_test)

    // Declare an exception list object for error injection.
    svt_PCIE_driver_app_transaction_exception_list drv_app_exc_list_factory;

    /** Class Constructor */
    function new(string name = "pseudo_random_serdes_test", uvm_component parent=null);
        super.new(name,parent);
    endfunction: new

    virtual function void build_phase(uvm_phase phase);
        `uvm_info("build_phase", "Entered...", UVM_LOW)
        super.build_phase(phase);
    endfunction
```

```
// Create an object of drv_app_exc_list_factory
drv_app_exc_list_factory = new("drv_app_exc_list_factory");

// Setting a limit on the maximum possible exceptions attached on a single transaction.
// Setting to 1 will result in a random behavior of no error or 1 error on the transaction.
drv_app_exc_list_factory.max_num_exceptions = 1;
// Weight distribution for a short (less than or equal to num_exceptions/2) list. Set to 1 so that the driver application generates a single error.
drv_app_exc_list_factory.EXCEPTION_LIST_SINGLE_wt = 1;
// Weight distribution for an empty list. Set to 0 since the test intends to generate a single error.
drv_app_exc_list_factory.EXCEPTION_LIST_EMPTY_wt = 0;
// Weight distribution for a short (less than or equal to num_exceptions/2) list. Set to 0 since the test intends to generate a single error.
drv_app_exc_list_factory.EXCEPTION_LIST_SHORT_wt = 0;
// Weight distribution for a short (greater than num_exceptions/2) list. Set to 0 since the test intends to generate a single error.
drv_app_exc_list_factory.EXCEPTION_LIST_LONG_wt = 0;

// Set the factory exception list inside the driver application using UVM config DB
uvm_config_db#(svt_PCIE_driver_app_transaction_exception_list)::set(this,
"env.endpoint.driver0", "driver_xact_exception_list", drv_app_exc_list_factory);

`uvm_info("build_phase", "Exiting...", UVM_LOW)
endfunction: build_phase

virtual task run_phase(uvm_phase phase);
    pcie_device_pseudo_random_sequence p_rand_seq;
    svt_PCIE_driver_app_service_wait_until_idle_sequence
wait_until_driver_idle_service_seq;

    `uvm_info("run_phase", "Entered...", UVM_LOW)

// Raise UVM objection
phase.raise_objection(this);

...
// Assumptions:
// The UVM test has an instance of UVM environment named 'env'
// The UVM environment has an instance of the PCIe device agent named 'root'
// VIP's DL is enabled.
// LTSSM is in L0
    p_rand_seq = new();
    p_rand_seq.cfg = env.endpoint_cfg;
    p_rand_seq.write_transaction.cfg = env.endpoint_cfg;
    p_rand_seq.read_transaction.cfg = env.endpoint_cfg;

    for (int i=0; i<5 ; i++) begin
// Randomize the UVM sequence
```

```
p_rand_seq.randomize with {
    write_transaction.address == 'h0000_0000;
    write_transaction.length == 2;
    write_transaction.first_dw_be == 4'b1111;
    write_transaction.last_dw_be == 4'b1111;
    write_transaction.traffic_class == 0;
    write_transaction.address_translation == 2'b00;
    foreach(write_transaction.payload[i])
        write_transaction.payload[i] == 'hbaadbaad;
};

// Start the UVM sequence
p_rand_seq.start(env.root.driver_transaction_seqr[0]);
end

wait_until_driver_idle_service_seq = new();
// Check for the driver is idle before ending test.
wait_until_driver_idle_service_seq.start(env.root.driver_seqr[0]); // End of Test

// Drop UVM objection
phase.drop_objection(this);
`uvm_info("run_phase", "Exiting...", UVM_LOW)
endtask

endclass //pseudo_random_serdes_test
```

[Example 17-12](#) illustrates the injection of a LCRC corruption error via the component factory. In the example, the weight distribution in the exception list object is set to randomly introduce the LCRC corruption on 20% of the transactions. Note how the specification of the error is very abstract compared to the specification used in the previous section. Also, the weights can be modified to specify a mix of different kinds of error, for example, 80 percent no error, 5 percent corrupt LCRC error, 5 percent duplicate sequence number error, 5 percent corrupt length error and 5 percent corrupt transaction type error.

The exception list also provides parameters to control the number of exceptions being injected. For instance, `svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions` can be used to specify the maximum possible exceptions. This parameter is a non-random type integer variable which constrains the random type integer variable `svt_PCIE_driver_app_transaction_exception_list::num_exceptions`. When exceptions are introduced using the factory, the driver randomizes the factory exception list object and attaches it to every transaction being transmitted by the driver. The randomization can yield a value anywhere between 0 and `svt_PCIE_driver_app_transaction_exception_list::max_num_exceptions` in `svt_PCIE_driver_app_transaction_exception_list::num_exceptions`. Once the number of exceptions is resolved by the driver, it then decides the kinds of errors as described above.

The exception list also provides additional parameters that weigh the resolution of `svt_PCIE_driver_app_transaction_exception_list::num_exceptions`. [Table 17-4](#) provides the details of these parameters.

**Table 17-4 Weight Distribution Parameters**

| Variable name                         | Description                                                                                                                                     |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>EXCPETION_LIST_SINGLE_wt</code> | Sets the weight distribution for the generation of <code>svt_PCIE_driver_app_transaction_exception_list::num_exceptions</code> to a value of 1. |

**Table 17-4 Weight Distribution Parameters**

| Variable name           | Description                                                                                                                                                                                         |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXCEPTION_LIST_EMPTY_wt | Sets the weight distribution for the generation of <code>svt_pcie_driver_app_transaction_exception_list::num_exceptions</code> to a value of 0.                                                     |
| EXCEPTION_LIST_SHORT_wt | Sets the weight distribution for the generation of <code>num_exceptions</code> to a value less than or equal to <code>svt_pcie_driver_app_transaction_exception_list::max_num_exceptions/2</code> . |
| EXCEPTION_LIST_LONG_wt  | Sets the weight distribution for the generation of <code>num_exceptions</code> to a value greater than <code>svt_pcie_driver_app_transaction_exception_list::max_num_exceptions/2</code> .          |

## 17.4 Status

The driver application provides a set of state values representing its status at any given time in the test simulation. These state values are encapsulated within `svt_pcie_driver_app_status` class. The driver application class has an object of type `svt_pcie_driver_application_status` instanced as `status`.

For more details, such as members, class inheritance UML, list of tasks, list of constraints and so on, see the HTML class description of `svt_pcie_driver_app_status` at:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/status/class_svt_pcie_driver_app_status.html`

There are two ways in which a test can access the `status` object of the driver application.

1. Directly accessing object `svt_pcie_driver_app::status` as illustrated in [Example 17-13](#).
2. Using `svt_pcie_device_agent::get_device_status()` function to retrieve the status of the agent and refer to `svt_pcie_device_status::driver_status[0]` object as shown in [Example 17-14](#).



The `get_device_status` function takes an input which is passed by reference.

### Example 17-13

```
class pcie_traffic_test extends uvm_test;
  `uvm_component_utils(pcie_traffic_test)
  ...
  task run_phase (uvm_phase phase);
    svt_pcie_driver_app_service_wait_until_idle_sequence drv_is_idle_serv_seq;
    super.run_phase(phase);
  ...
  // Assumptions:
  // The UVM test has an instance of UVM environment named 'env'
  // The UVM environment has an instance of the PCIe device agent named 'root'
  // VIP's DL is enabled.
```

```
// LTSSM gets operational at 2.5G and the model issued a number of requests.  
// A number of requests were queued on the driver app.  
// About to end the test. Make sure the driver app is idle.  
drv_is_idle_serv_seq = new();  
drv_app_serv_seq.start(env.root.virt_seqr.driver_seqr[0]);  
  
// Print the number of transaction sent, completed and completions received by the driver  
'uvm_info("run_phase", $sformatf("Num trans sent = %0d",  
env.root.driver[0].status.num_transaction_sent))  
'uvm_info("run_phase", $sformatf("Num trans completed = %0d",  
env.root.driver[0].status.num_transaction_completed))  
'uvm_info("run_phase", $sformatf("Num completions received = %0d",  
env.root.driver[0].status.num_completion_tlbs_received))  
endtask  
endclass
```

#### Example 17-14

```
class pcie_traffic_test extends uvm_test;  
  `uvm_component_utils(pcie_traffic_test)  
  ...  
  task run_phase (uvm_phase phase);  
    svt_PCIE_driver_app_service_wait_until_idle_sequence drv_is_idle_serv_seq;  
  
    super.run_phase(phase);  
    ...  
  // Assumptions:  
  // The UVM test has an instance of UVM environment named 'env'  
  // The UVM environment has an instance of the PCIe device agent named 'root'  
  // VIP's DL is enabled.  
  // LTSSM gets operational at 2.5G and the model issued a number of requests.  
  // A number of requests were queued on the driver app.  
  
  // About to end the test. Make sure the driver app is idle.  
  drv_is_idle_serv_seq = new();  
  drv_app_serv_seq.start(env.root.virt_seqr.driver_seqr[0]);  
  
  env.root.get_device_status(root_dev_status);  
  
  // Print the number of transaction sent, completed and completions received by the driver  
'uvm_info("run_phase", $sformatf("Num trans sent =  
%0d",root_device_status.driver_status[0].num_transaction_sent))  
'uvm_info("run_phase", $sformatf("Num trans completed = %0d",  
root_device_status.driver_status[0].num_transaction_completed))  
'uvm_info("run_phase", $sformatf("Num completions received = %0d",  
root_device_status.driver_status[0].num_completion_tlbs_received))  
endtask  
endclass
```



# 18 Functional Coverage

This chapter discusses the following topics:

- ❖ [Introduction](#)
- ❖ [Usage Notes](#)

 **Attention** The legacy coverage model has been moved to Appendix [Functional Coverage](#). For more details on the mapped covergroups, see [Mapping Legacy Covergroups to Corresponding New Covergroups](#).

## 18.1 Introduction

This Section provides the overview of PCIe functional coverage features, usage mechanism, coverage generation and coverage back annotation process.

### 18.1.1 Key Features

[Table 18-1](#) lists the Gen4 protocol coverage features in each layer of the coverage model.

**Table 18-1 Protocol Coverage Features - Gen4**

| Coverage | Description                                                                                                                                                                                                             |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TL       | Covers the fields in prefixes and headers in the transmitted and received TLPS.                                                                                                                                         |
| DL       | Covers different transmitted and received DLLPs. For example, ACK, NAK, NOP, VENDOR DLLP and Flow control DLLPs.                                                                                                        |
| PL       | Covers the features in the PL layer such as Ordered sets (for example, SKP, Control SKP, TS OS, EIOS, FTS), link width, speed negotiations, 8b/10b K codes, and lane skew ranges.                                       |
| LTSSM    | Covers the LTSSM state transitions along with the transition reasons, path coverage such as link width negotiations, initial bring up and partial Equalization scenarios and transitional coverage of low power states. |
| PIPE     | Covers signals on PIPE interface.                                                                                                                                                                                       |

[Table 18-2](#) lists the Gen5 protocol coverage features in each layer of the coverage model.

**Table 18-2 Protocol Coverage Features - Gen5**

| Coverage | Description                                                                                                                                                                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PL       | Covers new ordered sets (MODIFIED_TS_OS), ordered set updates (TS1, TS2, SKP, EIEOS), Precoding for Error protection, Redo Equalization scenarios, extended lane skew ranges, Link speed negotiations to Gen5, equalization coefficients, presets at Gen5 and cross combinational coverage with Gen5 speed. |
| LTSSM    | Covers new Loop back equalization architecture for multi-lane Bert testing support, initial link bring up scenarios at Gen5, L0s Tx and Rx transitions at Gen5, L1 substates at Gen5.                                                                                                                       |
| PIPE     | Covers the Equalization signals at Gen5 (for example, preset_index, tx_deemphasis, Figure of merit, Feedback_direction_change, rx_eval_equalization, Local LF, Local FS, LF, FS), Rx_Status, Rx_Polarity, and Tx_Block_Align, PowerDown signals at Gen5.                                                    |

### 18.1.2 Coverage Model Interpretation

The coverage is collected by VIP instances based on DUT type as shown in [Figure 18-1](#).

For example, if the DUT is Root Complex, then in the coverage report under the `ltssm*_ep_cg`, LTSSM state Recovery Equalization phase 0 is registered as hit after EP VIP enters this state, even though Recovery Equalization phase 0 is not a legal state for Root Complex DUT LTSSM.

It can be inferred that, if all the VIP LTSSM states are covered, then DUT LTSSM must have gone through its respective states.

**Figure 18-1 Function Coverage Block Diagram**



### 18.1.3 Covergroup Naming Conventions

Following are the naming conventions followed for covergroups:

- ❖ Covergroup names beginning with a common prefix. For example, for all the LTSSM covergroups, `ltssm_` is the prefix.
- ❖ Covergroups with `_ep_` and `_rc_` in the name are generated by EP VIP and RC VIP respectively.

- ❖ A Covergroup without `_rc_` or `_ep_` in the name are applicable for both RC and EP VIPs.
- ❖ Covergroup names with `_tx_` and `_rx_` denote the direction. The direction is with respect to VIP—that is, `_rx_` is the coverage based on observations at the RX path of the VIP. For example, `pl_rx_skp_os_lane0_cg` covergroup covers SKP ordered set received on lane 0 by the VIP.
- ❖ TL and DL covergroup names with `_downstream_` and `_upstream_` denote the coverage of downstream and the upstream TLP or DLLPs respectively.

For more details on covergroups and coverpoints, see "Coverage" tab in the HTML class reference documentation:

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/index.html`

#### 18.1.4 DUT Type and Coverage Applicability

Covergroups applicability based on DUT type is as follows:

- ❖ TL and DL covergroup names with `*_downstream_*cg` denotes the downstream travelling DLLPs or TLPs which are transmitted by Root Complex and received at Endpoint VIP.
  - ◆ For EP DUT in coverage report, they are identified by `<Root VIP instance>.*_tx_* *_downstream_*cg()`.
  - ◆ For RC DUT in coverage report, they are identified by `<Endpoint VIP instance>.*_rx_* *_downstream_*cg()`.
  - ◆ PHY DUT is an interoperability testing between two VIPs based on the interest these covergroups are applicable for assessing whether the PHY is transferring TLPs or DLLPs successfully under Normal state of operation.
- ❖ TL and DL covergroup names with `*_upstream_*cg` denotes the upstream travelling DLLPs or TLPs which are transmitted by Endpoint and received at Root complex VIP.
  - ◆ For EP DUT in coverage report, they are identified by `<Root VIP instance>.*_rx_* *_upstream_*cg()`.
  - ◆ For RC DUT in coverage report, they are identified by `<Endpoint VIP instance>.*_tx_* *_upstream_*cg()`.
  - ◆ PHY DUT is an interoperability testing between two VIPs based on the interest these covergroups are applicable for assessing whether the PHY is transferring TLPs or DLLPs successfully under Normal state of operation.
- ❖ The covergroup names with a suffix of `*_rc_cg` are applicable for EP and PHY DUTs as they are created based on RC VIP.
- ❖ The covergroup names with a suffix of `*_ep_cg` are applicable for RC and PHY DUTs as they are created based on EP VIP.

#### 18.1.5 Coverage Hierarchical Verification Plans

The PCIe VIP provides Verdi compatible top-level HVP for Root Complex, Endpoint and PHY DUT. You can create your own HVP and use the PCIe VIP HVP as subplans.

Top-level HVPs are available at the following locations:

- ❖ RC DUT

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/dut_rc/pcie_dut_rc_fc_toplevel_plan.hvp`

- ❖ EP DUT

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/dut_ep/pcie_dut_ep_fc_toplevel_plan.hvp`

- ❖ PHY DUT

`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/dut_phy/pcie_dut_phy_fc_toplevel_plan.hvp`

The top-level HVP instantiates respective protocol layer coverage subplans based on the DUT.

For example, RC DUT top-level plans includes the subplans with the following names.

- ❖ `pcie_dut_rc_pci_express_base_spec_r3_1_data_link_layer_fc_subplan.hvp`
- ❖ `pcie_dut_rc_pci_express_base_spec_r3_1_physical_layer_fc_subplan.hvp`
- ❖ `pcie_dut_rc_pci_express_base_spec_r3_1_power_management_fc_subplan.hvp`
- ❖ `pcie_dut_rc_pci_express_base_spec_r3_1_system_architecture_fc_subplan.hvp`
- ❖ `pcie_dut_rc_pci_express_base_spec_r3_1_transaction_layer_fc_subplan.hvp`
- ❖ `pcie_dut_rc_pipe_ver_4_4_subplan.hvp`

The Filters (for example, `lane_number_filter.hvpm`, excludes unsupported lanes based on lane count supported by the DUT) and HVP source code of each subplan is available at the following location:  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/`

- ❖ For Gen4 Coverage with RC DUT / EP DUT, following filters must be loaded along with the HVP plan.
  - ◆ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/lane_number_filter.hvpm`
  - ◆ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/pipe_filter.hvpm`
  - ◆ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/gen4_coverage_filter.hvpm`
- ❖ For Gen4 Coverage with PHY DUT, following filters must be loaded based on MAC along with the HVP plan.
  - ◆ RC MAC
    - ✧ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/rc_mac_pipe_filter.hvpm`
    - ✧ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/lane_number_filter.hvpm`
  - ◆ EP MAC
    - ✧ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/ep_mac_pipe_filter.hvpm`
    - ✧ `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/lane_number_filter.hvpm`
- ❖ For Gen5 Coverage with EP DUT following filters to be loaded along with the HVP plan.  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/EP_DUT_Gen5_Cov_filter.hvpm`

- ❖ For Gen5 Coverage with RC DUT following filters to be loaded along with the HVP plan.  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/RC_DUT_Gen5_Cov_filter.hvpmod`
- ❖ For Gen5 Coverage with PHY\_DUT following filters should be loaded based on MAC along with the HVP plan.
  - ◆ RC MAC
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/rc_mac_pipe_filter.hvpmod`
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/lane_number_filter.hvpmod`
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/gen5_coverage_filter.hvpmod`
  - ◆ EP MAC
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/ep_mac_pipe_filter.hvpmod`
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/lane_number_filter.hvpmod`
    - `$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/VerificationPlans/functional_coverage_plans/common/gen5_coverage_filter.hvpmod`

**Example 18-1 Sample Top Plan****Example 18-2 Sample Subplan of Data Link Layer**



The HVP plans provided with the PCIe VIP should be used as-is, because the HVP plan will be periodically updated based on the coverage enhancement.

## 18.2 Usage Notes

### 18.2.1 Enabling Function Coverage

To enable the new function coverage, define the macro `SVT_PCIE_ENABLE_COMMON_COV` at compile time and set the `enable_cov` variable in `svt_PCIE_configuration` class to a desired value.

The configuration variable `enable_cov` is a 6-bit vector, where each bit corresponds to enabling coverage for subsections listed in the table.

**Table 18-3 Coverage Controls**

| Bit Position               | Coverage Control                                                                               |
|----------------------------|------------------------------------------------------------------------------------------------|
| <code>enable_cov[0]</code> | When set to 1'b1, enables PIPE functional coverage.                                            |
| <code>enable_cov[1]</code> | When set to 1'b1, enables functional coverage in PL Layer                                      |
| <code>enable_cov[2]</code> | When set to 1'b1, enables functional coverage in DL Layer.                                     |
| <code>enable_cov[3]</code> | When set to 1'b1, enables functional coverage in TL Layer.                                     |
| <code>enable_cov[4]</code> | When set to 1'b1, enables LTSSM functional coverage.                                           |
| <code>enable_cov[5]</code> | When set to 1'b1, enables 8b/10b symbol functional coverage (only valid for SERDES interface). |



- Do not define the macros `SVT_PCIE_INCLUDE_AC_COVERAGE` and `SVT_PCIE_ENABLE_COMMON_COV` macros at the same time. Defining both the macros together at compile time will generate undesirable coverage results.
- The legacy coverage model and `SVT_PCIE_INCLUDE_AC_COVERAGE` macro will be deprecated from 0-2018.12 release.

The Covergroup creation depends on following configuration in addition to `enable_cov`, changing these configurations after initial `build_phase()` causes incorrect coverage.

- ❖ `supported_speed` field in `svt_PCIE_pl_configuration`
- ❖ `link_width` field in `svt_PCIE_pl_configuration`
- ❖ `pipe_spec_ver` field in `svt_PCIE_pl_configuration`
- ❖ `enable_pclk_as_phy_input` field in `svt_PCIE_pl_configuration`
- ❖ `enable_l1ss_pipe_handshake` field in `svt_PCIE_pl_configuration`

Based on DUT type and interface, the function coverage control will change for RC and EP DUT.

| RC DUT or EP DUT                                  |        |
|---------------------------------------------------|--------|
| PIPE                                              | SERDES |
| PIPE Coverage Enable - <code>enable_cov[0]</code> | Y NA   |

|                                               | RC DUT or EP DUT |   |
|-----------------------------------------------|------------------|---|
| PL Coverage Enable - enable_cov[1]            | Y                | Y |
| DL Coverage Enable - enable_cov[2]            | Y                | Y |
| TL Coverage Enable - enable_cov[3]            | Y                | Y |
| LTSSM Coverage Enable - enable_cov[4]         | Y                | Y |
| 8b/10b K-code & data Coverage - enable_cov[6] | NA               | Y |

A typical PHY DUT environment will consist of two PCIe VIPs, one on either side of PHY DUT. One VIP will have PIPE Interface connecting to PHY DUT and the other VIP will be connected with Serial interface. Below is the quick reference for function coverage controls for PHY DUT environment.

|                                               | PHY DUT                 |                           |
|-----------------------------------------------|-------------------------|---------------------------|
|                                               | VIP with PIPE Interface | VIP with SERDES Interface |
| PIPE Coverage Enable - enable_cov[0]          | Y                       | NA                        |
| PL Coverage Enable - enable_cov[1]            | Y                       | Y                         |
| DL Coverage Enable - enable_cov[2]            | Y                       | Y                         |
| TL Coverage Enable - enable_cov[3]            | Y                       | Y                         |
| LTSSM Coverage Enable - enable_cov[4]         | Y                       | Y                         |
| 8b/10b K-code & data Coverage - enable_cov[6] | NA                      | Y                         |

### 18.2.2 HVP Coverage Back Annotation with PCIe VIP RC DUT

Back annotating coverage with PCIe VIP HVP for RC DUT.

1. Create a top-level HVP.

A key variable for back annotating the HVP is the path to coverage groups in VDB. The coverage path can be divided into two sections:

- ◆ User environment path - Path to VIP agent in the user environment.
- ◆ Fixed path - Path for covergroup/coverpoint/bin from VIP agent.

To use the HVP, you must update your path to coverage. For RC DUT HVP, the user environment path can be defined by the `SVT_PCIE_HVP_RC_DUT_VIP_AGENT_PATH` attribute. To set the path for VIP agent, create a top-level HVP plan and instantiate `pcie_dut_rc_fc_toplevel_plan.hvp` as a subplan, and pass the correct path to the HVP attribute.

```

`include
"<DESIGNWARE_HOME_PATH>/vip/svt/pcie_svt/latest/doc/VerificationPlans/function
al_coverage_plans/dut_rc/pcie_dut_rc_fc_toplevel_plan.hvp"

plan Customer_Plan;

    subplan pcie_dut_rc_fc_toplevel_plan #(SVT_PCIE_HVP_RC_DUT_VIP_AGENT_PATH =
"<VIP_AGENT_PATH>") ;

```

```
endplan
```

## 2. Back annotating HVP

HVP can be back annotated in Verdi for analysis in GUI or can be back annotated to HTML.

### a. Command to back annotate to HTML

```
urg -lca -full64 -dir <Coverage_Database>.vdb -plan Customer_Plan.hvp [-mod  
lane_number_filter.hvpmod] -report rc_dut_back_annotated
```

#### Switch Description

|        |                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| plan   | Top-level user plan                                                                                                                                                                                                                                                                                                                                                                        |
| dir    | Coverage database                                                                                                                                                                                                                                                                                                                                                                          |
| report | Back annotate HTML files directory,<br><i>rc_dut_back_annotated/dashboard.html</i> will be top-level HTML page.                                                                                                                                                                                                                                                                            |
| mod    | Plan modified [Optional]. To load plan modified<br>For example, PL coverage for Ordered Set is per lane coverage and HVP<br>plan lists all possible 32 lanes. But if the DUT only supports a maximum of<br>8 lanes, then with plan modified you can remove lanes from 8–31 from the<br>HVP.<br>filter lane_number_filter;<br>remove feature where SVT_PCIE_HVP_LANE_NUM > 7;<br>endifilter |

### b. Back annotating with Verdi

- To invoke Verdi coverage, you need to add the **-cov** option to the Verdi command line. You can also specify the directory name in the command line while invoking Verdi coverage as shown below:

```
> verdi -cov &  
> verdi -cov -covdir <filename>.vdb &
```

In the Verdi GUI, select **File > Open/Add Database** to load the database.



ii. Select **Plan > Open Plan** to load the HVP plan.



iii. Select **Load modifiers > load the Filter** based on the DUT type.



iv. Opening the plan will automatically back annotate the coverage as per the HVP.





# 19 Using Callbacks

## 19.1 Introduction

Callbacks provide a means to examine or modify transactions at various points in the protocol stack. This chapter describes their basic usage, provides some examples, and gives tips for debugging them.

Within a transaction, you can use the transaction handle to:

- ❖ Understand where in the protocol layers a particular transaction is being processed.
- ❖ Examine a particular field that was added to a transaction (for example, the Link Layer Sequence Number).
- ❖ Collect statistics and functional coverage or provide transactions to a scoreboard.
- ❖ Modify a transmitted TLP to cause a particular error to occur in the DUT and then examine the received TLP to verify that the error actually occurred as planned.
- ❖ Modify a received transaction to cause the VIP to respond abnormally to that transaction (for example, by injecting an illegal CRC value.)

## 19.2 How Callbacks Are Used

Callbacks occur at specific places within the VIP, where callback “hooks” have been provided by the VIP. Follow these steps to implement and use a callback:

1. Identify which callback you need to use.
2. Sub-class the appropriate data type and implement the appropriate callback method with a user-defined action each time the callback is made.
3. Create an object of this type and add it to the queue of callback objects on the appropriate VIP instance.

You can request a callback by specifying:

1. What VIP layer you are interested in (for example, the Data Link Layer)
2. Which direction (transmit or receive) and location within that layer you want to get the callback from. (Typically, there is more than one callback point you can specify).
3. The particular object you want registered to receive callbacks.

4. Code within a method of the above object to examine and modify the transaction.

While a test is running, whenever the callback you have implemented occurs (that is, when the transaction reaches the point in the protocol flow that causes the callback to occur), your registered callback method will be called. Once your method has finished its processing, it returns from the callback and the protocol processing continues. [Figure 19-1](#) is a diagram of the callback process for a callback that you request in the Data Link Layer.

**Figure 19-1** Callback operation for a callback in the Data Link Layer



### 19.2.1 Other Uses for Callbacks

Although callbacks are typically used to examine and modify the transactions as they move through the protocol stack, there are additional uses for callbacks:

- ❖ Examining if a previous callback or error injection has occurred on the transaction
- ❖ Causing an exception to occur on the associated transaction

### 19.2.2 Callback Hints

Callbacks are a tool that should be used conservatively:

- ❖ Limit callback modifications to one per callback.
- ❖ If multiple modifications are truly needed, use multiple callbacks.
- ❖ If multiple callbacks are used, it is important to understand the order in which the callbacks will be called.

### 19.2.3 When Not to Use a Callback

Although callbacks are a flexible mechanism, UVM analysis ports are preferred for statistics, coverage, scoreboarding, and so on. However UVM ports do not allow modification of the transaction within the caller, so use callbacks if you want to modify the transaction within the caller.

The VIP has many mechanisms for examining transactions, altering frame data, timing, and so on that might be easier to use. Here are some examples:

- ❖ When an exception already exists for the modification you have in mind, use the exception. It will not only inject the error, it will also verify that the response is correct for that error, and automatically recover. If a control already exists in the configuration or via a service request, use that control instead of a callback.
- ❖ Statistics - There already are statistics available that count many protocol items. There is no need to rewrite these.
- ❖ Delays of packets - Callbacks must be called in “zero time”. They are coded as functions to enforce this.
- ❖ Scoreboards - Do not use a callback to send data to your scoreboard if there is an available analysis port at the same location.

## 19.3 Detailed Usage

This section describes how callbacks are used in several example testcases. The first example is a working testcase, although it is missing many features that you would normally use. The second example expands on those additional useful mechanisms.

### 19.3.1 A Basic Testcase

These are the main mechanisms, classes and methods used in the basic testcase example:

- ❖ Test Case Class - Each method is a different UVM phase:
  - ◆ new() constructor
  - ◆ build\_phase() - Set up a test-specific configuration.
  - ◆ end\_of\_elaboration\_phase() - Create and register the callback object
  - ◆ run\_phase() - A placeholder. Nothing to do here.
- ❖ Callback Class - Each method is a specific callback from the given layer:
  - ◆ new() constructor
  - ◆ pre\_tlp\_framed\_out\_put() - Callback called just prior to framing the TLP.

#### Example 19-1 Code for a basic testcase

```
typedef class tx_dl_tlp_callback; // Forward declaration

// The testcase class:
class dl_tlp_basic_callback_test extends basic ;
  // Factory registration
  `uvm_component_utils( dl_tlp_basic_callback_test )

  // Callback instance:
  tx_dl_tlp_callback dl_tlp_cb;

  // Constructor:
  function new(string name="dl_tlp_basic_callback_test", uvm_component parent=null);
    super.new(name, parent);
  endfunction : new
```

```
// Configure/build various components:  
virtual function void build_phase(uvm_phase phase);  
    super.build_phase(phase);  
  
    // Set test-specific cfg values:  
    cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_width_values(4);  
    cust_cfg.endpoint_cfg.pcie_cfg.pl_cfg.set_link_width_values(4);  
  
    //Register the cfg with the registry so that it will be picked up by the env.  
    svt_config_object_db#(pcie_device_system_configuration)::set(this, , {"env",  
        ".", "cfg"}, cust_cfg);  
endfunction : build_phase  
  
function void end_of_elaboration_phase(uvm_phase phase);  
    super.end_of_elaboration_phase(phase);  
  
    // Create a callback object instance:  
    dl_tlp_cb = tx_dl_tlp_callback::type_id::create("dl_tlp_cb");  
  
    // Register the callback object with the DL component:  
    uvm_callbacks#(svt_pcie_dl, svt_pcie_dl_callback)::add(env.endpoint.port.dl,  
        dl_tlp_cb) ;  
endfunction : end_of_elaboration_phase  
  
task run_phase( uvm_phase phase );  
    // In this case, there is not much to do in this phase  
    `uvm_info(get_full_name(), "Running test dl_tlp_basic_callback_test .\n",  
        UVM_LOW);  
endtask : run_phase  
  
endclass : dl_tlp_basic_callback_test  
  
// This is the callback class that is instantiated in the test class above:  
class tx_dl_tlp_callback extends svt_pcie_dl_callback;  
  
    // Factory registration:  
    `uvm_object_utils(tx_dl_tlp_callback)  
  
    // Error counter - static to allow it to act globally across all callback instances:  
    static int error_count = 0;  
  
    function new(string name = "tx_dl_tlp_callback");  
        super.new(name);  
endfunction : new  
  
    // pre_tlp_framed_out_put: this is the actual callback function. It will be  
    // called every time a DL/TLP is ready to be framed for transmission:  
virtual function void pre_tlp_framed_out_put( svt_pcie_dl dl,  
        svt_pcie_dl_tlp transaction, ref bit drop);  
  
        `uvm_info(get_full_name(), $sformatf("\nA callback prior to transmitting TLP.  
            Current TC=%0d and ECRC=0x%x, error count=%0d.\n",  
            transaction.tlp.traffic_class, transaction.tlp.ecrc, error_count), UVM_LOW);
```

```
if(error_count < 1) begin // Just corrupt one TLP
    // Force a new traffic class field. Note that the traffic class (since it's in
    // the TLP header) is not directly a member of the transaction, but of the
    // tlp object encapsulated by the DL/TLP object. The only directly
    // modifiable member of the svt_PCIE_DL_TLP_TRANSACTION class is the sequence
    // number.
    transaction.tlp.traffic_class = 3;
    error_count++;
end
endfunction : pre_tlp_framed_out_put
endclass : tx_dl_tlp_callback
```

## 19.4 Advanced Topics in Callbacks

As mentioned above, there are other features you can incorporate (or, depending on what you need to do – must incorporate) in the testcase. This section discusses the concept of *exceptions*, a mechanism to request changes to a transaction that works a bit differently than directly modifying the fields of the transaction. (For example that is how the traffic class is modified in [Example 19-1](#)).

### 19.4.1 Exceptions – a “Delayed” Transaction Modification Request

When you make direct changes to fields in the transaction, they take effect immediately. In many cases, this works fine, but there are situations where you want to hold off on updating the transaction until all the changes are in place. A typical example of this is CRC fields. It makes little sense to calculate a CRC field if another transaction field on which the CRC depends will be changing.

There is a mechanism that allows you to schedule that CRC change (for example) when all of the transactions changes have been incorporated. This delayed transaction update is handled with an object called an *exception*.

An exception is created to request a particular change to the transaction. Once an exception is created, it is then associated with the transaction by placing it on that transaction’s *exception list*. Just prior to the callback transaction being placed back into the data flow, the exception is examined and the transaction is updated based on the contents of that exception.

### 19.4.2 Creating an Exception

As with any object, a handle first must be declared for the exception. Its type will be based on the type of transaction with which it is associated. In the HTML class reference, follow the svt\_PCIE\_DL class to the class attributes and find the exception class svt\_PCIE\_DL\_TLP\_TRANSACTION\_EXCEPTION.

To create an exception, first create a handle of this type and an object associated with it:

Perhaps show the complete callback class?

```
// Exception handle and object
svt_PCIE_DL_TLP_EXCEPTION dl_tlp_exc = new("my_dl_tlp_exc");
```

Next, create the handle and object for the exception list:

```
// Exception list handle and object
DL_TLP_EXCEPTION_LIST_VIA_CALLBACK my_dl_tlp_exc_list = new("my_dl_tlp_exc_list");
```

Now set the appropriate fields in the exception to make the request (in this case, a DL/TLP LCRC error):

```
my_dl_tlp_exc.error_kind = svt_PCIE_DL_TLP_EXCEPTION::CORRUPT_LCRC;  
  
// The CORRUPT_LCRC causes the 'corrupted_data' value to be XOR'd with the  
// (correctly) calculated LCRC field.  
my_dl_tlp_exc.corrupted_data = 32'h0000_0001; // This will invert bit 0 of LCRC.
```

Put the exception into the exception list:

```
my_dl_tlp_exc_list.add_exception(my_dl_tlp_exc);
```

Finally, cast the exception list into the transaction:

```
$cast(transaction.tx_exception_list, my_dl_tlp_exc_list.`SVT_DATA_COPY());
```

Now every time the transaction is handled, if there is an exception in the transaction's exception list, it will be evaluated just prior to the transaction being put back into the data flow.

### 19.4.3 Creating a Factory Exception

In addition to the above callback exceptions, there is another type of exception: Instead of it being associated with user-specified callback code, it occurs automatically each time the callback function is called (even if there is no user-specified callback code). This allows you to generate randomized error injections.

Note that factory exceptions and callbacks are mutually exclusive: If a user modifies the transaction in the callback, the factory exception will not occur.

The code to set up a factory exception is similar to the code in “[Creating an Exception](#)” above, with a few minor differences.

First, define a derived exception list class:

```
class dl_tlp_exception_list_via_factory extends  
    svt_PCIE_DL_TLP_TRANSACTION_EXCEPTION_LIST;  
    svt_PCIE_DL_TLP_EXCEPTION xact_exc = new("xact_exc");  
    function new(string name = "dl_tlp_exception_list_via_factory",  
        svt_PCIE_DL_TLP_EXCEPTION xact_exc = null);  
        super.new(name,xact_exc);  
        xact_exc = this.xact_exc;  
        xact_exc.NO_ERROR_wt = 0;  
        xact_exc.AUTO_CORRUPT_LCRC_wt = 0;  
        xact_exc.ILLEGAL_SEQ_NUM_wt = 0;  
        xact_exc.DUPLICATE_SEQ_NUM_wt = 0;  
        xact_exc.NULLIFIED_TLP_wt = 0;  
        xact_exc.NULLIFIED_TLP_GOOD_LCRC_wt = 0;  
        xact_exc.NULLIFIED_TLP_AUTO_CORRUPT_LCRC_wt = 0;  
        xact_exc.MISSING_START_wt = 0;  
        xact_exc.MISSING_END_wt = 0;  
        xact_exc.CORRUPT_DISPARITY_wt = 0;  
        xact_exc.CODE_VIOLATION_wt = 0;  
        xact_exc.CORRUPT_8G_HEADER_CRC_wt = 0;  
        xact_exc.CORRUPT_8G_HEADER_PARITY_wt = 0;  
        xact_exc.RETAIN_LCRC_wt = 0;  
        xact_exc.RECALC_LCRC_wt = 0;
```

```
xact_exc.FORCE_LCRC_wt = 0;
xact_exc.CORRUPT_LCRC_wt = 1; // This will cause a corrupt LCRC
xact_exc.corrupted_data=32'hffff_ffff; // This value will be XOR'd with the LCRC
this.randomized_exception = xact_exc;
endfunction : new
endclass
```

Now, in the testcase, create an exception in the list handle:

```
rand dl_tlp_exception_list_via_factory dl_tlp_exc_list;
```

In the build\_phase of the testcase, create and randomize the exception list object, then set it to the per-layer component configuration database:

```
dl_tlp_exc_list = new("dl_tlp_exc_list");
dl_tlp_exc_list.randomize();
uvm_config_db#(svt_pcie_dl_tlp_exception_list)::set(this,
    "env.endpoint.port0.dl0",
    "tlp_xact_exception_list",
    dl_tlp_exc_list);
```

Whenever the transaction callback is called, (assuming there is no user callback), the transaction will be modified based on the exception above. If there is a user callback, it will be called *after* the exception code has modified the transaction and you then have the option to further modify the transaction.

## 19.4.4 Error Injection Using Application Layer TX Callbacks

This section shows you how to use Application Layer TX callbacks for error injection.

### 19.4.4.1 Basic Target Application Completion Callbacks

Whenever a target has built a completion TLP for transmission (to the TL layer, and ultimately to the remote device) the model calls a completion callback (class: `svt_pcie_target_app_callback`, method: `pre_tx_tlp_put()`). The testbench can use this callback by creating an object of a derived class and using `uvm_callbacks()` and `add()` to include that callback object in the list of callback objects. This, of course, is standard UVM. Some minor additions are available.

### 19.4.4.2 Methods to Modify the Transaction

There are three ways to modify the transaction:

- ❖ Simple Modifications.
- ❖ Exceptions
- ❖ Error Injection Exceptions

#### 19.4.4.2.1 Simple Modifications

When a callback is called, it is passed a TLP object (of type `svt_pcie_tlp`) transaction that contains various fields that can be modified in several ways; the transaction can be modified directly, for example:

```
virtual function void pre_tx_tlp_put(svt_pcie_target_app target_app,
                                      svt_pcie_tlp transaction,
                                      ref bit drop);
    transaction.ep = 1; // Set the Poison Bit in the TLP
endfunction // pre_tx_tlp_put()
```

In the example, you simply set the value of the TLP poison bit (ep) to 1. The callback will hand the TLP back to the protocol stack , and that TLP's Poison bit will be set.

Note that there is not an explicit Error Injection code being added. However , an implicit virtual EI code *is* added: *USER\_MODIFIED\_TLP*. This code does two main things:

1. Marks the TLP as having been modified, so later callbacks can know.
2. Keeps any later “automatic” error injections from occurring.

Note that although you should not need to add *USER\_MODIFIED\_TLP* manually, it will be placed on the TLP automatically when the TLP has been modified in a callback. (As you will see below, there is an analogous EI code *MALFORMED\_TLP* that will be added to a TLP that is explicitly Malformed.)

#### 19.4.4.2.2 Exceptions

Another way the transaction can be modified is via an *exception* – essentially a delayed update to that transaction, for example:

```
virtual function void pre_tx_tlp_put(svt_pcie_target_app target_app,
                                      svt_pcie_tlp transaction,
                                      ref bit drop);
    svt_pcie_tlp_exception_list my_tlp_exc_list;      // Exception list
    svt_pcie_tlp_transaction_exception my_tlp_exc;   // Exception obj
    my_tlp_exc_list = new("my_tlp_exc_list");
    my_tlp_exc = new("my_tlp_exc");
    my_tlp_exc.error_kind =      // Set the exc type
        svt_pcie_tlp_transaction_exception::CORRUPT_ECRC;
    my_tlp_exc.corrupted_data = 32'hffff_ffff; // XOR with ECRC
    my_tlp_exc_list.add_exception(my_tlp_exc); // Add exc to list
    $cast(transaction.exception_list,
          my_tlp_exc_list.`SVT_DATA_COPY() ); // Add exc list to TLP
endfunction // pre_tx_tlp_put()
```

In the previous example, the ECRC will be corrupted (see the documentation for details, but essentially the ECRC will be calculated, and the XOR'd with the provided *corrupted\_data* (i.e. 32'hffff\_ffff). However, this does not occur immediately. Since this is a calculation that is done on the entire TLP, you need to ensure that all the fields that you may intend to change have been changed prior to the ECRC calculation. Using an exception allows you to do this – an exception is applied to the TLP until that TLP is actually getting *pack'ed*, just prior to its being handed back to the protocol stack.

As previous stated, once the exception is applied and the TLP modified, it will be tagged with the *USER\_MODIFIED\_TLP* EI code.

#### Error Injection Exceptions

In addition to modifying the TLP contents directly, an exception can be used to propagate an *Error Injection* (EI) to the layers below it. For example, although the Application layer isn't able to modify the LCRC of a TLP to be transmitted, you can request via an EI that the LCRC be corrupted:

```
virtual function void pre_tx_tlp_put(svt_pcie_target_app target_app,
                                     svt_pcie_tlp transaction,
                                     ref bit drop);
    svt_pcie_tlp_exception_list my_tlp_exc_list; // Exception list
    svt_pcie_tlp_transaction_exception my_tlp_exc; // Exception obj
    my_tlp_exc_list = new("my_tlp_exc_list");
    my_tlp_exc = new("my_tlp_exc");
    my_tlp_exc.error_kind = // Set the exc type
        svt_pcie_tlp_transaction_exception::AUTO_TX_CORRUPT_LCRC;
    my_tlp_exc_list.add_exception(my_tlp_exc); // Add exc to list
    $cast(transaction.exception_list,
          my_tlp_exc_list.`SVT_DATA_COPY()); // Add exc list to TLP
endfunction // pre_tx_tlp_put()
```

The previous example provides the exception, which will be ‘translated’ to an Error Injection to be handed down the protocol stack. Once it goes into the DataLink Layer (where the LCRC is calculated), then the LCRC is corrupted (as instructed above).

In addition, since the prefix to the exception is *AUTO\_*, this implies that not only will the error injection occur, but that the VIP will automatically do the following:

- ❖ Determine if the LCRC actually was recognized correctly by the remote device.
- ❖ Recover from the error, and retransmit any required TLPS.
- ❖ Suppress any error messages associated with the above.

Note: once a TLP has an EI Exception attached to it, you should not attempt to modify in any other way. Error injections work due to a controlled injection of the error – if multiple errors are attempted simultaneously, the EI will generally fail in a typically difficult-to-debug way!

Unlike the previous examples note that since the user has *not* changed the TLP (adding the EI request doesn’t count as a change to the actual TLP header/data), only the actual EI is attached; the **USER\_MODIFIED\_TLP** is **not**.

#### 19.4.4.3 Malformed and Nullified TLPS

If you intend to create a TLP that is *Malformed* (see PCIe spec for details), it is up to the testbench to inform the VIP of that fact. This is done simply via the transactions *set\_malformed(value)* method. For example:

```
virtual function void pre_tx_tlp_put(svt_pcie_target_app target_app,
                                     svt_pcie_tlp transaction,
                                     ref bit drop);
    ... various manipulations on TLP ...// Corrupt the TLP
    // Set TLP to be treated as Malformed
    transaction.set_malformed(1);
endfunction // pre_tx_tlp_put()
```

Note that if an Error Injection is set on a TLP marked as Malformed, that Error Injection will be canceled (for reasons given above – the requirement of a controlled Error Injection has been broken.) Note also that in the TL layer, credits are not counted for a Malformed transaction – as it is assumed that (being Malformed) the receiver will neither recognize nor count credits for the associated transaction.

Recall previously that we added **USER\_MODIFIED\_TLP** as a virtual EI code to TLPS that a user has modified. In this (Malformed) case, the virtual EI code **MALFORMED\_TLP** will be added instead. It has the

same basic effect to remind lower layers that this TLP has been modified; in addition it also tells those same lower layers (including callbacks in those layers) that this has been modified so as to be Malformed.



If the transaction did not already have an error injected, then the TL would have consumed credits as appropriate. If the TLP is malformed or nullified via callback (using exceptions), then credit consumption by the VIP cannot be changed. Similarly, a TL layer exception cannot be canceled or changed via this callback.

#### 19.4.5 A More Comprehensive Example

In addition to the Test Case and Callback classes used in [Example 19-1](#), three other classes are added in [Example 19-2](#):

- ❖ Exception Classes – Each transaction type has its own exception class, which contains objects of its exception class:
  - ◆ new() constructor
  - ◆ Various per-transaction fields to set up the exception
- ❖ Exception List Classes – Each transaction has a class for its exception list
- ❖ Error Handler – Extended from uvm\_report\_catcher. It has several important methods:
  - ◆ new() constructor
  - ◆ pattern\_match() – Matches the actual error string with the “expected” string
  - ◆ catch() – Called upon an error message being potentially displayed. You can filter with this.

#### Example 19-2 Code for a more comprehensive testcase

```
// Forward declarations
typedef class tlp_exc_list_via_callback;
typedef class dl_tlp_exception_list_via_callback;
typedef class dl_tlp_err_catcher;
typedef class tx_dl_tlp_callback;

// The testcase class:
class dl_tlp_example_callback extends basic ;
  // Factory registration:
  `uvm_component_utils( dl_tlp_example_callback )
  // Callback instance:
  tx_dl_tlp_callback dl_tlp_cb;
  // Exception list class instance:
  dl_tlp_exception_list_via_callback dl_tlp_exc_list;
  // Error catcher:
  dl_tlp_err_catcher err_catcher;
  // Constructor "new":
  function new(string name="tlp_exception_via_callback", uvm_component parent=null);
    super.new(name,parent);
  endfunction : new

  // build_phase: To build various components of class:
  virtual function void build_phase(uvm_phase phase);
    super.build_phase(phase);
    // Load test specific cfg values:
    cust_cfg.root_cfg.pcie_cfg.pl_cfg.set_link_width_values(4);
  endfunction : build_phase
```

```
cust_cfg.endpoint_cfg.pcie_cfg.pl_cfg.set_link_width_values(4);

// Register config with the registry so that it will be picked up by the env:
svt_config_object_db#(pcie_device_system_configuration)::set(this, ,
{ "env", ".", "cfg"}, cust_cfg);

// Create dl_tlp_exc_list:
dl_tlp_exc_list = new("dl_tlp_exc_list");

// Pass the constrained exception list to Data Link Layer:
uvm_config_db#(svt_pcie_dl_tlp_exception_list)::set(this,
"env.endpoint.port0.dl0",
"dl_tlp_xact_exception_list",
dl_tlp_exc_list);

// Create error report catcher object and register it:
err_catcher = new();
uvm_report_cb::add(null, err_catcher);
endfunction : build_phase

function void end_of_elaboration_phase(uvm_phase phase);
    super.end_of_elaboration_phase(phase);
    // Create the callback object:
    dl_tlp_cb = new("dl_tlp_cb");
    dl_tlp_cb.randomize();
    // Register the callback object with the DL component:
    uvm_callbacks#(svt_pcie_dl, svt_pcie_dl_callback)::add(env.endpoint.port.dl,
        dl_tlp_cb);
    `uvm_info(get_full_name(), "Exiting...", UVM_HIGH);
endfunction : end_of_elaboration_phase

task run_phase( uvm_phase phase );
    `uvm_info(get_full_name(), "Running test dl_tlp_example_callback .\n",
        UVM_LOW);
endtask : run_phase
endclass : dl_tlp_example_callback

// This is the callback class. It is instantiated in the test class above:
class tx_dl_tlp_callback extends svt_pcie_dl_callback;
    // Factory registration:
    `uvm_object_utils(tx_dl_tlp_callback)
    //`svt_uvm_object_utils(tx_dl_tlp_callback)

    // There are two basic ways to modify a value in a transaction (which is
    // really what we are aiming to do with the callback):
    // 1. Explicitly modify the value (e.g. transaction.<field> = <value> )
    // 2. Use an exception to cause a modification (typically for 'calculated' fields
    //     such as CRC).
    // To use an exception, you need two things:
    // 1. The "exception" - one per modification to the transaction (note that the
    //     type [class] of this object is specific to the transaction).
    // 2. The "exception list" - holds the exception(s) (again, the
    //     exception-list class is specific to the transaction.)
```

```
// Exceptions - Use one each for the TLP transaction and the DL/TLP (which is
// essentially a TLP transaction with a sequence number and LCRC added):
// For a TLP transaction (within the DL/TLP transaction):
svt_PCIE_tlp_exception my_tlp_exc = new("my_tlp_exc");
// For DL/TLP transaction:
svt_PCIE_dl_tlp_exception my_dl_tlp_exc = new("my_dl_tlp_exc");

// Exception lists - Use one per transaction type that you intend to modify:
tlp_exc_list_via_callback my_tlp_exc_list = new("my_tlp_exc_list");
dl_tlp_exception_list_via_callback my_dl_tlp_exc_list = new("my_dl_tlp_exc_list");

// Error counter:
static int error_count = 0;
rand bit do_lcrc_err;

// Constructor:
function new(string name = "tx_dl_tlp_callback");
    super.new(name);
endfunction : new

// pre_tlp_framed_out_put: this is the actual callback function. It will be
// called every time a DL/TLP is ready to be framed for transmission:
virtual function void pre_tlp_framed_out_put( svt_PCIE_dl dl,
                                             svt_PCIE_dl_tlp transaction,
                                             ref bit drop);
    `uvm_info(get_full_name(),
              $sformatf("\nA callback prior to transmitting TLP. Current TC=%0d and
                        ECRC = 0x%x, error count=%0d.\n",
                        transaction.tlp.traffic_class,
                        transaction.tlp.ecrc, error_count),
              UVM_LOW);
    if(error_count < 1) begin      // Just corrupt one TLP
        if (do_lcrc_err) begin    // inject an LCRC err
            // The AUTO_TX_FORCE_LCRC causes the 'corrupted_data' value to
            // be forced into the LCRC field:
            my_dl_tlp_exc.corrupted_data = 32'hbaad_baad; // Forced LCRC value
            my_dl_tlp_exc.error_kind = svt_PCIE_dl_tlp_exception::AUTO_TX_FORCE_LCRC;
        end
        else begin
            my_dl_tlp_exc.error_kind=svt_PCIE_dl_tlp_exception::AUTO_TX_ILLEGAL_SEQ_NUM;
        end
        // Put the exc into the list, then copy/cast the list into the transaction:
        my_dl_tlp_exc_list.add_exception(my_dl_tlp_exc);
        `svt_note("pre_tlp_framed_out_put",
                  $sformatf(" Attaching DL/TLP exception list .\n."));
        $cast(transaction.exception_list, my_dl_tlp_exc_list.`SVT_DATA_COPY());
        error_count++;
    end
endfunction
endclass : tx_dl_tlp_callback

////////// Various helper classes: exception lists, error catcher //////////
// tlp_exc_list_via_callback: see above for details of exception lists.
// This is for the TLP transaction encapsulated in the DL/TLP transaction
```

```
class tlp_exc_list_via_callback extends svt_pcie_tlp_transaction_exception_list;
    // The default exception, in case we have no others defined:
    svt_pcie_tlp_exception xact_exc = new("xact_exc");

    // Constructor:
    function new(string name = "tlp_exc_list_via_callback",
        svt_pcie_tlp_exception xact_exc = null);
        super.new(name,xact_exc);
        xact_exc = this.xact_exc;
        xact_exc.NO_ERROR_wt = 1;           // Implies no errors
        xact_exc.set_constraint_weights(0);
        this.randomized_exception = xact_exc; // insert this exception into our list
    endfunction : new
endclass : tlp_exc_list_via_callback

// dl_tlp_exception_list_via_callback: see above for details of exception lists.
// This is for actual the DL/TLP transaction.
class dl_tlp_exception_list_via_callback extends svt_pcie_dl_tlp_exception_list;
    // The default exception - in case we have no others defined.
    svt_pcie_dl_tlp_exception xact_exc = new("xact_exc");
    // Constructor:
    function new(string name = "dl_tlp_exception_list_via_callback",
        svt_pcie_dl_tlp_exception xact_exc = null);
        super.new(name,xact_exc);
        xact_exc = this.xact_exc;
        xact_exc.NO_ERROR_wt = 1;
        xact_exc.set_constraint_weights(0);
        this.randomized_exception = xact_exc;
    endfunction : new
endclass : dl_tlp_exception_list_via_callback

// Class to demote UVM_WARNING and UVM_ERROR messages:
class dl_tlp_err_catcher extends uvm_report_catcher;
    // Constructor:
    function new(string name="error catcher");
        super.new(name);
    endfunction

    // catch(): This function is where we handle the actual UVM WARNING/ERROR
    // messages; it suppresses the errors that would occur due to the corrupted
    // CRC, etc.
    virtual function action_e catch();
        // Error catcher required if CORRUPT_TC is injected:
        if(get_severity() == UVM_ERROR) begin
            if ((uvm_is_match("*Received TLP with invalid seq num*", get_message())))
                begin
                    set_severity(UVM_INFO);
                end
        end
        else if (get_severity() == UVM_WARNING) begin
            if ((uvm_is_match("*Received TLP with bad LCRC*", get_message()))) begin
                set_severity(UVM_INFO);
            end
        end
    end
endclass
```

```

    return THROW;
endfunction : catch
endclass : dl_tlp_err_catcher

```

## 19.5 SVT VIP Callbacks Reference

The callbacks that currently are supported and their arguments are listed in [Table 19-1](#).

Callbacks and their methods for each layer are listed in [Table 19-2](#).

**Table 19-1 Supported PCIe callbacks**

| Function Name                                                                                                       | Arguments<br>(type and name) | I/O | Values                                                                                                |
|---------------------------------------------------------------------------------------------------------------------|------------------------------|-----|-------------------------------------------------------------------------------------------------------|
| pre_tlp_framed_out_put<br><br>DL Layer<br><br>Called just prior to framing a TLP for transmission to the Phy Layer. | svt_PCIE_DL dl               | I   | The component object of the calling layer.                                                            |
|                                                                                                                     | svt_PCIE_DL_TLP transaction  | I   | The DL/TLP transaction to be examined/modified. Note that it also contains a TLP object.              |
|                                                                                                                     | drop                         | ref | When set, the transaction is dropped prior to transmission.<br><b>NOTE: Currently not implemented</b> |
| post_tlp_framed_in_get<br><br>DL Layer<br><br>Called just after reception from the Phy Layer.                       | svt_PCIE_DL dl               | I   | The component object of the calling layer.                                                            |
|                                                                                                                     | svt_PCIE_DL_TLP transaction  | I   | The DL/TLP transaction to be examined/modified. Note that it also contains a TLP object.              |
|                                                                                                                     | bit drop                     | ref | When set, the transaction is dropped prior to transmission.<br><b>NOTE: Currently not implemented</b> |
| tx_dllp_started<br><br>DL Layer<br><br>Called just prior to transmitting a DLLP to the Phy Layer.                   | svt_PCIE_DL dl               | I   | The component object of the calling layer.                                                            |
|                                                                                                                     | svt_PCIE_DLLP transaction    | I   | The DLLP transaction to be examined/modified.                                                         |
|                                                                                                                     | bit drop                     | ref | When set, the transaction is dropped prior to transmission.<br><b>NOTE: Currently not implemented</b> |
| rx_dllp_started<br><br>DL Layer<br><br>Called just after reception from the Phy Layer.                              | svt_PCIE_DL dl               | I   | The component object of the calling layer.                                                            |
|                                                                                                                     | svt_PCIE_DLLP transaction    | I   | The dllp transaction t be examined/modified.                                                          |
|                                                                                                                     | bit drop                     | ref | When set, the transaction is dropped prior to transmission.<br><b>NOTE: Currently not implemented</b> |

**Table 19-1 Supported PCIe callbacks (Continued)**

|                                                                                                                                                |                                                          |     |                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----|-------------------------------------------------------------------------------|
| Target Application<br><br>Called by the component just after scheduling a TLP transaction for transmission on the link, just prior to framing. | <code>svt_PCIE_TARGET_APP_TARGET_APP</code>              | I   | The component object of the calling layer.                                    |
|                                                                                                                                                | <code>svt_PCIE_TLP TRANSACTION</code>                    | I   | The transaction to be examined/modified.                                      |
|                                                                                                                                                | <code>bit drop</code>                                    | ref | When set, the transaction is dropped prior to framing and is not transmitted. |
| Target Application<br><br>Called by the component after receiving a TLP transaction from the link.                                             | <code>svt_PCIE_TARGET_APP_TARGET_APP</code>              | I   | The component object of the calling layer.                                    |
|                                                                                                                                                | <code>svt_PCIE_TLP TRANSACTION</code>                    | I   | The transaction to be examined/modified.                                      |
|                                                                                                                                                | <code>bit drop</code>                                    | ref | When set, the transaction is dropped without any further processing.          |
| Driver Application<br><br>Called by the component when the transaction is complete                                                             | <code>svt_PCIE_DRIVER_APP_DRIVER</code>                  | I   | The component object issuing the callback                                     |
|                                                                                                                                                | <code>svt_PCIE_DRIVER_APP_TRANSACTION TRANSACTION</code> | I   | The transaction to be examined/modified.                                      |
|                                                                                                                                                | <code>svt_PCIE_PL PL</code>                              | I   | The component object issuing this callback.                                   |
| Phy Layer<br><br>Called by the component after building a TS OS transaction.                                                                   | <code>svt_PCIE_OS TRANSACTION</code>                     | I   | The transaction to be examined/modified.                                      |
|                                                                                                                                                | <code>svt_PCIE_PL PL</code>                              | I   | The component object issuing this callback.                                   |
|                                                                                                                                                | <code>svt_PCIE_OS TRANSACTION</code>                     | I   | The transaction to be examined/modified.                                      |
| Phy Layer<br><br>Called by the component after building a non-TS OS Transaction                                                                | <code>svt_PCIE_PL PL</code>                              | I   | The component object issuing this callback.                                   |
|                                                                                                                                                | <code>svt_PCIE_SYMBOL_SYMBOLS[]</code>                   | I   | The array of symbols to be examined/modified.                                 |
|                                                                                                                                                |                                                          |     |                                                                               |
| Phy Layer<br><br>Called by the component at every symbol time after gathering all the symbols to be transmitted on the link                    | <code>svt_PCIE_SYMBOL_SYMBOLS[]</code>                   | I   | The array of symbols to be examined/modified.                                 |
|                                                                                                                                                |                                                          |     |                                                                               |
|                                                                                                                                                |                                                          |     |                                                                               |

**Table 19-1 Supported PCIe callbacks (Continued)**

|                                                                                                               |                                      |  |                                             |
|---------------------------------------------------------------------------------------------------------------|--------------------------------------|--|---------------------------------------------|
| symbol_stripe_ended<br><br>Phy Layer<br><br>Called by the component when the symbol stripe has been completed | svt_PCIE_PL pl                       |  | The component object issuing this callback. |
|                                                                                                               | svt_PCIE_SYMBOL_STRIPE symbol_stripe |  | The symbol stripe object to be examined.    |

**Table 19-2 Callback classes and methods by layer**

| Layer      | Callback Class               | Method                 | Description                                                                                                                                                  |
|------------|------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Driver App | svt_PCIE_DRIVER_APP_CALLBACK | transaction_ended      | Called by the component once the transaction is completed by the link partner. Completion data returned by the link partner is now available in the payload. |
| Target App | svt_PCIE_TARGET_APP_CALLBACK | post_rx_tlp_get        | Called by the component after recognizing a TLP transaction received immediately from the link.                                                              |
|            |                              | pre_tx_tlp_put         | Called by the component after scheduling a TLP transaction for transmission on the link, just prior to framing.                                              |
| TL Layer   | svt_PCIE_TL_CALLBACK         | post_seq_item_get      | Called by the component after pulling a TLP out of its TLP input, but before acting on the TLP.                                                              |
|            |                              | pre_tlp_out_put        | Called by the component once the TLP is completely received and prior to putting the TLP on the rx port.                                                     |
| DL Layer   | svt_PCIE_DL_CALLBACK         | post_tlp_framed_in_get | Called by the component after recognizing a TLP transaction received immediately from the link.                                                              |
|            |                              | pre_tlp_framed_out_put | Called by the component after scheduling a TLP transaction for transmission on the link, just prior to framing.                                              |
|            |                              | rx_dllp_started        | Called by the component after receiving user DLLP transaction from an input port.                                                                            |
|            |                              | tx_dllp_started        | Called by the component after constructing a DLLP transaction just prior to its further processing.                                                          |

**Table 19-2** Callback classes and methods by layer (Continued)

|          |                      |                     |                                                                                                                                                                                                   |
|----------|----------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PL Layer | svt_PCIE_pl_callback | pre_symbol_out_put  | Called by the component at every symbol time after gathering all the symbols to be transmitted on the link. Last chance to corrupt any symbol before it goes on the link.                         |
|          |                      | tx_os_started       | Called by the component after building an OS Transaction. The callback gives the user a chance to attach an exception list to the OS transaction prior to its transmission on the link.           |
|          |                      | tx_ts_os_started    | Called by the component after building a TS OS transaction. The callback gives the user a chance to attach an exception list to the TS OS transaction prior to its transmission on the link.      |
|          |                      | symbol_stripe_ended | Called by the component when the symbol stripe has been completed. The symbol_stripe object contains the information necessary to log symbol data. Writes to the symbol_stripe object are ignore. |

## 19.6 Transaction Layer Callbacks and Exceptions

The Transaction Layer provides a callback class, svt\_PCIE\_t1\_callback. This callback class is used to apply exceptions that can modify or observe data.

The Transaction Layer callbacks are used only in case of transactions that are generated externally to the model. These callbacks will not be executed for a transaction from internal applications (requests from the Driver or Requester Applications, or completions from the Target Application). Only testbenches that generate request objects and push them directly into the TL should use the TL callbacks.

```
class svt_PCIE_t1_callback extends svt_callback;
extern function void new ( string name = "svt_PCIE_t1_callback" );
extern virtual function void pre_tlp_out_put ( svt_PCIE_t1 tl , svt_PCIE_tlp tlp ,
ref bit drop );
extern virtual function void post_seq_item_get(svt_PCIE_t1 tl, svt_PCIE_tlp tlp,
ref bit drop);
endclass
```

**Table 19-3** Transaction Layer Callbacks

| Callback          | VIP Direction | Behavior                                                                                                                                                                                                                                                  |
|-------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| post_seq_item_get | TX            | Called by the component after pulling a TLP out of its TLP input port, but before acting on the TLP in any way. In other words, this callback is only used for transactions coming either directly from TL input port or from external user applications. |

**Table 19-3 Transaction Layer Callbacks**

| Callback        | VIP Direction | Behavior                                                                                                                                                                                                                                                 |
|-----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pre_tlp_out_put | RX            | Callback issued by the component after a completion is received completely and prior to transmitting to the RX port. In other words, this callback is only used for completions that are in response to requests that come into model via TL input port. |

### 19.6.1 Transaction Layer Exceptions

Transaction Layer exceptions can be applied using the svt\_pcie\_tl\_callback class. The callback methods in this class support the svt\_pcie\_tlp transaction class. The svt\_pcie\_tlp transaction class includes an exception list, svt\_pcie\_tlp\_exception\_list, which contains an exception, svt\_pcie\_tlp\_exception. The svt\_pcie\_tlp\_exception exception is used to specify the type of exception to be applied.

By default the exception list is null, thus indicating no exception is to be applied. Exceptions are added by adding a handle to an exception list that is not null. For more information on the available exception types, refer to the HTML class reference of the exception class, svt\_pcie\_tlp\_exception.

## 19.7 Datalink Layer Callbacks and Exceptions

The Datalink Layer provides a callback class, svt\_pcie\_dl\_callback. This callback class is used to apply exceptions that can modify or observe data.

```
class svt_pcie_dl_callback extends svt_callback;
    extern function new(string name = "svt_pcie_dl_callback");
    extern virtual function void pre_tlp_framed_out_put(svt_pcie_dl dl,
                                                       svt_pcie_dl_tlp transaction, ref bit drop);
    extern virtual function void post_tlp_framed_in_get(svt_pcie_dl dl,
                                                       svt_pcie_dl_tlp transaction, ref bit drop);
    extern virtual function void tx_dllp_started(svt_pcie_dl dl,
                                               svt_pcie_dllp transaction, ref bit drop);
    extern virtual function void rx_dllp_started(svt_pcie_dl dl,
                                               svt_pcie_dllp transaction, ref bit drop);
endclass
```

**Table 19-4 Datalink Layer Callbacks**

| Callback               | VIP Direction | Behavior                                                                                                                |
|------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------|
| post_tlp_framed_in_get | RX            | Callback issued by the component after recognizing a TLP transaction received immediately from a link                   |
| pre_tlp_framed_out_put | TX            | Callback issued by the component after scheduling a TLP transaction for transmission on the link, just prior to framing |
| rx_dllp_started        | RX            | Callback issued by the component after receiving User DLLP transaction from an input port                               |
| tx_dllp_started        | TX            | Callback issued by the component after building a DLLP transaction just prior to its further processing                 |

### 19.7.1 Datalink Layer Exceptions

Datalink Layer exceptions can be applied using the svt\_PCIE\_DL\_CALLBACK class. Each callback method in this class supports a particular transaction class. Each transaction class includes an exception list which contains an exception that is used to specify the type of exception to be applied.

By default the exception list is null, thus indicating no exception is to be applied. Exceptions are added by adding a handle to an exception list that is not null.

For example, the post\_tlp\_framed\_in\_get callback method supports the svt\_PCIE\_DL\_TLP transaction class. The svt\_PCIE\_DL\_TLP transaction class includes an exception list, svt\_PCIE\_DL\_TLP\_EXCEPTION\_LIST, that contains an exception, svt\_PCIE\_DL\_TLP\_EXCEPTION. The svt\_PCIE\_DL\_TLP\_EXCEPTION exception is used to specify the exception type. [Table 19-5](#) highlights the relationships between the DL callback methods and their associated classes.

For more information on the available exception types, refer to the HTML class reference of the exception classes in [Tables 19-5](#).

**Table 19-5 Datalink Layer Callback Method and Associated Classes**

| Callback               | Transaction Class | Exception List Class           | Exception Class           |
|------------------------|-------------------|--------------------------------|---------------------------|
| post_tlp_framed_in_get | svt_PCIE_DL_TLP   | svt_PCIE_DL_TLP_EXCEPTION_LIST | svt_PCIE_DL_TLP_EXCEPTION |
| pre_tlp_framed_out_put | svt_PCIE_DL_TLP   | svt_PCIE_DL_TLP_EXCEPTION_LIST | svt_PCIE_DL_TLP_EXCEPTION |
| rx_dllp_started        | svt_PCIE_DLLP     | svt_PCIE_DLLP_EXCEPTION_LIST   | svt_PCIE_DLLP_EXCEPTION   |
| tx_dllp_started        | svt_PCIE_DLLP     | svt_PCIE_DLLP_EXCEPTION_LIST   | svt_PCIE_DLLP_EXCEPTION   |

### 19.8 Physical Layer Callbacks and Exceptions

The Physical Layer provides a callback class, svt\_PCIE\_PL\_CALLBACK. This callback class is used to apply exceptions that can modify or observe data.

```
class svt_PCIE_PL_CALLBACK extends svt_XACTOR_CALLBACK;
    extern function new(string name = "svt_PCIE_PL_CALLBACK");
    extern virtual function void tx_ts_os_started(svt_PCIE_PL pl,
                                                svt_PCIE_OS transaction);
    extern virtual function void tx_os_started(svt_PCIE_PL pl, svt_PCIE_OS transaction);
    extern virtual function void pre_symbol_out_put(svt_PCIE_PL pl,
                                                    svt_PCIE_SYMBOL symbols[]);
    extern virtual function void symbol_stripe_ended(svt_PCIE_PL pl,
                                                    svt_PCIE_SYMBOL_STRIPE symbol_stripe);
    virtual function void pre_pipe_data_out_put(svt_PCIE_PL pl, svt_PCIE_PIPE_DATA
                                                pipe_data);
    virtual function void post_pipe_data_in_get(svt_PCIE_PL pl, svt_PCIE_PIPE_DATA
                                                pipe_data);
endclass
```

**Table 19-6 Physical Layer Callbacks**

| Callback              | VIP Direction | Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pre_symbol_out_put    | TX            | Callback issued by the PL at every symbol time after gathering all the symbols to be transmitted on the PCIe link. This is the last chance the user has to corrupt any symbol before it goes on the link. Note, for multi-lane configurations the symbols are striped per lane into symbols[].                                                                                                                                                                                               |
| tx_os_started         | TX            | Callback issued by the component after building an OS Transaction. The callback gives user a chance to attach exception list to the OS transaction prior to its transmission on the link                                                                                                                                                                                                                                                                                                     |
| tx_ts_os_started      | TX            | Callback issued by the component after building a TS OS Transaction. The callback gives user a chance to attach exception list to the TS OS transaction prior to its transmission on the link                                                                                                                                                                                                                                                                                                |
| symbol_stripe_ended   | TX            | Called by the component when the symbol stripe has been completed. The symbol_stripe object contains the information necessary to log symbol data. Writes to the symbol_stripe object are ignored.                                                                                                                                                                                                                                                                                           |
| pre_pipe_data_out_put | TX            | Callback issued by the component just before every posedge pipe_clk after gathering all the pipe_data signals to be transmitted on the PCIe link. This is the last chance to force any pipe data signals before it goes on the wire.<br>Note: MAC must be turned-off for this callback to work so that all the data is driven by the PIPE callback only. Service request HOT_PLUG_UNPLUG can be enabled to turn-off the MAC.                                                                 |
| post_pipe_data_in_get | RX            | Callback issued by the component after every posedge of pipe_clk after gathering all the pipe data signals that were received on the PIPE bus. Used solely to report values of the per-lane datapath signals received off the PIPE bus. Exceptions are not supported by this callback.<br>Note: MAC must be turned-off as users are responsible for handling/demoting any errors that may occur if the MAC is turned on. Service request HOT_PLUG_UNPLUG can be enabled to turn-off the MAC. |

These callbacks can be used to inject errors into symbols/ordered-sets using exception objects. The example shown below illustrates how to corrupt the COM in a SKP ordered set using a callback function that is issued with the transmission of each symbol.

**Example:**

```
// Callback Class
class tx_symbol_callback extends svt_PCIE_pl_callback;

// Factory registration
`uvm_object_utils(tx_symbol_callback)

function new(string name = "tx_symbol_callback");
super.new();
endfunction

virtual function void pre_symbol_out_put(svt_PCIE_pl pl, svt_PCIE_symbol
symbols[]);
`uvm_info(get_full_name(),"Entered...", UVM_HIGH);
// Test case decision to determine how many errors to introduce.
if(symbols[0].symbol_event == svt_PCIE_symbol::SKP_STARTED) // event indicates what
type of symbol is starting
begin
// build an exception list
svt_PCIE_symbol_exception_list sym_exc_list = new();
svt_PCIE_symbol_exception sym_exc = new();
`uvm_info(get_full_name(),$sformatf("Link width = %0d. Corrupting COM in SKP OS for
transmission.\n",symbols.size()), UVM_LOW);
foreach(symbols[lanes]) begin
`uvm_info(get_full_name(), $sformatf("\tsymbol[%0d] : %0s", lanes,
symbols[lanes].symbol_type), UVM_LOW)
end
sym_exc.error_kind = svt_PCIE_symbol_exception::CORRUPT_DATA_VALUE_ONLY; // Corrupt
the data
sym_exc.corrupted_data = 'h55;
sym_exc.scrambler_control = svt_PCIE_symbol_exception::NONE; // Do not corrupt
scrambling
sym_exc_list.add_exception(sym_exc);
symbols[0].exception_list = sym_exc_list; // add the Exception to the symbol
end
endfunction
endclass
```

```
// UVM Test Class
class symbol_exception_via_callback_test extends pcie_device_base_test ;

// Factory registration
`uvm_component_utils( symbol_exception_via_callback_pipe_test )

// Callback instance
tx_symbol_callback endpoint_tx_symbol_cb;

...
function void connect_phase(uvm_phase phase);
super.connect_phase(phase);
`uvm_info(get_full_name(), "Entered...", UVM_HIGH);
...
endpoint_tx_symbol_cb = new("endpoint_tx_symbol_cb");
uvm_callbacks#(svt_PCIE_Pl, svt_PCIE_Pl_Callback)::add(env.endpoint.port.pl,
endpoint_tx_symbol_cb);
...
`uvm_info(get_full_name(), "Exiting...", UVM_HIGH);
endfunction
...
endclass
```

The `svt_PCIE_Symbol::symbol_event` can be used within the callback to wait for specific events like start of a TS1 (`svt_PCIE_Symbol::TS1_STARTED`), start of a DLLP (`svt_PCIE_Symbol::DLLP_STARTED`), and so on to be able to inject all possibly symbol errors. To check the list of events, see “[Callbacks](#)” (for enumerated data type `svt_PCIE_Symbol::symbol_event_enum` and enumerated data type `svt_PCIE_Symbol_Exception::error_kind_enum`) for the full list of errors that can be injected on symbol.

Similarly, the `tx_os_started()`/`tx_ts_os_started()` callback functions can be used to inject errors on OS transactions. The example below illustrates the corruption of the link number (symbol 1) in a TS1 while in LTSSM ‘Configuration.Linkwidth.Start’ state.

**Example:**

```
// Callback Class
class link_number_corruption_callback extends svt_PCIE_pl_callback;

// Factory registration
`svt_xvm_object_utils(link_number_corruption_callback)
```
virtual function void tx_ts_os_started(svt_PCIE_pl pl, svt_PCIE_os transaction);
if(pl.status.ltssm_state == svt_PCIE_types::CONFIGURATION_LINKWIDTH_START) begin
// create exception list
svt_PCIE_os_exception_list os_exc_list = new();
svt_PCIE_os_exception os_exc = new();
os_exc.error_kind = svt_PCIE_os_exception::CORRUPT_LINK_NUMBER;
`uvm_info("tx_ts_os_started", $sformatf("\n Exception: Link number corrupted on
lane = %0d.\n", transaction.logical_lane_num), UVM_MEDIUM);
os_exc_list.add_exception(os_exc);
// add exception list to transaction.
transaction.exception_list = os_exc_list;
end
endfunction
endclass

// UVM Test Class
class link_number_corruption_via_callback_test extends pcie_device_base_test ;

// Factory registration
`uvm_component_utils( symbol_exception_via_callback_pipe_test )

// Callback instance
link_number_corruption_callback endpoint_tx_ts_os_cb;

```
function void connect_phase(uvm_phase phase);
super.connect_phase(phase);
`uvm_info(get_full_name(), "Entered...", UVM_HIGH);
```
endpoint_tx_ts_os_cb = new("endpoint_tx_ts_os_cb");
uvm_callbacks#(svt_PCIE_pl,
svt_PCIE_pl_callback)::add(env.endpoint.port.pl,endpoint_tx_ts_os_cb);
```
`uvm_info(get_full_name(), "Exiting...", UVM_HIGH);
endfunction
```
endclass
```

## 19.8.1 Physical Layer Exceptions

Physical Layer exceptions can be applied using the svt\_PCIE\_pl\_callback class. Each callback method in this class supports a particular transaction class. Each transaction class includes an exception list which contains an exception that is used to specify the type of exception to be applied.

By default the exception list is null, thus indicating no exception is to be applied. Exceptions are added by adding a handle to an exception list that is not null.

For example, the pre\_symbol\_out callback method supports the svt\_PCIE\_symbol transaction class. The svt\_PCIE\_symbol transaction class includes an exception list, svt\_PCIE\_symbol\_exception\_list, which contains an exception, svt\_PCIE\_symbol\_exception. The svt\_PCIE\_symbol\_exception exception is used to specify the exception type. [Tables 19-7](#) highlights the relationships between the PL callback methods and their associated classes.

For more information on the available exception types, refer to the HTML class reference of the exception classes in [Tables 19-7](#).

**Table 19-7 Physical Layer Callback Methods and Associated Classes**

| Callback              | Transaction Class       | Exception List Class              | Exception Class              |
|-----------------------|-------------------------|-----------------------------------|------------------------------|
| pre_symbol_out_put    | svt_PCIE_symbol         | svt_PCIE_symbol_exception_list    | svt_PCIE_symbol_exception    |
| tx_os_started         | svt_PCIE_os             | svt_PCIE_os_exception_list        | svt_PCIE_os_exception        |
| tx_ts_os_started      | svt_PCIE_os             | svt_PCIE_os_exception_list        | svt_PCIE_os_exception        |
| pre_pipe_data_out_put | svt_PCIE_pipe_data_pipe | svt_PCIE_pipe_data_exception_list | svt_PCIE_pipe_data_exception |
| post_pipe_data_in_get | svt_PCIE_pipe_data_pipe | Not Applicable                    | Not Applicable               |

## 19.9 Controlling Completion Timing and Size Using Callbacks

There are two ways to control completion timing:

1. By specifying a delay for the current completion.
2. By specifying a delay for the next completion.

Control of completion size is applied only to the next completion, and not the current completion.

### 19.9.1 Controlling Delay for the Current Completion

To specify a delay for the current completion, use the completion\_delay\_in\_ns attribute in the svt\_PCIE\_tlp class.

This is used only in association with the following callback:

- svt\_PCIE\_target\_app\_callback::pre\_tx\_tlp\_put

It is ignored in all other use.

When used at the specified callback this attribute controls the delay between the time the callback occurs (at creation of the completion) and the time the completion is sent from the target application to the transaction layer. It does not incorporate the delay through the layers or the time required to actually transmit the completion, which may be significant for large memory read completions on narrow links.

This value is ignored if:

- ❖ This TLP is not a completion.
- ❖ The value is not set during the specified callbacks.
- ❖ The value is negative.

### 19.9.2 Controlling Delay for the Next Completion

To specify a delay for the next completion, use the `next_completion_delay_in_ns` attribute in the `svt_PCIE_tlp` class . It specifies the delay in ns to the creation of a completion that follows the current TLP.

This is used only in association with the following callbacks:

- ❖ `svt_PCIE_target_app_callback::post_rx_tlp_get`
- ❖ `svt_PCIE_target_app_callback::pre_tx_tlp_put`

It is ignored in all other use.

When used at the specified callbacks it controls the delay between:

- ❖ The execution of the callback, and
- ❖ The target application creating the subsequent completion

It does not incorporate the delay through the layers or the time required to actually transmit the completion, which may be significant for large memory read completions on narrow links.

The delay is used in two cases:

1. A non-posted request received by the vip: the value specifies the delay to the first completion transmitted by the vip in response.
2. A memory read completion transmitted by the vip, if there will be at least one subsequent completion for the same request: the value specifies the delay to the next completion transmitted by the VIP.

To control completion timing using this value, set it in either the `pre_tx_tlp_put` callback or the `post_rx_tlp_get` callback in the `svt_PCIE_target_app_callback` class.

This value is ignored if:

- ❖ This TLP is neither a non-posted request received by the vip nor a memory read completion transmitted by the VIP.
- ❖ This TLP is the last completion of a memory read request.
- ❖ The value is not set during the specified callbacks.
- ❖ The value is negative.

### 19.9.3 Controlling Size for the Next Completion

You can control the size of completions by using callbacks and the class member `next_completion_size_in_rcb`. It specifies the size in RCB units of the completion that follows this TLP.

It is used only in associated with the following callbacks:

- ❖ `svt_pcie_target_app_callback::post_rx_tlp_get`
- ❖ `svt_pcie_target_app_callback::pre_tx_tlp_put`

The `next_completion_size_in_rcb` attribute is ignored in all other uses. It is used in two cases:

- ❖ A memory read request received by the vip: it specifies the size in RCB of the first completion transmitted by the vip in response.
- ❖ A memory read completion transmitted by the vip, if there will be at least one subsequent completion for the same request: it specifies the size of the next completion transmitted by the VIP.

If the value is set to 1, the VIP will transmit only enough data to reach the first RCB. In that case, the length of the first completion could be as small as one dword.

To control completion size using this value, set it in either the `pre_tx_tlp_put` callback or the `post_rx_tlp_get` callback in the `svt_pcie_target_app_callback` class.

This value is ignored if:

- ❖ This TLP is not a memory read request received by the vip or a completion transmitted by the VIP in response to a memory read request.
- ❖ This TLP is the last completion of a read request.
- ❖ The value is not set during the specified callbacks.

This value is not intended to produce error scenarios and will also be ignored if the value is less than 1. For large values the completion size will be truncated to either the max payload size or the max read completion data size, whichever is smaller.

If the specified size is larger than the number of dwords remaining to finish the request, the next completion will include all remaining data (unless limited by the max payload size or max read completion data size).

# 20 Support for CCIX

---

This chapter describes the CCIX features available with the Synopsys PCIe SVT Verification IP.

This chapter discusses the following topics:

- ❖ [Version Support](#)
- ❖ [Supported Interfaces](#)
- ❖ [Supported Features](#)
- ❖ [Support for CCIX ESM Operation](#)
- ❖ [Support for CCIX Optimized TLP Format](#)
- ❖ [Limitations](#)

## 20.1 Version Support

The Synopsys PCIe SVT VIP supports the *CCIX Transport, Release 2 Draft specification, March 2017*. Functionality and controls will be updated as the specification changes.

## 20.2 Supported Interfaces

CCIX support is currently available for both serial and PIPE (4.4/4.4.1) interfaces using the PCIe SVT Unified model.

### 20.2.1 Updates for PIPE interface

For CCIX ESM support, `svt_PCIE_PIPE_if` interface is updated with the following:

- ❖ Widened PclkRate signal from 3bits to 4bits to accommodate 625 MHz, 781.25 MHz, 1250 MHz, 1562.5 MHz, 2500 MHz, 3125 MHz PCLK frequencies.
  - ◆ ‘b1000 : 625 MHz
  - ◆ ‘b1001 : 781.25 MHz
  - ◆ ‘b1010 : 1250 MHz
  - ◆ ‘b1011 : 1562.5 MHz
  - ◆ ‘b1100 : 2500 MHz

- ◆ ‘b1101 : 3125 MHz

## 20.3 Supported Features

The Synopsys PCIe SVT VIP supports the following features:

- ❖ Extended Speed Mode (ESM)
- ❖ Optimized TLP Format



These are independently enabled.

## 20.4 Support for CCIX ESM Operation

### 20.4.1 Enabling ESM Operation

To enable CCIX ESM operation, compile the model with the following macro defined:

`SVT_PCIE_CCIX_ESM_MODE_SUPPORTED`

Also, set the following configuration attribute to 1:

`svt_PCIE_pl_configuration::ccix_esm_mode_supported`

### 20.4.2 Configuring ESM Operation

#### 20.4.2.1 Interface-Independent Configuration

The model provides the following configuration attributes in `svt_PCIE_pl_configuration` to support the equivalent fields in the noted ESM registers:

- ❖ CCIX Transport Capabilities Register
  - ◆ `ccix_esm_phy_reach_len_capability`
  - ◆ `ccix_esm_recal_reqd_after_data_rate_update`
  - ◆ `ccix_esm_calibration_time`
  - ◆ `ccix_esm_quick_eq_timeout`
    - ◆ `ccix_esm_quick_eq_select_1_timeout_ns`
    - ◆ `ccix_esm_quick_eq_select_2_timeout_ns`
    - ◆ `ccix_esm_quick_eq_select_3_timeout_ns`
    - ◆ `ccix_esm_quick_eq_select_4_timeout_ns`
    - ◆ `ccix_esm_quick_eq_select_5_timeout_ns`
- ❖ ESM Mandatory Data Rate Capability Register
  - ◆ `ccix_mandatory_data_rates`
- ❖ ESM Control Register
  - ◆ `ccix_esm_extended_eq_ph2_timeout_sel_default`
    - ◆ `ccix_esm_extended_eq_ph2_select_0_timeout_ns`
    - ◆ `ccix_esm_extended_eq_ph2_select_1_timeout_ns`
    - ◆ `ccix_esm_extended_eq_ph2_select_2_timeout_ns`
    - ◆ `ccix_esm_extended_eq_ph2_select_3_timeout_ns`
    - ◆ `ccix_esm_extended_eq_ph2_select_4_timeout_ns`

- ❖ ccix\_esm\_extended\_eq\_ph2\_select\_5\_timeout\_ns
- ◆ ccix\_esm\_extended\_eq\_ph3\_timeout\_sel\_default
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_0\_timeout\_ns
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_1\_timeout\_ns
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_2\_timeout\_ns
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_3\_timeout\_ns
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_4\_timeout\_ns
  - ❖ ccix\_esm\_extended\_eq\_ph3\_select\_5\_timeout\_ns

To support dynamic configuration that is equivalent to writing the ESM Control Register, the model implements the sequence `svt_PCIE_pl_service_ccix_configure_esm_sequence`. The sequence is defined in `svt_PCIE_pl_service_sequence_collection.sv`. It can be used to set the model's implementation of the fields in the ESM Control Register (model attribute names in parentheses):

- ❖ ESM Data Rate 0 (`ccix_esm_data_rate_0`)
- ❖ ESM Perform Calibration (`perform_calibration`)
- ❖ ESM Data Rate 1 (`ccix_esm_data_rate_1`)
- ❖ ESM Enable (`ccix_esm_enable`)
- ❖ ESM Extended Equalization Phase2 Timeout  
(`ccix_esm_extended_equalization_phase2_timeout`)
- ❖ ESM Extended Equalization Phase3 Timeout  
(`ccix_esm_extended_equalization_phase3_timeout`)
- ❖ Link Reach Target (`link_reach_target`)
- ❖ Quick Equalization Timeout Select (`ccix_quick_eq_timeout_select`)



This sequence should be run on the PHY layer sequencer.

### Example 20-1

```
svt_PCIE_pl_service_ccix_configure_esm_sequence esm_seq;
`uvm_do_on_with(
    ep_esm_seq,
    p_sequencer.endpoint_virt_seqr.pcie_virt_seqr.pl_seqr,
    { ccix_esm_enable == 1;
      ccix_esm_data_rate_0 == <ccix_esm_data_rate_0>;
      ccix_esm_data_rate_1 == <ccix_esm_data_rate_1>;
      ccix_quick_equalization_timeout_select ==
<ccix_quick_equalization_timeout_select>;
      ccix_esm_extended_equalization_phase2_timeout == <phase2_timeout>;
      ccix_esm_extended_equalization_phase3_timeout == <phase3_timeout>;
    }
)
```

The model implements calibration only as a timeout of the configured duration, with completion indicated in the status class – triggering calibration has no other effect. When `perform_calibration` is set, the timer is initiated after the model enters L1.

When configured as a root complex, the model initiates link training any time this sequence is executed with `ccix_esm_enable` set to 1. A testbench using this sequence should expect the subsequent transition to Recovery.

The model provides the following CCIX ESM status attributes in `svt_PCIE_Pl_Status`:

- ❖ `ccix_esm_current_data_rate`
- ❖ `ccix_esm_perform_calibration`
- ❖ `ccix_esm_calibration_done`

For more information about CCIX-related attributes, see [HTML class reference documentation](#).

#### 20.4.2.2 Configuration for PIPE Interface

There is currently no industry specification for CCIX use over the PIPE interface. The VIP implements the CCIX interface of the Synopsys DWC Controller. This interface uses MBI to communicate commands and status.

In addition, the VIP adds encodings of `pclk_rate` and `width` in its configuration class (`svt_PCIE_Pl_Configuration`), to support operation at 20G and 25G rates using the PIPE interface.

For 2.5G, 5G, 8G and 16G rates, the `pclk_rate` and `width` combinations are same as the existing use model. For 20G and 25G rates, the VIP provides following additional attributes.

- ❖ `svt_PCIE_Pl_Configuration::pclk_rate[5]` and `svt_PCIE_Pl_Configuration::pclk_rate[6]` for 20G and 25G respectively.

Allowed enum values for 20G are:

- ◆ `svt_PCIE_Pl_Configuration::PCLK_625_MHZ`
- ◆ `svt_PCIE_Pl_Configuration::PCLK_1250_MHZ`
- ◆ `svt_PCIE_Pl_Configuration::PCLK_2500_MHZ`

Allowed enum values for 25G are:

- ◆ `svt_PCIE_Pl_Configuration::PCLK_781_25_MHZ`
- ◆ `svt_PCIE_Pl_Configuration::PCLK_1562_5_MHZ`
- ◆ `svt_PCIE_Pl_Configuration::PCLK_3125_MHZ`

- ❖ `svt_PCIE_Pl_Configuration::width[5]` and `svt_PCIE_Pl_Configuration::width[6]` for 20G and 25G respectively.

Allowed enum values for both 20G and 25G are:

- ◆ `svt_PCIE_Pl_Configuration::PIPE_8_BITS`
- ◆ `svt_PCIE_Pl_Configuration::PIPE_16_BITS`
- ◆ `svt_PCIE_Pl_Configuration::PIPE_32_BITS`

When configured for MPIPE operation, the `CCIX_CONFIGURE_ESM` service also initiates Write Committed commands with the configured values to PHY registers (ESM Rate0, ESM Rate1, ESM Control, and ESM Link Reach Target) over MBI. If the VIP is configured as root and ESM Enable bit is set, then VIP verifies that Write ACK is received for the Write Committed command before initiating the link retraining.

When configured for SPIPE operation, if configured as root and the ESM Enable bit is set to 1, then VIP initiates link retraining only after the remote partner has completed the ESM Enable handshake with SPIPE over MBI.



Calibration is not supported in PIPE mode.

## 20.5 Support for CCIX Optimized TLP Format

### 20.5.1 Enabling Optimized TLP Format

To enable CCIX Optimized TLP format, set each of the following configuration attributes to 1:

- ❖ `svt_PCIE_Configuration::is_ccix_transaction_layer`
- ❖ `svt_PCIE_TL_Configuration::enable_ccix_optimized_tlp`

### 20.5.2 Configuring VC for Optimized TLP Traffic

To configure the VC to be used for exchanging Optimized TLPs, set the following configuration attribute:

`svt_PCIE_TL_Configuration::ccix_vc`

If this attribute is set to 0, the model will use the highest enabled VC for Optimized TLP traffic.

The model does not support the use of VC0 or TC0 for Optimized TLP traffic. Although the specification does not permit mapping multiple TCs to the designated VC for Optimized TLP traffic, the model supports this.

### 20.5.3 Sending Optimized TLPs

To transmit CCIX Optimized TLPs, use the sequence `svt_PCIE_TLP_ccix_optimized_tlp_sequence` defined in `svt_PCIE_TLP_Sequence_Collection.sv` on the TLP sequencer.

#### Example 20-2

```
svt_PCIE_TLP_ccix_optimized_tlp_sequence optimized_tlp_sequence;
uvm_do_on_with(optimized_tlp_sequence,
    vip_seqr_PCIE_virt_seqr.tlp_seqr,
    { traffic_class == 3;
        ccix_byte0_bit5_to_byte1_bit7 == 7'h0;
        ccix_byte1_bit3_to_byte3_bit7 == 13'h0;
        length = 1;
    })
```

### 20.5.4 Receiving Optimized TLPs

CCIX Optimized TLPs received by the transaction layer can be checked via output port or callback. Optimized TLPs are not forwarded to the Target Application and consequently are not accessible by the normal mechanisms for TLPs it receives.

The output port for received TLPs in `svt_PCIE_TL` is `rx_tlp_out_port`. This is a blocking put port (in UVM, the type is `uvm_blocking_put_port`) for the `svt_PCIE_TLP` type. The following example shows the code that connects the port to a blocking put implementation and prints all received TLPs.

#### Example 20-3

```
class example_blocking_put_imp extends uvm_component;
    ...
    //Declare the blocking put implementation
    uvm_blocking_put_imp #(svt_PCIE_TLP, example_blocking_put_imp) rx_tlp_in_export;

    function new( string name, uvm_component parent );
        super.new( name, parent );
        rx_tlp_in_export = new("rx_tlp_in_export", this);
    endfunction
```

```

//Implement the put task that will be connected to the vip's output port
virtual task put( svt_PCIE_tlp t );
    //Print all received TLPs
    t.print();
endtask
endclass

//In test, declare instance of the class with the blocking put implementation
example_blocking_put_imp rcvd_tlp_port;

//In build_phase, create instance:
rcvd_tlp_port = new( "rcvd_tlp_port", this );

//In connect_phase, connect the vip's put port to the test's put implementation:
<vip instance>.tl.rx_tlp_out_port.connect(rcvd_tlp_port.rx_tlp_in_export);

```

The callback to access TLPs received by the transaction layer is `pre_tlp_out_put` in the `svt_PCIE_t1_callbacks` class. For example, this implementation would print all received TLPs.

#### Example 20-4

```

class example_t1_callback extends svt_PCIE_t1_callback;
    ...
    /**
     *Callback issued by the component once the TLP is received completely and
     *prior to putting received TLP on the rx port.
     */
    *@param tl: A reference to the component object issuing this callback.
    *@param tlp: A reference to the svt_PCIE_tlp descriptor object of interest.
    *@param drop: A reference bit which indicates to drop the transaction when set to 1.
    */
    virtual function void pre_tlp_out_put(svt_PCIE_t1 tl, svt_PCIE_tlp tlp, ref bit drop);
        //Print all received TLPs
        tlp.print();
    endfunction

endclass //ccix_esm_rc_t1_callback

```

The callback occurs immediately before the transaction is pushed to the output port. If the drop bit is set in the callback, the transaction will not be pushed to the output port, but the model will otherwise be unaffected.

#### 20.5.5 Transaction Logging of Optimized TLPs

Display of optimized TLPs in the transaction log is done automatically when optimized TLPs are enabled. No other enable is required. The TLP Type field is set to `CCIX_OPT`, and only the fields that are defined for Optimized TLPs are specified.

**Example 20-5**

| Reporter | Start Time (ns) | End Time (ns) | D | I                    | Address      | BE ST         | Len                                                | E        | ECRC   | LCRC                                                      | TX/RX Status |
|----------|-----------------|---------------|---|----------------------|--------------|---------------|----------------------------------------------------|----------|--------|-----------------------------------------------------------|--------------|
|          |                 |               | I | TLP Type R DLLP Type | Seq Num VC H | P D R N HdrFC | Reg#/MsgRt/Cpl DataFC                              | BC MCode | Idx DW | Prefix (P) / Header (H) / Data (D)<br>(All values in Hex) | P            |
| spd_1    | 52147.000       | 52150.000     | R | CCIX_OPT             | 2            | 5             | 3 (H) 10572303<br>0 (D) c5efe409 4888b941 72095bfa | ----     | ----   | ----                                                      | 0x4cd42071   |

## 20.6 Limitations

Following are the limitations of CCIX feature:

- ❖ CCIX support is only available when using PCIe SVT Unified model.
- ❖ The Driver Application does not support sending CCIX Optimized TLPs. They must be injected into the model via the transaction layer as described in this chapter.
- ❖ The Target Application does not receive CCIX Optimized TLPs. A testbench that requires access to received Optimized TLPs must do so via the transaction layer.
- ❖ The model does not automatically assign CCIX Optimized TLPs the highest priority over other VC traffic. However, the VC arbitration scheme is configurable and can support this prioritization.
- ❖ EQ Bypass is not supported when CCIX ESM is enabled.
- ❖ When using the PIPE interface:
  - ◆ CCIX ESM with PCLK as PHY input is not supported.
  - ◆ Calibration is optional and not supported.
  - ◆ Retimer is not supported with CCIX ESM.
  - ◆ VIP works only with SNPS DWC Controller 5.20a version and later.

# A PCIe PIPE Interface

---

This chapter provides the detailed list of all the signal widths and associated macros present in PIPE interface `svt_PCIE_PIPE_if` and PIPE5 interface `svt_PCIE_PIPE5_if`.

This chapter discusses the following topics:

- ❖ PIPE Interface Specifications
- ❖ Configuring the PIPE Data Bus Width
- ❖ PIPE Coefficient Use

## A.1 PIPE Interface Specifications

[Table A-1](#) lists the control macros for PIPE interfaces `svt_PCIE_PIPE_if` and `svt_PCIE_PIPE5_if`.

**Table A-1 Control Macros for PIPE Interfaces**

| Control Macros for Signal Widths                  | <code>svt_PCIE_PIPE_if</code> * |                             | <code>svt_PCIE_PIPE5_if</code> ** |                             |
|---------------------------------------------------|---------------------------------|-----------------------------|-----------------------------------|-----------------------------|
|                                                   | Default Value                   | Additional Supported Values | Default Value                     | Additional Supported Values |
| <code>SVT_PCIE_PIPE_DATA_WIDTH</code>             | 32                              | 64                          | 32                                | 64, 40, 80                  |
| <code>SVT_PCIE_PIPE_DATAK_WIDTH</code>            | 4                               | None                        | 4                                 | 8                           |
| <code>SVT_PCIE_PIPE_TXELECIDL_WIDTH</code>        | 1                               | None                        | 4                                 | None                        |
| <code>SVT_PCIE_PIPE_SYNCHDR_WIDTH</code>          | 2                               | None                        | 2                                 | None                        |
| <code>SVT_PCIE_PIPE_RATE_WIDTH</code>             | 2                               | 3                           | 4                                 | None                        |
| <code>SVT_PCIE_PIPE_WIDTH_WIDTH</code>            | 2                               | None                        | 2                                 | None                        |
| <code>SVT_PCIE_PIPE_PCLKRATE_WIDTH</code>         | 3                               | 4                           | 5                                 | None                        |
| <code>SVT_PCIE_PIPE_MBI_WIDTH</code>              | 8                               | None                        | 8                                 | None                        |
| <code>SVT_PCIE_PIPE_LOCALPRESETINDEX_WIDTH</code> | 5                               | 6                           | NA                                |                             |

**Table A-1 Control Macros (Continued)for PIPE Interfaces**

| Control Macros for Signal Widths | svt_PCIE_PIPE_if * |                             | svt_PCIE_PIPE5_if ** |                             |
|----------------------------------|--------------------|-----------------------------|----------------------|-----------------------------|
|                                  | Default Value      | Additional Supported Values | Default Value        | Additional Supported Values |
| SVT_PCIE_PIPE_PHYMODE_WIDTH      | NA                 |                             | 4                    | None                        |

\* Used when PCIe specification version is 4.0 or earlier and PIPE specification version is 4.4 or earlier or when using custom enhancements.

\*\* Used only when PCIe specification version is 5.0 and later and PIPE specification version is 5.0 and later.

[Table A-2](#) lists the signals for PIPE interfaces svt\_PCIE\_PIPE\_if and svt\_PCIE\_PIPE5\_if.

**Table A-2 Signals for PIPE Interfaces**

| Signal Name                | svt_PCIE_PIPE_if * |       | svt_PCIE_PIPE5_if ** |       |
|----------------------------|--------------------|-------|----------------------|-------|
|                            | Shared/per lane    | Width | Shared/per lane      | Width |
| clkreq_n                   | shared             | 1     | shared               | 1     |
| wake_n                     | shared             | 1     | shared               | 1     |
| reset                      | shared             | 1     | shared               | 1     |
| max_pclk                   | shared             | 1     | shared               | 1     |
| pclk                       | shared             | 1     | Not available        |       |
| pclk_<ln_num>              | per lane           | 1     | per lane             | 1     |
| pipe_reset_n               | shared             | 1     | Not available        |       |
| pipe_reset_n_<ln_num>      | Not available      |       | optional             | 1     |
| block_align_control        | shared             | 1     | Not available        |       |
| sris_enable_<ln_num>       | per lane           | 1     | per lane             | 1     |
| phy_status_<ln_num>        | per lane           | 1     | per lane             | 1     |
| elasticity_buffer_mode     | shared             | 1     | Not available        |       |
| rx_standby_<ln_num>        | per lane           | 1     | per lane             | 1     |
| rx_standby_status_<ln_num> | per lane           | 1     | per lane             | 1     |
| pclk_change_ok             | shared             | 1     | Not available        |       |
| pclk_change_ok_<ln_num>    | Not available      |       | per lane             | 1     |
| pclk_change_ack            | shared             | 1     | Not available        |       |
| pclk_change_ack_<ln_num>   | Not available      |       | per lane             | 1     |
| async_power_change_ack     | shared             | 1     | Not available        |       |

**Table A-2 Signals for PIPE Interfaces (Continued)**

| Signal Name                     | svt_pcie_pipe_if * |                              | svt_pcie_pipe5_if ** |                              |
|---------------------------------|--------------------|------------------------------|----------------------|------------------------------|
|                                 | Shared/per lane    | Width                        | Shared/per lane      | Width                        |
| async_power_change_ack_<ln_num> | Not available      |                              | per lane             | 1                            |
| txdetectrx_loopback             | shared             | 1                            | Not available        |                              |
| txdetectrx_loopback_<ln_num>    | Not available      |                              | optional             | 1                            |
| power_down                      | shared             | 4                            | Not available        |                              |
| power_down_<ln_num>             | Not available      |                              | per lane             | 4                            |
| rate                            | shared             | SVT_PCIE_PIPE_RATE_WIDTH     | Not available        |                              |
| rate_<ln_num>                   | Not available      |                              | optional             | SVT_PCIE_PIPE_RATE_WIDTH     |
| width                           | shared             | SVT_PCIE_PIPE_WIDTH_WIDTH    | Not available        |                              |
| width_<ln_num>                  | Not available      |                              | optional             | SVT_PCIE_PIPE_WIDTH_WIDTH    |
| pclk_rate                       | shared             | SVT_PCIE_PIPE_PCLKRATE_WIDTH | Not available        |                              |
| pclk_rate_<ln_num>              | Not available      |                              | optional             | SVT_PCIE_PIPE_PCLKRATE_WIDTH |
| data_bus_width                  | shared             | SVT_PCIE_PIPE_WIDTH_WIDTH    | Not available        |                              |
| data_bus_width_<ln_num>         | Not available      |                              | optional             | SVT_PCIE_PIPE_WIDTH_WIDTH    |
| rx_eidetect_disable             | shared             | 1                            | Not available        |                              |
| rx_eidetect_disable_<ln_num>    | Not available      |                              | optional             | 1                            |
| tx_commonmode_disable           | shared             | 1                            | Not available        |                              |
| tx_commonmode_disable_<ln_num>  | Not available      |                              | optional             | 1                            |
| tx_data_<ln_num>                | per lane           | SVT_PCIE_PIPE_DATA_WIDTH     | per lane             | SVT_PCIE_PIPE_DATA_WIDTH     |
| tx_data_k_<ln_num>              | per lane           | SVT_PCIE_PIPE_DATAK_WIDTH    | per lane             | SVT_PCIE_PIPE_DATAK_WIDTH    |

**Table A-2 Signals for PIPE Interfaces (Continued)**

| Signal Name                | svt_pcie_pipe_if * |                                 | svt_pcie_pipe5_if ** |                                 |
|----------------------------|--------------------|---------------------------------|----------------------|---------------------------------|
|                            | Shared/per lane    | Width                           | Shared/per lane      | Width                           |
| rx_data_<ln_num>           | per lane           | SVT_PCIE_PIPE_DATA_WIDTH        | per lane             | SVT_PCIE_PIPE_DATA_WIDTH        |
| rx_data_k_<ln_num>         | per lane           | SVT_PCIE_PIPE_DATAK_WIDTH       | per lane             | SVT_PCIE_PIPE_DATAK_WIDTH       |
| tx_data_valid_<ln_num>     | per lane           | 1                               | per lane             | 1                               |
| tx_start_block_<ln_num>    | per lane           | 1                               | per lane             | 1                               |
| tx_sync_header_<ln_num>    | per lane           | SVT_PCIE_PIPE_SYNCHDR_WIDT H    | per lane             | SVT_PCIE_PIPE_SYNCHDR_WIDT H    |
| tx_elec_idle_<ln_num>      | per lane           | SVT_PCIE_PIPE_TXELECidle_WIDT H | per lane             | SVT_PCIE_PIPE_TXELECidle_WIDT H |
| tx_compliance_<ln_num>     | per lane           | 1                               | per lane             | 1                               |
| rx_valid_<ln_num>          | per lane           | 1                               | per lane             | 1                               |
| rx_data_valid_<ln_num>     | per lane           | 1                               | per lane             | 1                               |
| rx_start_block_<ln_num>    | per lane           | 1                               | per lane             | 1                               |
| rx_sync_header_<ln_num>    | per lane           | SVT_PCIE_PIPE_SYNCHDR_WIDT H    | per lane             | SVT_PCIE_PIPE_SYNCHDR_WIDT H    |
| rx_elec_idle_<ln_num>      | per lane           | 1                               | per lane             | 1                               |
| rx_status_<ln_num>         | per lane           | 3                               | per lane             | 3                               |
| rx_polarity_<ln_num>       | per lane           | 1                               | Not available        |                                 |
| m2p_message_bus_<ln_num>   | per lane           | SVT_PCIE_PIPE_MBI_WIDTH         | per lane             | SVT_PCIE_PIPE_MBI_WIDTH         |
| p2m_message_bus_<ln_num>   | per lane           | SVT_PCIE_PIPE_MBI_WIDTH         | per lane             | SVT_PCIE_PIPE_MBI_WIDTH         |
| phy_mode_<ln_num>          | Not available      |                                 | per lane             | SVT_PCIE_PIPE_PHYMODE_WIDT H    |
| rxclk_<ln_num>             | Not available      |                                 | per lane             | 1                               |
| serdes_arch                | Not available      |                                 | shared               | 1                               |
| refclk_required_n_<ln_num> | Not available      |                                 | per lane             | 1                               |

**Table A-2 Signals for PIPE Interfaces (Continued)**

| Signal Name                                        | svt_PCIE_PIPE_if *     |       | svt_PCIE_PIPE5_if ** |                           |
|----------------------------------------------------|------------------------|-------|----------------------|---------------------------|
|                                                    | Shared/per lane        | Width | Shared/per lane      | Width                     |
| rx_width_<ln_num>                                  | Not available          |       | optional             | SVT_PCIE_PIPE_WIDTH_WIDTH |
| tx_swing                                           | shared                 | 1     | Not available        |                           |
| tx_margin                                          | shared                 | 3     | Not available        |                           |
| lf                                                 | Available but not used |       | Not available        |                           |
| fs                                                 | Available but not used |       | Not available        |                           |
| lf_<ln_num>                                        | per lane               | 6     | Not available        |                           |
| fs_<ln_num>                                        | per lane               | 6     | Not available        |                           |
| get_local_preset_coefficients_<ln_num>             | per lane               | 1     | Not available        |                           |
| local_tx_coefficients_valid_<ln_num>               | per lane               | 1     | Not available        |                           |
| local_tx_preset_coefficients_<ln_num>              | per lane               | 18    | Not available        |                           |
| local_fs_<ln_num>                                  | per lane               | 6     | Not available        |                           |
| local_lf_<ln_num>                                  | per lane               | 6     | Not available        |                           |
| local_preset_index_<ln_num>                        | per lane               | 5     | Not available        |                           |
| rx_eq_in_progress_<ln_num>                         | per lane               | 1     | Not available        |                           |
| rx_preset_hint_<ln_num>                            | per lane               | 3     | Not available        |                           |
| rx_eq_eval_<ln_num>                                | per lane               | 1     | Not available        |                           |
| link_evaluation_feedback_figure_merit_<ln_num>     | per lane               | 8     | Not available        |                           |
| link_evaluation_feedback_direction_change_<ln_num> | per lane               | 6     | Not available        |                           |
| invalid_request_<ln_num>                           | per lane               | 1     | Not available        |                           |
| tx_deemph_<ln_num>                                 | per lane               | 18    | Not available        |                           |

\* Used when PCIe specification version is 4.0 or earlier and PIPE specification version is 4.4 or earlier or when using custom enhancements.

\*\* Used only when PCIe specification version is 5.0 and later and PIPE specification version is 5.0 and later.

**Table A-3:** VIP Supports the following PCLK rates and data widths for PIPE 4.3, and PIPE 4.4 specifications:

**Table A-3 PCLK Rates and Data Widths in PIPE 4.3, 4.4 Specifications**

| Speed    | PCLK     | PIPE Data Width       |
|----------|----------|-----------------------|
| 2.5 GT/s | 2000 MHz | 8 bits <sup>*1</sup>  |
| 2.5 GT/s | 1000 MHz | 8 bits <sup>1</sup>   |
| 2.5 GT/s | 500 MHz  | 8 bits <sup>1</sup>   |
| 2.5 GT/s | 250 MHz  | 8 bits                |
| 2.5 GT/s | 1000 MHz | 16 bits <sup>*1</sup> |
| 2.5 GT/s | 250 MHz  | 16 bits <sup>1</sup>  |
| 2.5 GT/s | 500 MHz  | 16 bits <sup>1</sup>  |
| 2.5 GT/s | 125 MHz  | 16 bits               |
| 2.5 GT/s | 1000 MHz | 32 bits <sup>*1</sup> |
| 2.5 GT/s | 250 MHz  | 32 bits <sup>1</sup>  |
| 2.5 GT/s | 62.5 MHz | 32 bits               |
| 5.0 GT/s | 2000 MHz | 8 bits <sup>*1</sup>  |
| 5.0 GT/s | 1000 MHz | 8 bits <sup>1</sup>   |
| 5.0 GT/s | 500 MHz  | 8 bits                |
| 5.0 GT/s | 1000 MHz | 16 bits <sup>*1</sup> |
| 5.0 GT/s | 500 MHz  | 16 bits <sup>1</sup>  |
| 5.0 GT/s | 250 MHz  | 16 bits               |
| 5.0 GT/s | 1000 MHz | 32 bits <sup>*1</sup> |
| 5.0 GT/s | 250 MHz  | 32 bits <sup>1</sup>  |
| 5.0 GT/s | 125 MHz  | 32 bits               |
| 8.0 GT/s | 2000 MHz | 8 bits <sup>1</sup>   |
| 8.0 GT/s | 2000 MHz | 16 bits <sup>*1</sup> |
| 8.0 GT/s | 1000 MHz | 8 bits                |
| 8.0 GT/s | 1000 MHz | 16 bits <sup>1</sup>  |
| 8.0 GT/s | 500 MHz  | 16 bits               |
| 8.0 GT/s | 1000 MHz | 32 bits <sup>*1</sup> |
| 8.0 GT/s | 500 MHz  | 32 bits <sup>1</sup>  |
| 8.0 GT/s | 250 MHz  | 32 bits               |

**Table A-3 PCLK Rates and Data Widths in PIPE 4.3, 4.4 Specifications (Continued)**

| <b>Speed</b> | <b>PCLK</b> | <b>PIPE Data Width</b> |
|--------------|-------------|------------------------|
| 8.0 GT/s     | 125 MHz     | 64 bits*               |
| 16.0 GT/s    | 2000 MHz    | 8 bits                 |
| 16.0 GT/s    | 2000 MHz    | 16 bits* <sup>1</sup>  |
| 16.0 GT/s    | 2000 MHz    | 32 bits* <sup>1</sup>  |
| 16.0 GT/s    | 1000 MHz    | 16 bits                |
| 16.0 GT/s    | 1000 MHz    | 32 bits* <sup>1</sup>  |
| 16.0 GT/s    | 500 MHz     | 32 bits                |
| 16.0 GT/s    | 250 MHz     | 64 bits*               |
| 32.0 GT/s    | 4000 MHz    | 8 bits*                |
| 32.0 GT/s    | 2000 MHz    | 16 bits*               |
| 32.0 GT/s    | 1000 MHz    | 32 bits*               |
| 32.0 GT/s    | 500 MHz     | 64 bits*               |

• <sup>1</sup> Indicates data throttling mode.  
 • \* Indicates the combination is outside of PIPE 4.3 and 4.4 specification.  
   - \*<sup>1</sup> Indicates the data throttling modes that are outside of PIPE specification. These customized combinations are supported only when `enable_custom_data_throttling_mode` attribute of `svt_PCIE_pl_configuration` is set to 1.  
   - Gen5 combinations are supported with PIPE 4.4 only when `enable_gen5_using_pipe_4_4` attribute of `svt_PCIE_pl_configuration` is set to 1.  
   - 64-bit PIPE data bus width is supported at Gen3, Gen4, and Gen5 speeds only when the `SVT_PCIE_PIPE_DATA_WIDTH` macro is set to 64.

**Table A-4: VIP Supports the following PCLK rates and data widths in PIPE traditional architecture mode for PIPE 5.1 specifications:****Table A-4 PCLK Rates and Data Widths in PIPE 5.1 Traditional Architecture Mode**

| <b>Speed</b> | <b>PCLK</b> | <b>PIPE Data Width</b> |
|--------------|-------------|------------------------|
| 2.5 GT/s     | 4000 MHz    | 8 bits <sup>1</sup>    |
| 2.5 GT/s     | 2000 MHz    | 8 bits <sup>1</sup>    |
| 2.5 GT/s     | 1000 MHz    | 8 bits <sup>1</sup>    |
| 2.5 GT/s     | 500 MHz     | 8 bits <sup>1</sup>    |
| 2.5 GT/s     | 250 MHz     | 8 bits                 |
| 2.5 GT/s     | 1000 MHz    | 16 bits* <sup>1</sup>  |

**Table A-4 PCLK Rates and Data Widths in PIPE 5.1 Traditional Architecture Mode (Continued)**

| Speed     | PCLK      | PIPE Data Width       |
|-----------|-----------|-----------------------|
| 2.5 GT/s  | 250 MHz   | 16 bits <sup>1</sup>  |
| 2.5 GT/s  | 500 MHz   | 16 bits <sup>1</sup>  |
| 2.5 GT/s  | 125 MHz   | 16 bits               |
| 2.5 GT/s  | 1000 MHz  | 32 bits* <sup>1</sup> |
| 2.5 GT/s  | 250 MHz   | 32 bits <sup>1</sup>  |
| 2.5 GT/s  | 62.5 MHz  | 32 bits               |
| 2.5 GT/s  | 31.25 MHz | 64 bits*              |
| 5.0 GT/s  | 4000 MHz  | 8 bits <sup>1</sup>   |
| 5.0 GT/s  | 2000 MHz  | 8 bits <sup>1</sup>   |
| 5.0 GT/s  | 1000 MHz  | 8 bits <sup>1</sup>   |
| 5.0 GT/s  | 500 MHz   | 8 bits                |
| 5.0 GT/s  | 1000 MHz  | 16 bits* <sup>1</sup> |
| 5.0 GT/s  | 500 MHz   | 16 bits <sup>1</sup>  |
| 5.0 GT/s  | 250 MHz   | 16 bits               |
| 5.0 GT/s  | 1000 MHz  | 32 bits* <sup>1</sup> |
| 5.0 GT/s  | 250 MHz   | 32 bits <sup>1</sup>  |
| 5.0 GT/s  | 125 MHz   | 32 bits               |
| 5.0 GT/s  | 62.5 MHz  | 64 bits*              |
| 8.0 GT/s  | 4000 MHz  | 8 bits <sup>1</sup>   |
| 8.0 GT/s  | 2000 MHz  | 8 bits <sup>1</sup>   |
| 8.0 GT/s  | 2000 MHz  | 16 bits* <sup>1</sup> |
| 8.0 GT/s  | 1000 MHz  | 8 bits                |
| 8.0 GT/s  | 1000 MHz  | 16 bits <sup>1</sup>  |
| 8.0 GT/s  | 500 MHz   | 16 bits               |
| 8.0 GT/s  | 1000 MHz  | 32 bits* <sup>1</sup> |
| 8.0 GT/s  | 500 MHz   | 32 bits <sup>1</sup>  |
| 8.0 GT/s  | 250 MHz   | 32 bits               |
| 8.0 GT/s  | 125 MHz   | 64 bits*              |
| 16.0 GT/s | 4000 MHz  | 8 bits <sup>1</sup>   |

**Table A-4 PCLK Rates and Data Widths in PIPE 5.1 Traditional Architecture Mode (Continued)**

| <b>Speed</b> | <b>PCLK</b> | <b>PIPE Data Width</b> |
|--------------|-------------|------------------------|
| 16.0 GT/s    | 2000 MHz    | 8 bits                 |
| 16.0 GT/s    | 2000 MHz    | 16 bits <sup>*1</sup>  |
| 16.0 GT/s    | 2000 MHz    | 32 bits <sup>*1</sup>  |
| 16.0 GT/s    | 1000 MHz    | 16 bits                |
| 16.0 GT/s    | 1000 MHz    | 32 bits <sup>*1</sup>  |
| 16.0 GT/s    | 500 MHz     | 32 bits                |
| 16.0 GT/s    | 250 MHz     | 64 bits*               |
| 32.0 GT/s    | 4000 MHz    | 8 bits                 |
| 32.0 GT/s    | 2000 MHz    | 16 bits                |
| 32.0 GT/s    | 1000 MHz    | 32 bits                |
| 32.0 GT/s    | 500 MHz     | 64 bits*               |

• <sup>1</sup> Indicates data throttling mode.  
 • \* Indicates the combination is outside of PIPE 5.1 specification.  
   - <sup>\*1</sup> Indicates the data throttling modes that are outside of PIPE specification. These customized combinations are supported only when `enable_custom_data_throttling_mode` attribute of `svt_PCIE_pl_configuration` is set to 1.  
   - 64-bit PIPE data bus width is supported when the `SVT_PCIE_PIPE_DATA_WIDTH` macro is set to 64 and `SVT_PCIE_PIPE_DATAK_WIDTH` macro is set to 8.

**Table A-5: VIP Supports following PCLK rates and data widths on the Tx path in PIPE SerDes architecture mode for PIPE 5.1 specification:****Table A-5 PCLK Rates and Data Widths on the Tx Path in PIPE SerDes Architecture Mode**

| <b>Speed</b> | <b>PCLK</b> | <b>SerDes Data Width</b> |
|--------------|-------------|--------------------------|
| 2.5 GT/s     | 4000 MHz    | 10 bits <sup>1</sup>     |
| 2.5 GT/s     | 2000 MHz    | 10 bits <sup>1</sup>     |
| 2.5 GT/s     | 1000 MHz    | 10 bits <sup>1</sup>     |
| 2.5 GT/s     | 500 MHz     | 10 bits <sup>1</sup>     |
| 2.5 GT/s     | 250 MHz     | 10 bits                  |
| 2.5 GT/s     | 1000 MHz    | 20 bits <sup>*1</sup>    |
| 2.5 GT/s     | 250 MHz     | 20 bits <sup>1</sup>     |
| 2.5 GT/s     | 500 MHz     | 20 bits <sup>1</sup>     |
| 2.5 GT/s     | 125 MHz     | 20 bits                  |

**Table A-5 PCLK Rates and Data Widths on the Tx Path in PIPE SerDes Architecture Mode (Continued)**

| Speed     | PCLK      | SerDes Data Width     |
|-----------|-----------|-----------------------|
| 2.5 GT/s  | 1000 MHz  | 40 bits <sup>*1</sup> |
| 2.5 GT/s  | 250 MHz   | 40 bits <sup>1</sup>  |
| 2.5 GT/s  | 62.5 MHz  | 40 bits               |
| 2.5 GT/s  | 31.25 MHz | 80 bits               |
| 5.0 GT/s  | 4000 MHz  | 10 bits <sup>1</sup>  |
| 5.0 GT/s  | 2000 MHz  | 10 bits <sup>1</sup>  |
| 5.0 GT/s  | 1000 MHz  | 10 bits <sup>1</sup>  |
| 5.0 GT/s  | 500 MHz   | 10 bits               |
| 5.0 GT/s  | 1000 MHz  | 20 bits <sup>*1</sup> |
| 5.0 GT/s  | 500 MHz   | 20 bits <sup>1</sup>  |
| 5.0 GT/s  | 250 MHz   | 20 bits               |
| 5.0 GT/s  | 1000 MHz  | 40 bits <sup>*1</sup> |
| 5.0 GT/s  | 250 MHz   | 40 bits <sup>1</sup>  |
| 5.0 GT/s  | 125 MHz   | 40 bits               |
| 5.0 GT/s  | 62.5 MHz  | 80 bits               |
| 8.0 GT/s  | 4000 MHz  | 10 bits <sup>1</sup>  |
| 8.0 GT/s  | 2000 MHz  | 10 bits <sup>1</sup>  |
| 8.0 GT/s  | 2000 MHz  | 20 bits <sup>*1</sup> |
| 8.0 GT/s  | 1000 MHz  | 10 bits               |
| 8.0 GT/s  | 1000 MHz  | 20 bits <sup>1</sup>  |
| 8.0 GT/s  | 500 MHz   | 20 bits               |
| 8.0 GT/s  | 1000 MHz  | 40 bits <sup>*1</sup> |
| 8.0 GT/s  | 500 MHz   | 40 bits <sup>1</sup>  |
| 8.0 GT/s  | 250 MHz   | 40 bits               |
| 8.0 GT/s  | 125 MHz   | 80 bits               |
| 16.0 GT/s | 4000 MHz  | 10 bits <sup>1</sup>  |
| 16.0 GT/s | 2000 MHz  | 10 bits               |
| 16.0 GT/s | 2000 MHz  | 20 bits <sup>*1</sup> |
| 16.0 GT/s | 2000 MHz  | 40 bits <sup>*1</sup> |

**Table A-5 PCLK Rates and Data Widths on the Tx Path in PIPE SerDes Architecture Mode (Continued)**

| <b>Speed</b> | <b>PCLK</b> | <b>SerDes Data Width</b> |
|--------------|-------------|--------------------------|
| 16.0 GT/s    | 1000 MHz    | 20 bits                  |
| 16.0 GT/s    | 1000 MHz    | 40 bits <sup>*1</sup>    |
| 16.0 GT/s    | 500 MHz     | 40 bits                  |
| 16.0 GT/s    | 250 MHz     | 80 bits                  |
| 32.0 GT/s    | 4000 MHz    | 10 bits                  |
| 32.0 GT/s    | 2000 MHz    | 20 bits                  |
| 32.0 GT/s    | 1000 MHz    | 40 bits                  |
| 32.0 GT/s    | 500 MHz     | 80 bits                  |

• <sup>1</sup> Indicates data throttling mode.  
 • \* Indicates the combination is outside of PIPE 5.1 specification.  
 - <sup>\*1</sup> Indicates the data throttling modes that are outside of PIPE specification. These customized combinations are supported only when `enable_custom_data_throttling_mode` attribute of `svt_PCIE_pl_configuration` is set to 1.

**Table A-6: VIP Supports following RxCLK rates and RxWidths on the Rx path in PIPE SerDes architecture mode for PIPE 5.1 specification:****Table A-6 RxCLK rates and RxWidths on the Rx Path in PIPE SerDes Architecture Mode**

| <b>Speed</b> | <b>RxCLK</b> | <b>RxWidth</b> |
|--------------|--------------|----------------|
| 2.5 GT/s     | 250 MHz      | 10 bits        |
| 2.5 GT/s     | 125 MHz      | 20 bits        |
| 2.5 GT/s     | 62.5 MHz     | 40 bits        |
| 2.5 GT/s     | 31.25 MHz    | 80 bits        |
| 5.0 GT/s     | 500 MHz      | 10 bits        |
| 5.0 GT/s     | 250 MHz      | 20 bits        |
| 5.0 GT/s     | 125 MHz      | 40 bits        |
| 5.0 GT/s     | 62.5 MHz     | 80 bits        |
| 8.0 GT/s     | 1000 MHz     | 10 bits        |
| 8.0 GT/s     | 500 MHz      | 20 bits        |
| 8.0 GT/s     | 250 MHz      | 40 bits        |
| 8.0 GT/s     | 125 MHz      | 80 bits        |
| 16.0 GT/s    | 2000 MHz     | 10 bits        |
| 16.0 GT/s    | 1000 MHz     | 20 bits        |

**Table A-6 RxCLK rates and RxWidths on the Rx Path in PIPE SerDes Architecture Mode (Continued)**

| <b>Speed</b> | <b>RxCLK</b> | <b>RxWidth</b> |
|--------------|--------------|----------------|
| 16.0 GT/s    | 500 MHz      | 40 bits        |
| 16.0 GT/s    | 250 MHz      | 80 bits        |
| 32.0 GT/s    | 4000 MHz     | 10 bits        |
| 32.0 GT/s    | 2000 MHz     | 20 bits        |
| 32.0 GT/s    | 1000 MHz     | 40 bits        |
| 32.0 GT/s    | 500 MHz      | 80 bits        |

## A.2 Configuring the PIPE Data Bus Width

### A.2.1 PIPE 2.1/3

In PIPE 2.1 and PIPE 3.0 spec versions, the MAC does not specify the per-lane width and rate of the PIPE clock. For *\*mpipe\** models the width will take the width reflected on the `data_bus_signal`. See Table 7-3 for information about the `data_bus_signal`. For *\*spipe\** models, the width must be configured for each supported speed. These settings are made in the `svt_PCIE_pl_configuration` PL configuration class. The settings are:

- ❖ `pipe_width[0]` : Gen 1 data bus width
- ❖ `pipe_width[1]`: Gen 2 data bus width
- ❖ `pipe_width[2]`: Gen 3 data bus width

Supported widths are (`pipe_width_enum`): `PIPE_8_BITS`, `PIPE_16_BITS`, `PIPE_32_BITS`

### A.2.2 PIPE4 and Above

With PIPE 4, the per-lane data bus width and rate of the PIPE clock are determined by the `pclk_rate` and `width` PIPE signals. For *\*mpipe\** models the `pclk_rate` and `width` signals are set within the PL configuration class: `svt_PCIE_pl_configuration`. The settings are:

- ❖ `pclk_rate[0]`: Gen 1 `pclk_rate`
- ❖ `pclk_rate[1]`: Gen 2 `pclk_rate`
- ❖ `pclk_rate[2]`: Gen 3 `pclk_rate`
- ❖ `pclk_rate[3]`: Gen 4 `pclk_rate` (applicable for PIPE 4.2 and above)
- ❖ `pclk_rate[4]`: Gen 5 `pclk_rate` (applicable for PIPE 4.4 and above)

Options are (`pclk_rate_enum`): `PCLK_31_25_MHZ`, `PCLK_62_5_MHZ`, `PCLK_125_MHZ`, `PCLK_250_MHZ`, `PCLK_500_MHZ`, `PCLK_1000_MHZ`, `PCLK_2000_MHZ`, `PCLK_4000_MHZ`

- ❖ `pipe_width[0]`: Gen 1 data bus width
- ❖ `pipe_width[1]`: Gen 2 data bus width
- ❖ `pipe_width[2]`: Gen 3 data bus width
- ❖ `pipe_width[3]`: Gen 4 data bus width (applicable for PIPE 4.2 and above)

- ❖ pipe\_width[4]: Gen 5 data bus width (applicable for PIPE 4.4 and above)

Supported widths are (pipe\_width\_enum):

- ◆ PIPE\_8\_BITS
- ◆ PIPE\_16\_BITS
- ◆ PIPE\_32\_BITS
- ◆ PIPE\_64\_BITS (applicable for 2.5G [for PIPE Specification Version 5.1 and later], 5G [for PIPE Specification Version 5.1 and later], 8G, 16G and 32G link speeds when the macro SVT\_PCIE\_PIPE\_DATA\_WIDTH is set to 64)



**Note** PCIe VIP does not support 12 and 20 symbol size SKIP OS for 64-bit PIPE width at Gen3 and higher data rates.

For \*spipe\* models connect the pclk\_rate and width PIPE signals to the MAC.

Note: For SERDES or PMA models, do not set the pclk\_rate or pipe\_width.

If you want to reconfigure svt\_PCIE\_pl\_configuration::pclk\_rate or svt\_PCIE\_pl\_configuration::pipe\_width values, the recommended time is when LTSSM is in Detect.Quiet and pipe\_reset\_n is asserted.

Following are the two methods to reconfigure pclk\_rate or pipe\_width:

1. Set svt\_PCIE\_pl\_configuration::enable\_pipe\_reset\_n\_assertion\_in\_detect\_quiet = 1 and direct LTSSM to Detect.Quiet.
2. Use svt\_PCIE\_pl\_service::PIPE\_INJECT\_RESET to assert Reset#.

### A.3 PIPE Coefficient Use

Before using the PIPE preset coefficient feature of the model, you must first enable the feature with the following configuration members of the svt\_PCIE\_pl\_configuration class. The configuration members are used for both SPIPE and MPIPE.

- ❖ **enable\_get\_local\_preset\_coefficients.** Before you can use the PIPE GetLocalPresetCoefficients interface of the PHY you must enable those signals using the enable\_get\_local\_preset\_coefficients member. If you have a SERDES interface, this parameter has no effect as this interface is only present in a PIPE model (version 4.0 or greater).
  - ◆ **MPIPE model:** If the enable\_get\_local\_preset\_coefficients is a "1", then it enables the per-Lane "GetLocalPresetStateMachine" to drive the per-Lane get\_local\_preset\_coefficients/local\_preset\_index[4:0] outputs and interpret the per-Lane local\_tx\_preset\_coefficients[17:0]/local\_tx\_coefficients\_valid inputs. If the enable\_get\_local\_preset\_coefficients is a "0", there will be no activity presented on the previous outputs nor any response to the previous inputs.
  - ◆ **SPIPE model.** If the enable\_get\_local\_preset\_coefficients is a "1", it enables the per-Lane "RespLocalTxPresetCoeffStateMachine" to interpret a get\_local\_preset\_coefficients/local\_preset\_index[4:0] input request and respond with a per-Lane "local\_tx\_preset\_coefficients[17:0]/local\_tx\_coefficients\_valid" output. If the enable\_get\_local\_preset\_coefficients is a "0", there will be no response to any per-Lane get\_local\_preset\_coefficients/local\_preset\_index[4:0] input request.

- ❖ **enable\_get\_local\_preset\_coefficients\_checking.** When set to a “1”, you enable the model to check the returned preset coefficient values from the PHY against the values in its “preset mapping table”. The preset to coefficients mapping table is used to map received preset requests to coefficients for use in local transmitter settings.

**Table A-7 PIPE GetLocalPresetCoefficients Signals**

| Name                       | Direction | Active Level | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GetLocalPresetCoefficients | Input     | High         | A MAC holds this signal high for one PCLK cycle requesting a preset to coefficient mapping for the preset on LocalPresetIndex[3:0] to coefficients on LocalTxPresetCoefficient[17:0]<br>Maximum Response time of PHY is 128 nSec.<br>Note. A MAC can make this request any time after reset.<br>Note. After a local preset coefficient request a MAC could assert GetLocalPresetCoefficients again as soon as the next PCLK after LocalTxCoefficientsValid deasserts. |
| LocalPresetIndex [3:0]     | Input     | NA           | Index for local PHY preset coefficients requested by the MAC<br>The preset index value is encoded as follows:<br>0000b – Preset P0.<br>0001b – Preset P1.<br>0010b – Preset P2.<br>0011b – Preset P3.<br>0100b – Preset P4.<br>0101b – Preset P5.<br>0110b – Preset P6.<br>0111b – Preset P7.<br>1000b – Preset P8.<br>1001b – Preset P9.<br>1010b – Preset P10.<br>1011b – Reserved<br>1100b – Reserved<br>1101b – Reserved<br>1110b – Reserved<br>1111b – Reserved. |
| LocalTxCoefficientsValid   | Output    | High         | A PHY holds this signal high for one PCLK cycle to indicate that the LocalTxPresetCoefficients[17:0] bus correctly represents the coefficients values for the preset on the LocalPresetIndex bus.                                                                                                                                                                                                                                                                     |

**Table A-7 PIPE GetLocalPresetCoefficients Signals**

| Name                            | Direction | Active Level | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LocalTxPresetCoefficients[17:0] | Output    | NA           | <p>These are the coefficients for the preset on the LocalPresetIndex[3:0] after a GetLocalPresetCoefficients request:</p> <ul style="list-style-type: none"> <li>[5:0] C-1</li> <li>[11:6] C0</li> <li>[17:12] C+1</li> </ul> <p>Valid on assertion of LocalTxCoefficientsValid. The MAC will reflect these coefficient values on the TxDeemph bus when MAC wishes to apply this preset.</p> |

You fill in the preset mapping table using PHY layer configuration data member preset\_to\_coefficients\_mapping\_table[16]. Its declaration is as follows:

```
rand bit[17:0] preset_to_coefficients_mapping_table[16] = '{ 18'h0c900, 18'h0c900,
18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900,
18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900, 18'h0c900};
```

When the model is acting as an SPIPE, you must also set the min and max delay value from when the model will respond by asserting values on the local\_tx\_preset\_coefficients\_<n> set of signals. The parameters you must set are:

- ❖ **min\_spipe\_preset\_coefficients\_delay**. Default value is 4 time units. If performing as the PIPE slave for the GetLocalPresetCoefficients interface, this is the minimum number of “PClk cycles that a ‘per Lane’ “Respond Local Tx Preset Coefficients” state machine will wait in the RESP\_LOCAL\_TX\_COEFF\_DELAY state before asserting the “LocalTxCoefficientsValid” and “LocalTxPresetCoefficients[17:0]” PIPE interface signals and proceeding to completion. Selection is random between MIN\_SPIPE\_PRESET\_COEFFICIENTS\_DELAY and MAX\_SPIPE\_PRESET\_COEFFICIENTS\_DELAY.
- ❖ **max\_spipe\_preset\_coefficients\_delay**. Default value is 8 time units. This is the “Max” value that is paired with MIN\_SPIPE\_PRESET\_COEFFICIENTS\_DELAY above..

**⚠ Attention** The model generates a random value which is between the min and max values set by the previous configuration members.

### A.3.1 PHY PIPE GetLocalPresetCoefficients Interface ASCII Signals

The following table shows ASCII signals for the PHY PIPE GetLocalPresetCoefficients interface.

**Table A-8 ASCII Signal Names for PHY PIPE GetLocalPresetCoefficients Interface**

| Signal Name                       | Description                                                         |
|-----------------------------------|---------------------------------------------------------------------|
| ascii_pipe_lane0_get_coeff_state  | Current state of Lane 0's GetLocalPresetStateMachine state machine  |
| ascii_pipe_lane1_get_coeff_state  | Current state of Lane 1's GetLocalPresetStateMachine state machine  |
| ascii_pipe_lane30_get_coeff_state | Current state of Lane 30's GetLocalPresetStateMachine state machine |
| ascii_pipe_lane31_get_coeff_state | Current state of Lane 31's GetLocalPresetStateMachine state machine |

**Table A-8 ASCII Signal Names for PHY PIPE GetLocalPresetCoefficients Interface (Continued)**

| Signal Name                            | Description                                                                 |
|----------------------------------------|-----------------------------------------------------------------------------|
| ascii_pipe_lane0_coeff_response_state  | Current state of Lane 0's RespLocalTxPresetCoeffStateMachine state machine  |
| ascii_pipe_lane1_coeff_response_state  | Current state of Lane 1's RespLocalTxPresetCoeffStateMachine state machine  |
| ascii_pipe_lane30_coeff_response_state | Current state of Lane 30's RespLocalTxPresetCoeffStateMachine state machine |
| ascii_pipe_lane31_coeff_response_state | Current state of Lane 31's RespLocalTxPresetCoeffStateMachine state machine |

# B Functional Coverage

---

The PCIe VIP provides notification routines which users can utilize for functional coverage. The notifications are called inside of a class which can easily be extended by users to meet their specific needs. A set of default covergroups is provided, which you can use some or all of.

- ❖ Enabling Functional Coverage
- ❖ Class Structure and Callbacks
- ❖ Overriding the Default Coverage Class
- ❖ Transaction Layer
- ❖ Data Link Layer
- ❖ Physical Layer
- ❖ PIPE Interface
- ❖ Mapping Legacy Covergroups to Corresponding New Covergroups

## B.1 Enabling Functional Coverage

To enable function coverage define the macro 'SVT\_PCIE\_INCLUDE\_AC\_COVERAGE' at compile time, and set the following variables in the svt\_PCIE\_configuration class:

```
enable_cov = 6'b111111; // Bitwise enable
```

In the enable\_cov variable, bit 0 enables PIPE related functional coverage, and bits 1, 2, and 3 enable functional coverage for the Physical Layer, Data Link Layer, and Transaction Layers respectively.

## B.2 Class Structure and Callbacks

The classes described in this section are unencrypted and can be viewed in Include/pciesvc\_coverage\_pkg.sv.

All of the functional coverage classes have an abstract base class(ending is \_base) which contains the variables which are to be used by coverage groups as well as pure virtual declarations for Update() and Sample() routines. The Update() callback routines are used to unpack data passed in the callback function into class variables. The Sample() callbacks are used to trigger the coverage groups.

Derived from each base class is a data class where the implementation for all of the Update() tasks is defined. Users that do not wish to use any of the provided functional coverage can extend their own coverage class from the data class.

A functional coverage class is extended from the data class, and in the functional coverage class there is an implementation of the Sample() callbacks along with a number of different functional coverage groups. Users that wish to utilize some or all of the provided functional coverage but modify or add to the existing coverage should extend from the functional coverage classes. Individual covergroups and/or coverpoints can be turned off/adjusted by using standard SystemVerilog syntax such as option.weight. Please refer to the SystemVerilog LRM for more details.

For users who wish to modify the Update() implementation in the \_data class, it is recommended to call super.Update() in the child implementation to ensure that the data is unpacked correctly.

## B.3 Overriding the Default Coverage Class

Each layer in the VIP protocol stack has a pointer to the corresponding coverage class. The Physical Layer has a pointer to both phy coverage as well as pipe coverage. Any class which replaces the default coverage class must have the \_data class for the appropriate layer as its parent.

### B.3.1 Overriding With UVM

UVM users should override the default coverage class by using the factory to replace the \_data class with the desired class, as shown in the following example:

```
factory.set_type_override_by_type(
    pciesvc_coverage_pkg::link_fc_data::get_type(),
    a_different_coverage_class::get_type(),
    1
);
```

### B.3.2 Overriding for SystemVerilog Users

There is an override function for each of the four types of coverage classes: tl, link, phy and pipe. The transaction override function is in the Transaction Layer, the link override function is in the Data Link Layer, and the phy and pipe functions are in the Physical Layer. You must first instantiate the class that you want to use for coverage and then call new() on it. Once the class has been constructed the object handle is passed through the override function call. All override function calls are described in [Table B-1](#). These tasks may also be called through the SystemVerilog API.

**Table B-1 Transaction override functions**

| Function Name               | Arguments                                                                                                                            | Layer              |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| SetTransactionCoverageClass | new_class – handle to the new coverage class.<br>The new class must be derived from<br>pciesvc_tl_fc_data or pciesvc_tl_fc_coverage. | SVC_PATH.port0.tl0 |

**Table B-1 Transaction override functions (Continued)**

|                      |                                                                                                                                    |                     |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| SetLinkCoverageClass | new_class – handle to the new coverage class. The new class must be derived from pciesvc_link_fc_data or pciesvc_link_fc_coverage. | SVC_PATH.port0.dl0  |
| SetPhyCoverageClass  | new_class – handle to the new coverage class. The new class must be derived from pciesvc_phy_fc_data or pciesvc_phy_fc_coverage.   | SVC_PATH.port0.phy0 |
| SetPipeCoverageClass | new_class – handle to the new coverage class. The new class must be derived from pciesvc_pipe_fc_data or pciesvc_pipe_fc_coverage. | SVC_PATH.port0.phy0 |

## B.4 Transaction Layer

All methods and variables are declared in pciesvc\_tl\_fc\_base, which is located in Include/pciesvc\_coverage\_pkg.sv. Implementation of the Update() functions is in the pciesvc\_tl\_fc\_data class. The covergroups and implementation of the sample() functions are provided in the class pciesvc\_tl\_fc\_coverage.

### B.4.1 Transaction Layer Functional Coverage

Table B-2 lists the covergroups, coverpoints and bins present in the Transaction Layer coverage class.

**Table B-2 Covergroups, coverpoints and bins in the Transaction Layer coverage class**

| Covergroup          | Coverpoints                      | Bins                                                                                                                                                       |
|---------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cg_tx_tc_vc_mapping | cp_tc<br>cp_vc<br>cp_tc_cross_vc | tc_0<br>tc_1<br>tc_2<br>tc_3<br>tc_4<br>tc_5<br>tc_6<br>tc_7<br>vc_0<br>vc_1<br>vc_2<br>vc_3<br>vc_4<br>vc_5<br>vc_6<br>vc_7<br>All TC and VC combinations |

**Table B-2 Covergroups, coverpoints and bins in the Transaction Layer coverage class (Continued)**

|                     |                |                            |
|---------------------|----------------|----------------------------|
| cg_rx_tc_vc_mapping | cp_tc          | tc_0                       |
|                     |                | tc_1                       |
|                     |                | tc_2                       |
|                     |                | tc_3                       |
|                     |                | tc_4                       |
|                     |                | tc_5                       |
|                     |                | tc_6                       |
|                     |                | tc_7                       |
|                     | cp_vc          | vc_0                       |
|                     |                | vc_1                       |
|                     |                | vc_2                       |
|                     |                | vc_3                       |
|                     |                | vc_4                       |
|                     |                | vc_5                       |
|                     |                | vc_6                       |
|                     |                | vc_7                       |
|                     | cp_tc_cross_vc | All TC and VC combinations |

#### B.4.2 Transaction Layer Callbacks

Transaction Layer functional coverage class callbacks and arguments are listed in [Table B-3](#).

**Table B-3 Transaction Layer functional coverage class callbacks and arguments**

| Task Name                                          | Arguments | I/O | Values                                                    |
|----------------------------------------------------|-----------|-----|-----------------------------------------------------------|
| UpdateTxTcVcMapping                                | tx_tc     | I   | Traffic class of the transmitted TLP                      |
|                                                    | tx_vc     | I   | VC which maps to the traffic class of the transmitted TLP |
| UpdateRxTcVcMapping                                | rx_tc     | I   | Traffic class of the received TLP                         |
|                                                    | rx_vc     | I   | VC which maps to the traffic class of the received TLP    |
| SampleTxTcVcMapping                                | N/A       | N/A | N/a                                                       |
| Called immediately following UpdateTxTcVcMapping() |           |     |                                                           |
| SampleRxTcVcMapping                                | N/A       | N/A | N/a                                                       |
| Called immediately following UpdateRxTcVcMapping() |           |     |                                                           |

## B.5 Data Link Layer

All methods and class variables are declared in `pciesvc_link_fc_base`, which is located in `Include/pciesvc_coverage_pkg.sv`. Implementation of the `Update()` functions is in the `pciesvc_link_fc_data` class. The covergroups and implementation of the `sample()` functions are provided in the `pciesvc_link_fc_coverage` class.

Please note for the TLP and DLLP Update tasks that all fields in the argument list may not be valid depending on the type of packet. For example, the `message_code` field is valid only for message TLPs, and should be disregarded on other TLPs. The provided covergroups cover most aspects of TLP/DLLP transmission, but not all TLP fields have a coverpoint. However, all TLP fields are updated during the `UpdateTxTLP/UpdateRxTLP` callbacks so that users can create their own coverage if necessary.

### B.5.1 Data Link Layer Functional Coverage

**Table B-4** lists the covergroups, coverpoints and bins present in the Data Link Layer layer coverage class. Note that the `type` field for TLPs and DLLPs is sampled in several coverpoints. Having different types of TLPs in different coverpoints allows users to easily change weights/goals within the coverpoints to cover only the types of packets they are interested in.

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class**

| Covergroup | Coverpoint                   | Bins                    | Comment                |
|------------|------------------------------|-------------------------|------------------------|
| cg_tx_dllp | cp_dllp_type_acknak          | ACK                     | ACK/NAK DLLPs          |
|            |                              | NAK                     |                        |
|            | cp_dllp_type_pm              | PM Enter L1             | Power Management DLLPS |
|            |                              | PM Enter L23            |                        |
|            |                              | PM Active State Request |                        |
|            |                              | PM Request Ack          |                        |
|            | cp_dllp_type_vendor_specific | Vendor Specific         | Vendor Specific        |
|            | cp_dllp_type_fc_vc0          | initfc1_p_vc0           | VC0 Flow Control DLLPs |
|            |                              | initfc1_np_vc0          |                        |
|            |                              | initfc1_cpl_vc0         |                        |
|            |                              | initfc2_p_vc0           |                        |
|            |                              | initfc2_np_vc0          |                        |
|            |                              | initfc2_cpl_vc0         |                        |
|            |                              | updatefc_p_vc0          |                        |
|            |                              | updatefc_np_vc0         |                        |
|            |                              | updatefc_cpl_vc0        |                        |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                     |                  |                        |
|---------------------|------------------|------------------------|
| cp_dllp_type_fc_vc1 | initfc1_p_vc1    | VC1 Flow Control DLLPs |
|                     | initfc1_np_vc1   |                        |
|                     | initfc1_cpl_vc1  |                        |
|                     | initfc2_p_vc1    |                        |
|                     | initfc2_np_vc1   |                        |
|                     | initfc2_cpl_vc1  |                        |
|                     | updatefc_p_vc1   |                        |
|                     | updatefc_np_vc1  |                        |
|                     | updatefc_cpl_vc1 |                        |
| cp_dllp_type_fc_vc2 | initfc1_p_vc2    | VC2 Flow Control DLLPs |
|                     | initfc1_np_vc2   |                        |
|                     | initfc1_cpl_vc2  |                        |
|                     | initfc2_p_vc2    |                        |
|                     | initfc2_np_vc2   |                        |
|                     | initfc2_cpl_vc2  |                        |
|                     | updatefc_p_vc2   |                        |
|                     | updatefc_np_vc2  |                        |
|                     | updatefc_cpl_vc2 |                        |
| cp_dllp_type_fc_vc3 | initfc1_p_vc3    | VC3 Flow Control DLLPs |
|                     | initfc1_np_vc3   |                        |
|                     | initfc1_cpl_vc3  |                        |
|                     | initfc2_p_vc3    |                        |
|                     | initfc2_np_vc3   |                        |
|                     | initfc2_cpl_vc3  |                        |
|                     | updatefc_p_vc3   |                        |
|                     | updatefc_np_vc3  |                        |
|                     | updatefc_cpl_vc3 |                        |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                     |                  |                        |
|---------------------|------------------|------------------------|
| cp_dllp_type_fc_vc4 | initfc1_p_vc4    | VC4 Flow Control DLLPs |
|                     | initfc1_np_vc4   |                        |
|                     | initfc1_cpl_vc4  |                        |
|                     | initfc2_p_vc4    |                        |
|                     | initfc2_np_vc4   |                        |
|                     | initfc2_cpl_vc4  |                        |
|                     | updatefc_p_vc4   |                        |
|                     | updatefc_np_vc4  |                        |
|                     | updatefc_cpl_vc4 |                        |
| cp_dllp_type_fc_vc5 | initfc1_p_vc5    | VC5 Flow Control DLLPs |
|                     | initfc1_np_vc5   |                        |
|                     | initfc1_cpl_vc5  |                        |
|                     | initfc2_p_vc5    |                        |
|                     | initfc2_np_vc5   |                        |
|                     | initfc2_cpl_vc5  |                        |
|                     | updatefc_p_vc5   |                        |
|                     | updatefc_np_vc5  |                        |
|                     | updatefc_cpl_vc5 |                        |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                     |                                                            |                                                         |
|---------------------|------------------------------------------------------------|---------------------------------------------------------|
| cp_dllp_type_fc_vc6 | initfc1_p_vc6                                              | VC6 Flow Control DLLPs                                  |
|                     | initfc1_np_vc6                                             |                                                         |
|                     | initfc1_cpl_vc6                                            |                                                         |
|                     | initfc2_p_vc6                                              |                                                         |
|                     | initfc2_np_vc6                                             |                                                         |
|                     | initfc2_cpl_vc6                                            |                                                         |
|                     | updatefc_p_vc6                                             |                                                         |
|                     | updatefc_np_vc6                                            |                                                         |
|                     | updatefc_cpl_vc6                                           |                                                         |
| cp_dllp_type_fc_vc7 | initfc1_p_vc7                                              | VC7 Flow Control DLLPs                                  |
|                     | initfc1_np_vc7                                             |                                                         |
|                     | initfc1_cpl_vc7                                            |                                                         |
|                     | initfc2_p_vc7                                              |                                                         |
|                     | initfc2_np_vc7                                             |                                                         |
|                     | initfc2_cpl_vc7                                            |                                                         |
|                     | updatefc_p_vc7                                             |                                                         |
|                     | updatefc_np_vc7                                            |                                                         |
|                     | updatefc_cpl_vc7                                           |                                                         |
| cp_hdr_fc           | less_8                                                     | HDR FC Value (sampled only on flow control type DLLPs)  |
|                     | less_32                                                    |                                                         |
|                     | less_128                                                   |                                                         |
|                     | less_255                                                   |                                                         |
| cp_data_fc          | less_128                                                   | DATA FC Value (sampled only on flow control type DLLPs) |
|                     | less_512                                                   |                                                         |
|                     | less_1024                                                  |                                                         |
|                     | less_4096                                                  |                                                         |
| cp_hdr_cross_fc_vc0 | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc0 | hdr cross flow control type for VC0                     |
| cp_hdr_cross_fc_vc1 | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc1 | hdr cross flow control type for VC1                     |
| cp_hdr_cross_fc_vc2 | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc2 | hdr cross flow control type for VC2                     |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer coverage class (Continued)**

|  |                      |                                                             |                                      |
|--|----------------------|-------------------------------------------------------------|--------------------------------------|
|  | cp_hdr_cross_fc_vc3  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc3  | hdr cross flow control type for VC3  |
|  | cp_hdr_cross_fc_vc4  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc4  | hdr cross flow control type for VC4  |
|  | cp_hdr_cross_fc_vc5  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc5  | hdr cross flow control type for VC5  |
|  | cp_hdr_cross_fc_vc6  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc6  | hdr cross flow control type for VC6  |
|  | cp_hdr_cross_fc_vc7  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc7  | hdr cross flow control type for VC7  |
|  | cp_data_cross_fc_vc0 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc0 | data cross flow control type for VC0 |
|  | cp_data_cross_fc_vc1 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc1 | data cross flow control type for VC1 |
|  | cp_data_cross_fc_vc2 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc2 | data cross flow control type for VC2 |
|  | cp_data_cross_fc_vc3 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc3 | data cross flow control type for VC3 |
|  | cp_data_cross_fc_vc4 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc4 | data cross flow control type for VC4 |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                          |                              |                                                             |                                      |
|--------------------------|------------------------------|-------------------------------------------------------------|--------------------------------------|
|                          | cp_data_cross_fc_vc5         | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc5 | data cross flow control type for VC5 |
|                          | cp_data_cross_fc_vc6         | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc6 | data cross flow control type for VC6 |
|                          | cp_data_cross_fc_vc7         | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc7 | data cross flow control type for VC7 |
| cp_dllp_error_injections | corrupt_crc                  | Error injections for transmitted DLLPs                      |                                      |
|                          | unknown_type                 |                                                             |                                      |
|                          | rsvd_non_zero                |                                                             |                                      |
|                          | duplicate_ack                |                                                             |                                      |
|                          | missing_start                |                                                             |                                      |
|                          | missing_end                  |                                                             |                                      |
|                          | corrupt_disparity            |                                                             |                                      |
|                          | codeViolation                |                                                             |                                      |
| cg_rx_dllp               | cp_dllp_type_acknak          | ACK                                                         | ACK/NAK DLLPs                        |
|                          |                              | NAK                                                         |                                      |
|                          | cp_dllp_type_pm              | PM Enter L1                                                 | Power Management DLLPS               |
|                          |                              | PM Enter L23                                                |                                      |
|                          |                              | PM Active State Request                                     |                                      |
|                          | cp_dllp_type_vendor_specific | PM Request Ack                                              |                                      |
|                          | cp_dllp_type_vendor_specific | Vendor Specific                                             | Vendor Specific                      |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|  |                     |                  |                        |
|--|---------------------|------------------|------------------------|
|  | cp_dllp_type_fc_vc0 | initfc1_p_vc0    | VC0 Flow Control DLLPs |
|  |                     | initfc1_np_vc0   |                        |
|  |                     | initfc1_cpl_vc0  |                        |
|  |                     | initfc2_p_vc0    |                        |
|  |                     | initfc2_np_vc0   |                        |
|  |                     | initfc2_cpl_vc0  |                        |
|  |                     | updatefc_p_vc0   |                        |
|  |                     | updatefc_np_vc0  |                        |
|  |                     | updatefc_cpl_vc0 |                        |
|  | cp_dllp_type_fc_vc1 | initfc1_p_vc1    | VC1 Flow Control DLLPs |
|  |                     | initfc1_np_vc1   |                        |
|  |                     | initfc1_cpl_vc1  |                        |
|  |                     | initfc2_p_vc1    |                        |
|  |                     | initfc2_np_vc1   |                        |
|  |                     | initfc2_cpl_vc1  |                        |
|  |                     | updatefc_p_vc1   |                        |
|  |                     | updatefc_np_vc1  |                        |
|  |                     | updatefc_cpl_vc1 |                        |
|  | cp_dllp_type_fc_vc2 | initfc1_p_vc2    | VC2 Flow Control DLLPs |
|  |                     | initfc1_np_vc2   |                        |
|  |                     | initfc1_cpl_vc2  |                        |
|  |                     | initfc2_p_vc2    |                        |
|  |                     | initfc2_np_vc2   |                        |
|  |                     | initfc2_cpl_vc2  |                        |
|  |                     | updatefc_p_vc2   |                        |
|  |                     | updatefc_np_vc2  |                        |
|  |                     | updatefc_cpl_vc2 |                        |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|  |                     |                                                                                                                                                                   |                        |
|--|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|  | cp_dllp_type_fc_vc3 | initfc1_p_vc3<br>initfc1_np_vc3<br>initfc1_cpl_vc3<br>initfc2_p_vc3<br>initfc2_np_vc3<br>initfc2_cpl_vc3<br>updatefc_p_vc3<br>updatefc_np_vc3<br>updatefc_cpl_vc3 | VC3 Flow Control DLLPs |
|  | cp_dllp_type_fc_vc4 | initfc1_p_vc4<br>initfc1_np_vc4<br>initfc1_cpl_vc4<br>initfc2_p_vc4<br>initfc2_np_vc4<br>initfc2_cpl_vc4<br>updatefc_p_vc4<br>updatefc_np_vc4<br>updatefc_cpl_vc4 | VC4 Flow Control DLLPs |
|  | cp_dllp_type_fc_vc5 | initfc1_p_vc5<br>initfc1_np_vc5<br>initfc1_cpl_vc5<br>initfc2_p_vc5<br>initfc2_np_vc5<br>initfc2_cpl_vc5<br>updatefc_p_vc5<br>updatefc_np_vc5<br>updatefc_cpl_vc5 | VC5 Flow Control DLLPs |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|  |                     |                                                            |                                                         |
|--|---------------------|------------------------------------------------------------|---------------------------------------------------------|
|  | cp_dllp_type_fc_vc6 | initfc1_p_vc6                                              | VC6 Flow Control DLLPs                                  |
|  |                     | initfc1_np_vc6                                             |                                                         |
|  |                     | initfc1_cpl_vc6                                            |                                                         |
|  |                     | initfc2_p_vc6                                              |                                                         |
|  |                     | initfc2_np_vc6                                             |                                                         |
|  |                     | initfc2_cpl_vc6                                            |                                                         |
|  |                     | updatefc_p_vc6                                             |                                                         |
|  |                     | updatefc_np_vc6                                            |                                                         |
|  |                     | updatefc_cpl_vc6                                           |                                                         |
|  | cp_dllp_type_fc_vc7 | initfc1_p_vc7                                              | VC7 Flow Control DLLPs                                  |
|  |                     | initfc1_np_vc7                                             |                                                         |
|  |                     | initfc1_cpl_vc7                                            |                                                         |
|  |                     | initfc2_p_vc7                                              |                                                         |
|  |                     | initfc2_np_vc7                                             |                                                         |
|  |                     | initfc2_cpl_vc7                                            |                                                         |
|  |                     | updatefc_p_vc7                                             |                                                         |
|  |                     | updatefc_np_vc7                                            |                                                         |
|  |                     | updatefc_cpl_vc7                                           |                                                         |
|  | cp_hdr_fc           | less_8                                                     | HDR FC Value (sampled only on flow control type DLLPs)  |
|  |                     | less_32                                                    |                                                         |
|  |                     | less_128                                                   |                                                         |
|  |                     | less_255                                                   |                                                         |
|  | cp_data_fc          | less_128                                                   | DATA FC Value (sampled only on flow control type DLLPs) |
|  |                     | less_512                                                   |                                                         |
|  |                     | less_1024                                                  |                                                         |
|  |                     | less_4096                                                  |                                                         |
|  | cp_hdr_cross_fc_vc0 | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc0 | hdr cross flow control type for VC0                     |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|  |                      |                                                             |                                      |
|--|----------------------|-------------------------------------------------------------|--------------------------------------|
|  | cp_hdr_cross_fc_vc1  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc1  | hdr cross flow control type for VC1  |
|  | cp_hdr_cross_fc_vc2  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc2  | hdr cross flow control type for VC2  |
|  | cp_hdr_cross_fc_vc3  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc3  | hdr cross flow control type for VC3  |
|  | cp_hdr_cross_fc_vc4  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc4  | hdr cross flow control type for VC4  |
|  | cp_hdr_cross_fc_vc5  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc5  | hdr cross flow control type for VC5  |
|  | cp_hdr_cross_fc_vc6  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc6  | hdr cross flow control type for VC6  |
|  | cp_hdr_cross_fc_vc7  | all combinations of cp_hdr_fc bins and cp_dllp_type_fc_vc7  | hdr cross flow control type for VC7  |
|  | cp_data_cross_fc_vc0 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc0 | data cross flow control type for VC0 |
|  | cp_data_cross_fc_vc1 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc1 | data cross flow control type for VC1 |
|  | cp_data_cross_fc_vc2 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc2 | data cross flow control type for VC2 |
|  | cp_data_cross_fc_vc3 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc3 | data cross flow control type for VC3 |
|  | cp_data_cross_fc_vc4 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc4 | data cross flow control type for VC4 |
|  | cp_data_cross_fc_vc5 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc5 | data cross flow control type for VC5 |
|  | cp_data_cross_fc_vc6 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc6 | data cross flow control type for VC6 |
|  | cp_data_cross_fc_vc7 | all combinations of cp_data_fc bins and cp_dllp_type_fc_vc7 | data cross flow control type for VC7 |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|           |                       |                  |                                       |
|-----------|-----------------------|------------------|---------------------------------------|
| cg_tx_tlp | cp_mem_requests       | mem_rd_req_32    | fmt/type for Memory Requests          |
|           |                       | mem_rd_req_64    |                                       |
|           |                       | mem_wr_req_32    |                                       |
|           |                       | mem_wr_req_64    |                                       |
|           | cp_mem_rd_lk_requests | mem_rd_req_lk_32 | fmt/type for Mem Read Locked Requests |
|           |                       | mem_rd_req_lk_64 |                                       |
|           | cp_io_requests        | io_rd_req        | fmt/type for I/O Requests             |
|           |                       | io_wr_req        |                                       |
|           | cp_cfg_type0_requests | cfg_rd_req0      | fmt/type for Type 0 Config Requests   |
|           |                       | cfg_wr_req0      |                                       |
|           | cp_cfg_type1_requests | cfg_rd_req1      | fmt/type for Type 1 Config Requests   |
|           |                       | cfg_wr_req01     |                                       |
|           | cp_msg                | Msg              | fmt/type for Message TLPs             |
|           |                       | MsgD             |                                       |
|           | cp_cpl                | Cpl              | fmt/type for Completion TLPs          |
|           |                       | CplID            |                                       |
|           | cp_lk_cpl             | CplLk            | fmt/type for Completion Locked TLPs   |
|           |                       | CplIDLk          |                                       |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                         |                      |                                |
|-------------------------|----------------------|--------------------------------|
| cp_atomic_ops           | FetchAdd32           | fmt/type for Atomic Ops        |
|                         | FetchAdd64           |                                |
|                         | Swap                 |                                |
|                         | Swap64               |                                |
|                         | CAS32                |                                |
|                         | CAS64                |                                |
| cp_traffic class        | tc0                  | Traffic Class                  |
|                         | tc1                  |                                |
|                         | tc2                  |                                |
|                         | tc3                  |                                |
|                         | tc4                  |                                |
|                         | tc5                  |                                |
|                         | tc6                  |                                |
|                         | tc7                  |                                |
| cp_transaction_hint     | 0/1                  | Transaction hint               |
| cp_tlp_digest           | 0/1                  | TLP digest bit                 |
| cp_error_poison         | 0/1                  | Error Poison bit               |
| cp_address_transalation | default_untranslated | Address transaction bit        |
|                         | translation_request  |                                |
|                         | translated           |                                |
| cp_length               | length_1             | length field                   |
|                         | length_2_thru_1023   |                                |
|                         | length_1024          |                                |
| cp_attr_id_order        | 0/1                  | ID ordering attribute bit      |
| cp_attr_relax_order     | 0/1                  | relaxed ordering attribute bit |
| cp_attr_no_snoop        | 0/1                  | nosnoop attribute bit          |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                      |                       |                             |                                                                |
|----------------------|-----------------------|-----------------------------|----------------------------------------------------------------|
| cp_msg_code          | cp_first_dw_be        | autobins for 4'b000-4'b1111 | First DW byte enable. Fires only on mem, I/O and CFG type TLPs |
|                      | cp_last_dw_be         | autobins for 4'b0-4'b1111   | Last DW byte enable. Fires only on mom, I/O and CFG type TLPs  |
|                      | cp_ph                 | 0/1                         | processing hint                                                |
|                      | cp_assert_inta        |                             | Message Code Type                                              |
|                      | cp_assert_intb        |                             |                                                                |
|                      | cp_assert_intc        |                             |                                                                |
|                      | cp_assert_intd        |                             |                                                                |
|                      | cp_deassert_inta      |                             |                                                                |
|                      | cp_deassert_intb      |                             |                                                                |
|                      | cp_deassert_intc      |                             |                                                                |
|                      | cp_deassert_intd      |                             |                                                                |
|                      | pm_active_state_nak   |                             |                                                                |
|                      | pm_pme                |                             |                                                                |
|                      | pm_pme_turn_off       |                             |                                                                |
|                      | pm_pme_to_ack         |                             |                                                                |
|                      | err_cor               |                             |                                                                |
|                      | err_non_fatal         |                             |                                                                |
|                      | err_fatal             |                             |                                                                |
|                      | unlock                |                             |                                                                |
|                      | set_slot_power_limit  |                             |                                                                |
|                      | OBFF                  |                             |                                                                |
| cp_completion_status | successful completion |                             | Completion Status                                              |
|                      | unsupported request   |                             |                                                                |
|                      | completer abort       |                             |                                                                |
|                      | CRS                   |                             |                                                                |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|           |                 |                             |                              |
|-----------|-----------------|-----------------------------|------------------------------|
|           | cp_sequence_num | seq_num_0                   | TLP Sequence Number          |
|           |                 | seq_num_1_thru_4095         |                              |
|           |                 | seq_num_4095                |                              |
|           | cp_ei_code      | ei_none                     | Error Injection Codes        |
|           |                 | ei_corrupt_crc              |                              |
|           |                 | ei_illegal_seq_num          |                              |
|           |                 | ei_duplicate_seq_num        |                              |
|           |                 | ei_nullified                |                              |
|           |                 | ei_nullified_good_lcrc      |                              |
|           |                 | ei_nullified_corrupt_lcrc   |                              |
|           |                 | ei_corrupt_disparity        |                              |
|           |                 | ei_codeViolation            |                              |
|           |                 | ei_missing_start            |                              |
|           |                 | ei_missing_end              |                              |
|           |                 | ei_8g_corrupt_header_crc    |                              |
|           |                 | ei_8g_corrupt_header_parity |                              |
|           |                 | ei_corrupt_ecrc             |                              |
|           |                 | ei_ignore_credit            |                              |
|           |                 | ei_expect_ur                |                              |
|           |                 | ei_expect_crs               |                              |
|           |                 | ei_expect_ca                |                              |
|           |                 | ei_expect_timeout           |                              |
| cg_rx_tlp | cp_mem_requests | mem_rd_req_32               | fmt/type for Memory Requests |
|           |                 | mem_rd_req_64               |                              |
|           |                 | mem_wr_req_32               |                              |
|           |                 | mem_wr_req_64               |                              |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                       |                  |                                       |
|-----------------------|------------------|---------------------------------------|
| cp_mem_rd_lk_requests | mem_rd_req_lk_32 | fmt/type for Mem Read Locked Requests |
|                       | mem_rd_req_lk_64 |                                       |
| cp_io_requests        | io_rd_req        | fmt/type for I/O Requests             |
|                       | io_wr_req        |                                       |
| cp_cfg_type0_requests | cfg_rd_req0      | fmt/type for Type 0 Config Requests   |
|                       | cfg_wr_req0      |                                       |
| cp_cfg_type1_requests | cfg_rd_req1      | fmt/type for Type 1 Config Requests   |
|                       | cfg_wr_req01     |                                       |
| cp_msg                | Msg              | fmt/type for Message TLPs             |
|                       | MsgD             |                                       |
| cp_cpl                | Cpl              | fmt/type for Completion TLPs          |
|                       | CplID            |                                       |
| cp_lk_cpl             | CplLk            | fmt/type for Completion Locked TLPs   |
|                       | CplDLk           |                                       |
| cp_atomic_ops         | FetchAdd32       | fmt/type for Atomic Ops               |
|                       | FetchAdd64       |                                       |
|                       | Swap             |                                       |
|                       | Swap64           |                                       |
|                       | CAS32            |                                       |
|                       | CAS64            |                                       |
| cp_traffic class      | tc0              | Traffic Class                         |
|                       | tc1              |                                       |
|                       | tc2              |                                       |
|                       | tc3              |                                       |
|                       | tc4              |                                       |
|                       | tc5              |                                       |
|                       | tc6              |                                       |
|                       | tc7              |                                       |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|                     |                             |                                                                |
|---------------------|-----------------------------|----------------------------------------------------------------|
| cp_th               | 0/1                         | Transaction hint                                               |
| cp_td               | 0/1                         | TLP digest bit                                                 |
| cp_ep               | 0/1                         | Error Poison bit                                               |
| cp_at               | 0/1                         | Address transaction bit                                        |
| cp_length           | length_1                    | length field                                                   |
|                     | length_2_thru_1023          |                                                                |
|                     | length_1024                 |                                                                |
| cp_attr_id_order    | 0/1                         | ID ordering attribute bit                                      |
| cp_attr_relax_order | 0/1                         | relaxed ordering attribute bit                                 |
| cp_attr_no_snoop    | 0/1                         | nosnoop attribute bit                                          |
| cp_first_dw_be      | autobins for 4'b000-4'b1111 | First DW byte enable. Fires only on mem, I/O and CFG type TLPs |
| cp_last_dw_be       | autobins for 4'b0-4'b1111   | Last DW byte enable. Fires only on mom, I/O and CFG type TLPs  |
| cp_ph               | 0/1                         | processing hint                                                |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|  |                      |                       |                                         |
|--|----------------------|-----------------------|-----------------------------------------|
|  | cp_msg_code          | cp_assert_inta        | Message Code Type                       |
|  |                      | cp_assert_intb        |                                         |
|  |                      | cp_assert_intc        |                                         |
|  |                      | cp_assert_intd        |                                         |
|  |                      | cp_deassert_inta      |                                         |
|  |                      | cp_deassert_intb      |                                         |
|  |                      | cp_deassert_intc      |                                         |
|  |                      | cp_deassert_intd      |                                         |
|  |                      | pm_active_state_nak   |                                         |
|  |                      | pm_pme                |                                         |
|  |                      | pm_pme_turn_off       |                                         |
|  |                      | pm_pme_to_ack         |                                         |
|  |                      | err_cor               |                                         |
|  |                      | err_non_fatal         |                                         |
|  |                      | err_fatal             |                                         |
|  | cp_completion_status | unlock                | Completion Status                       |
|  |                      | set_slot_power_limit  |                                         |
|  |                      | OBFF                  |                                         |
|  |                      | successful completion |                                         |
|  | cp_sequence_num      | unsupported request   | Sequence number assigned to TLP         |
|  |                      | completer abort       |                                         |
|  |                      | CRS                   |                                         |
|  | cg_tx_ipg            | seq_num_0             | Inter packet gap of transmitted packets |
|  |                      | seq_num_1_thru_4094   |                                         |
|  |                      | seq_num_4095          |                                         |
|  | cp_tx_ipg            | ipg_0                 | Inter packet gap of transmitted packets |
|  |                      | ipg_1                 |                                         |
|  |                      | ipg_2                 |                                         |
|  |                      | ipg_3_to_4            |                                         |
|  |                      | ipg_5_to_8            |                                         |
|  |                      | ipg_9_to_16           |                                         |
|  |                      | ipg_16_to_32          |                                         |
|  |                      | ipg_greater_than_32   |                                         |

**Table B-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

|           |           |                     |                                      |
|-----------|-----------|---------------------|--------------------------------------|
| cg_rx_ipg | cp_rx_ipg | ipg_0               | Inter packet gap of received packets |
|           |           | ipg_1               |                                      |
|           |           | ipg_2               |                                      |
|           |           | ipg_3_to_4          |                                      |
|           |           | ipg_5_to_8          |                                      |
|           |           | ipg_9_to_16         |                                      |
|           |           | ipg_16_to_32        |                                      |
|           |           | ipg_greater_than_32 |                                      |

## B.5.2 Link Layer Callbacks

Data Link Layer callbacks are listed in [Table B-5](#).

**Table B-5 Data Link Layer callbacks**

| Function Name                                                                            | Arguments       | I/O | Values                                                                                                                                |
|------------------------------------------------------------------------------------------|-----------------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| UpdateTxDLLP<br><br>This function is called every time the link finishes sending a DLLP. | dllp[63:0]      | I   | 64 bit array containing the DLLP data                                                                                                 |
|                                                                                          | ei_code[31:0]   | I   | Error injection code associated with the DLLP.                                                                                        |
| UpdateRxDLLP<br><br>Called every time the link received a DLLP.                          | dllp[63:0]      | I   | 64 bit array containing the DLLP data                                                                                                 |
|                                                                                          | rx_status[31:0] | I   | Status of the received DLLP. Status bits are defined in <code>Include/pciesvc_parms.vp</code> under <code>RECEIVED_TLP_STATUS*</code> |

**Table B-5 Data Link Layer callbacks (Continued)**

|                                                                        |                    |  |                              |
|------------------------------------------------------------------------|--------------------|--|------------------------------|
| UpdateTxTLP<br><br>Called after the link sends the last byte of a TLP. | tlp_fmt[2:0]       |  | Format field                 |
|                                                                        | tlp_type[4:0]      |  | Type field                   |
|                                                                        | tc[2:0]            |  | Traffic class                |
|                                                                        | th                 |  | Transaction hint             |
|                                                                        | td                 |  | TLP Digest bit               |
|                                                                        | ep                 |  | Error/Poison bit             |
|                                                                        | attr_id_order      |  | ID Order attribute bit       |
|                                                                        | attr_relax_order   |  | Relaxed order attribute bit  |
|                                                                        | attr_no_snoop      |  | No snoop attribute attribute |
|                                                                        | at[1:0]            |  | address translation          |
|                                                                        | length[9:0]        |  | length field                 |
|                                                                        | ecrc[31:0]         |  | ECRC(digest) value           |
|                                                                        | lcrc[31:0]         |  | Link CRC value               |
|                                                                        | sequence_num (int) |  | Sequence number of the TLP   |
|                                                                        | requester_id[15:0] |  | Requester ID field           |
|                                                                        | tag[7:0]           |  | Tag value                    |
|                                                                        | first_dw_be[3:0]   |  | First DW byte enable field.  |
|                                                                        | last_dw_be[3:0]    |  | Last DW byte enable field.   |
|                                                                        | address[63:0]      |  | Address field.               |

**Table B-5 Data Link Layer callbacks (Continued)**

|                                                                           |                              |  |                                                                                        |
|---------------------------------------------------------------------------|------------------------------|--|----------------------------------------------------------------------------------------|
|                                                                           | ph[1:0]                      |  | Processing hint                                                                        |
|                                                                           | bus_num[7:0]                 |  | bus number                                                                             |
|                                                                           | device_num[2:0]              |  | device number                                                                          |
|                                                                           | function_num[2:0]            |  | function number                                                                        |
|                                                                           | register_num[9:0]            |  | Combines reg and ext_reg field for config TLPs                                         |
|                                                                           | message_code[7:0]            |  | Message code field                                                                     |
|                                                                           | message_dword2[31:0]         |  | 2 <sup>nd</sup> dword of message TLP. This would be used for vendor specific messages. |
|                                                                           | message_dword3[31:0]         |  | 3 <sup>rd</sup> dword of message TLP.                                                  |
|                                                                           | completer_id[15:0]           |  | Completer ID field                                                                     |
|                                                                           | completion_status[2:0]       |  | Completion status                                                                      |
|                                                                           | bcm                          |  | Byte count modified field                                                              |
|                                                                           | byte_count[11:0]             |  | Byte count field                                                                       |
|                                                                           | lower_address[6:0]           |  | Lower address field.                                                                   |
|                                                                           | steering_tag[7:0]            |  | Steering tag.                                                                          |
| UpdateRxTLP<br><br>Called after the link receives the last byte of a TLP. | payload_data (dynamic array) |  | Payload data, if any present.                                                          |
|                                                                           | ei_code [31:0]               |  | Error injection code associated with the TLP.                                          |
|                                                                           | tlp_fmt[2:0]                 |  | Format field                                                                           |
|                                                                           | tlp_type[4:0]                |  | Type field                                                                             |
|                                                                           | tc[2:0]                      |  | Traffic class                                                                          |
|                                                                           | th                           |  | Transaction hint                                                                       |
|                                                                           | td                           |  | TLP Digest bit                                                                         |
|                                                                           | ep                           |  | Error/Poison bit                                                                       |
|                                                                           | attr_id_order                |  | ID Order attribute bit                                                                 |
|                                                                           | attr_relax_order             |  | Relaxed order attribute bit                                                            |
|                                                                           | attr_no_snoop                |  | No snoop attribute attribute                                                           |

**Table B-5 Data Link Layer callbacks (Continued)**

|                                                                        |                              |  |                                                                                        |
|------------------------------------------------------------------------|------------------------------|--|----------------------------------------------------------------------------------------|
|                                                                        | at[1:0]                      |  | address translation                                                                    |
|                                                                        | length[9:0]                  |  | length field                                                                           |
|                                                                        | ecrc[31:0]                   |  | ECRC(digest) value                                                                     |
|                                                                        | lcrc[31:0]                   |  | Link CRC value                                                                         |
|                                                                        | sequence_num (int)           |  | Sequence number of the TLP                                                             |
|                                                                        | requester_id[15:0]           |  | Requester ID field                                                                     |
|                                                                        | tag[7:0]                     |  | Tag value                                                                              |
|                                                                        | first_dw_be[3:0]             |  | First DW byte enable field.                                                            |
|                                                                        | last_dw_be[3:0]              |  | Last DW byte enable field.                                                             |
|                                                                        | address[63:0]                |  | Address field.                                                                         |
|                                                                        | ph[1:0]                      |  | Processing hint                                                                        |
|                                                                        | bus_num[7:0]                 |  | bus number                                                                             |
|                                                                        | device_num[2:0]              |  | device number                                                                          |
|                                                                        | function_num[2:0]            |  | function number                                                                        |
|                                                                        | register_num[9:0]            |  | Combines reg and ext_reg field for config TLPs                                         |
|                                                                        | message_code[7:0]            |  | Message code field                                                                     |
|                                                                        | message_dword2[31:0]         |  | 2 <sup>nd</sup> dword of message TLP. This would be used for vendor specific messages. |
|                                                                        | message_dword3[31:0]         |  | 3 <sup>rd</sup> dword of message TLP.                                                  |
|                                                                        | completer_id[15:0]           |  | Completer ID field                                                                     |
|                                                                        | completion_status[2:0]       |  | Completion status                                                                      |
|                                                                        | bcm                          |  | Byte count modified field                                                              |
|                                                                        | byte_count[11:0]             |  | Byte count field                                                                       |
|                                                                        | lower_address[6:0]           |  | Lower address field.l                                                                  |
|                                                                        | steering_tag[7:0]            |  | Steering tag.                                                                          |
|                                                                        | payload_data (dynamic array) |  | Payload data, if any present.                                                          |
| UpdateTxIpg<br><br>Called every time a new packet starts transmission. | ipg(int)                     |  | Number of bytes between current packet and previously transmitted packet.              |
| UpdateRxIpg<br><br>Called on the start of a new received packet.       | ipg(int)                     |  | Number of bytes between current packet and previously received packet                  |

**Table B-5 Data Link Layer callbacks (Continued)**

|                                                                                       |             |     |                                                                                                              |
|---------------------------------------------------------------------------------------|-------------|-----|--------------------------------------------------------------------------------------------------------------|
| UpdateDLCMSMState<br><br>This function is called every time the DLCMSM changes state. | state[31:0] |     | Current state of the DLCMSM (states are defined in Verilog/Link_Layer/pciesvc_ll_parms.v)                    |
| UpdateFCState<br><br>Called every time the FC state machine changes state.            | state[31:0] |     | Current state of the flow control state machine. States are defined in Verilog/Link_Layer/pciesvc_ll_parms.v |
| SampleTxDLLP<br><br>Called immediately after UpdateTxDLLP()                           | n/a         | n/a | n/a                                                                                                          |
| SampleRxDLLP<br><br>Called immediately after UpdateRxDLLP()                           | n/a         | n/a | n/a                                                                                                          |
| SampleTxTLP<br><br>Called immediately after UpdateTxTLP()                             | n/a         | n/a | n/a                                                                                                          |
| SampleRxTLP<br><br>Called immediately after SampleRxTLP                               | n/a         | n/a | n/a                                                                                                          |
| SampleTxIPG<br><br>Called immediately after UpdateTxIPG()                             | n/a         | n/a | n/a                                                                                                          |
| SampleRxIPG<br><br>Called immediately following SampleRxIPG                           | n/a         | n/a | n/a                                                                                                          |
| SampleDLCMSMState<br><br>Called immediately following UpdateDLCMSMState()             | n/a         | n/a | n/a                                                                                                          |
| SampleFCState<br><br>Called immediately following UpdateFcState()                     | n/a         | n/a | n/a                                                                                                          |

## B.6 Physical Layer

All methods and class variables are declared in `pciesvc_phy_fc_base`, which is located in `Include/pciesvc_coverage_pkg.sv`. Implementation of the `Update()` functions is in the `pciesvc_phy_fc_data` class. The covergroups and implementation of the `sample()` functions are provided in the class `pciesvc_phy_fc_coverage`.

A covergroup with all of the legal transitions in the LTSSM has been provided, though users should note that the PCIESVC LTSSM hitting a certain state doesn't necessarily imply that the DUT has successfully entered that state. Depending on whether or not the VIP is upstream or downstream not all state transitions may apply. Finally, in many cases there are multiple conditions which may trigger a transition from one state to the next (example: transitioning from L0 to recover due to receiving a training set, or going from L0 to recover for a speed change). Additional coverage will be required to capture these conditions.

### B.6.1 Physical Layer Functional Coverage

Covergroups, coverpoints and bins in the Physical Layer coverage class are described in [Table B-6](#).

**Table B-6 Covergroups, coverpoints and bins in the Physical Layer coverage class**

| Covergroup                            | Coverpoint                            | Bins                       | Comment                       |
|---------------------------------------|---------------------------------------|----------------------------|-------------------------------|
| <code>cg_negotiated_data_rate</code>  | <code>cp_negotiated_data_rate</code>  | <code>speed_2_5G</code>    | Data rate upon entry into L0  |
|                                       |                                       | <code>speed_5_0G</code>    |                               |
|                                       |                                       | <code>speed_8_0G*</code>   |                               |
| <code>cg_negotiated_link_width</code> | <code>cp_negotiated_link_width</code> | <code>link_width_1</code>  | Link width upon entry into L0 |
|                                       |                                       | <code>link_width_2</code>  |                               |
|                                       |                                       | <code>link_width_4</code>  |                               |
|                                       |                                       | <code>link_width_8</code>  |                               |
|                                       |                                       | <code>link_width_12</code> |                               |
|                                       |                                       | <code>link_width_16</code> |                               |
|                                       |                                       | <code>link_width_32</code> |                               |

**Table B-6** Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)

|                            |                                                                 |                                                                                                             |
|----------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| cg_ltssm_state_transitions | detect_quiet_to_detect_active                                   | State transitions of all LTSSM states except for the L0s substates, which have their own separate coverage. |
| cp_ltss_state_transitions  | detect_active_to_polling_active                                 |                                                                                                             |
|                            | polling_active_to_polling_compliance                            |                                                                                                             |
|                            | polling_active_to_polling_configuration                         |                                                                                                             |
|                            | polling_active_to_detect_quiet                                  |                                                                                                             |
|                            | polling_compliance_to_detect_quiet                              |                                                                                                             |
|                            | polling_compliance_to_polling_active                            |                                                                                                             |
|                            | polling_configuration_to_configuration_linkwidth_start          |                                                                                                             |
|                            | polling_configuration_to_detect_quiet                           |                                                                                                             |
|                            | configuration_linkwidth_start_to_disabled                       |                                                                                                             |
|                            | configuration_linkwidth_start_to_lopback_entry                  |                                                                                                             |
|                            | configuration_linkwidth_start_to_configuration_linkwidth_accept |                                                                                                             |
|                            | configuration_linkwidth_start_to_detect_quiet                   |                                                                                                             |
|                            | configuration_linkwidth_accept_to_configuration_lanenum_wait    |                                                                                                             |
|                            | configuration_linkwidth_accept_to_detect_quiet                  |                                                                                                             |
|                            | configuration_lanenum_accept_to_configuration_complete          |                                                                                                             |

**Table B-6** Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)

|  |                                                              |  |
|--|--------------------------------------------------------------|--|
|  | configuration_lanenum_accept_to_configuration_lanenum_wait   |  |
|  | configuration_lanenum_accept_to_detect_quiet                 |  |
|  | configuration_lanenum_wait_to_configuration_lanenum_accept   |  |
|  | configuration_lanenum_wait_to_detect_quiet                   |  |
|  | configuration_complete_to_configuration_idle                 |  |
|  | configuration_complete_to_detect_quiet                       |  |
|  | configuration_idle_to_I0                                     |  |
|  | configuration_idle_to_detect_quiet                           |  |
|  | configuration_idle_to_recovery_rcvlock                       |  |
|  | recovery_rcvlock_to_recovery_equalization_phase0*            |  |
|  | recovery_rcvlock_to_recover_equalization_phase1*             |  |
|  | recovery_rcvlock_to_recovery_rcfg                            |  |
|  | recovery_rcvlock_to_recovery_speed                           |  |
|  | recovery_rcvlock_to_configuration_linkwidth_start            |  |
|  | recovery_rcvlock_to_detect_quiet                             |  |
|  | recovery_equalization_phase0_to_recovery_speed*              |  |
|  | recovery_equalization_phase0_to_recovery_equalization_phase1 |  |
|  | recovery_equalization_phase1_to_recovery_rcvlock*            |  |
|  | recovery_equalization_phase1_to_recovery_speed*              |  |

**Table B-6** Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)

|  |                                                              |  |
|--|--------------------------------------------------------------|--|
|  | recovery_equalization_phase2_to_recovery_speed*              |  |
|  | recovery_equalization_phase2_to_recovery_equaliztion_phase3* |  |
|  | recovery_equalization_phase3_to_recovery_speed*              |  |
|  | recovery_equalization_phase3_to_recovery_rcvrlock*           |  |
|  | recovery_speed_to_recovery_rcvrlock                          |  |
|  | recovery_rcvrcfg_to_recovery_idle                            |  |
|  | recovery_rcvrcfg_to_configuration_linkwidth_start            |  |
|  | recovery_rcvrcfg_to_recovery_idle                            |  |
|  | recovery_rcvrcfg_to_configuration_linkwidth_start            |  |
|  | recovery_rcvrcfg_to_detect_quiet                             |  |
|  | recovery_idle_to_disabled                                    |  |
|  | recovery_idle_to_hot_reset                                   |  |
|  | recovery_idle_to_configuration_linkwidth_start               |  |
|  | recovery_idle_to_loopback_entry                              |  |
|  | recovery_idle_to_I0                                          |  |
|  | recovery_idle_to_detect_quiet                                |  |
|  | recovery_idle_to_recovery_rcvrlock                           |  |
|  | I0_to_recovery_rcvrlock                                      |  |
|  | I0_to_I1_entry                                               |  |
|  | I1_entry_to_I1_idle                                          |  |
|  | I1_entry_to_recovery_rcvrlock                                |  |
|  | I1_idle_to_I1_1_idle*                                        |  |

**Table B-6** Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)

|                                |                                |                                   |                                                |
|--------------------------------|--------------------------------|-----------------------------------|------------------------------------------------|
|                                |                                | I1_idle_to_I1_2_entry*            |                                                |
|                                |                                | I1_2_entry_to_I1_2_idle*          |                                                |
|                                |                                | I1_2_idle_to_I1_2_exit*           |                                                |
|                                |                                | I1_2_exit_to_I1_idle*             |                                                |
|                                |                                | I1_1_idle_to_I1_idle*             |                                                |
|                                |                                | I1_1_idle_to_recovery_rcvlock*    |                                                |
|                                |                                | I0_to_I2_idle                     |                                                |
|                                |                                | I2_idle_to_detect_quiet           |                                                |
|                                |                                | disabled_to_detect_quiet          |                                                |
|                                |                                | loopback_entry_to_loopback_active |                                                |
|                                |                                | loopback_entry_to_loopback_exit   |                                                |
|                                |                                | loopback_active_to_loopback_exit  |                                                |
|                                |                                | loopback_exit_to_detect_quiet     |                                                |
|                                |                                | hot_reset_to_detect_quiet         |                                                |
| cg_tx_I0s_substate_transitions | cp_tx_I0s_substate             | I0_to_I0s_entry                   | I0s substate transitions for the transmit side |
|                                |                                | I0s_entry_to_I0s_idle             |                                                |
|                                |                                | I0s_idle_to_I0s_fts               |                                                |
|                                |                                | I0s_fts_to_I0                     |                                                |
| cg_rx_I0s_substate_transitions | cp_rx_I0s_substate_transitions | I0_to_I0s_entry                   | I0s substate transitions for the receive side  |
|                                |                                | I0s_entry_to_I0s_idle             |                                                |
|                                |                                | I0s_idle_to_I0s_fts               |                                                |
|                                |                                | I0s_fts_to_I0                     |                                                |
|                                |                                | I0s_fts_to_recovery_rcvlock       |                                                |

\*Exist for 8G models only

## B.6.2 Physical Layer Callbacks

Callbacks in the Physical Layer are defined in [Table B-7](#).

**Table B-7** Callbacks in the Physical Layer

| Function Name                                                                                   | Arguments             | I/O | Values                           |
|-------------------------------------------------------------------------------------------------|-----------------------|-----|----------------------------------|
| UpdateNegotiatedDataRate<br><br>Called every time the LTSSM enters the L0 state.                | rate [2:0]            | I   | Pipe rate value upon entering L0 |
| UpdateNegotiatedLinkWidth<br><br>Called every time the LTSSM enters the L0 state.               | width (int)           | I   | Link width upon entering L0      |
| UpdateLtssmState<br><br>Called every time the LTSSM enters a new state.                         | state [31:0]          | I   | Current LTSSM state              |
| UpdateTxL0sSubstate<br><br>Called every time the LTSSM transmit side enters a new L0s substate. | tx_l0s_substate[31:0] | I   | Current LTSSM tx substate        |
| UpdateRxL0sSubstate<br><br>Called every time the LTSSM receive side enters a new L0s substate.  | rx_l0s_substate[31:0] | I   | Current LTSSM rx substate        |
| SampleNegotiatedDataRate<br><br>Called immediately following UpdateNegotiatedDataRate()         | n/a                   | n/a | n/a                              |
| SampleNegotiatedLinkWidth<br><br>Called immediately following UpdateNegotiatedLinkWidth         | n/a                   | n/a | n/a                              |
| SampleLtssmState<br><br>Called immediately following UpdateLtssmState                           | n/a                   | n/a | n/a                              |
| SampleTxL0sSubstate<br><br>Called immediately following UpdateTxL0sSubstate                     | n/a                   | n/a | n/a                              |
| SampleRxL0sSubstate<br><br>Called immediately following UpdateRxL0sSubstate                     | n/a                   | n/a | n/a                              |

## B.7 PIPE Interface

All methods and class variables are declared in `pciesvc_pipe_fc_base`, which is located in `Include/pciesvc_coverage_pkg.sv`. Implementation of the `Update()` functions is in the `pciesvc_pipe_fc_data` class. The covergroups and implementation of the `Sample()` functions are provided in the class `pciesvc_pipe_fc_coverage`.

### B.7.1 PIPE Functional Coverage

PIPE functional covergroups coverpoints, and bins are listed in [Table B-8](#).

**Table B-8 PIPE covergroups, coverpoints and bins**

| Covergroup     | Coverpoint        | Bins              | Comment                                     |
|----------------|-------------------|-------------------|---------------------------------------------|
| cg_rate        | cp_rate           | PIPE_RATE_2_5G    | Valid values for the pipe rate signal       |
|                |                   | PIPE_RATE_5G      |                                             |
|                |                   | PIPE_RATE_8G*     |                                             |
| cg_powerdown   | cp_powerdown      | P0                | Valid values for the pipe powerdown signal  |
|                |                   | P0s               |                                             |
|                |                   | P1                |                                             |
|                |                   | P2                |                                             |
| data_bus_width | cp_data_bus_width | bus_width_8_bits  | Valid values for the data_bus_width signal. |
|                |                   | bus_width_16_bits |                                             |
|                |                   | bus_width_32_bits |                                             |

\* Exists for 8G models only

### B.7.2 PIPE Interface Callbacks

Callbacks in the PIPE interface are listed in [Table B-9](#).

**Table B-9 PIPE callbacks**

| Function Name                                                                    | Arguments           | I/O | Values                    |
|----------------------------------------------------------------------------------|---------------------|-----|---------------------------|
| UpdateRate                                                                       | rate [1:0]          | I   | Pipe rate value           |
| Called every time the pipe signal rate changes.                                  |                     |     |                           |
| UpdataPowerDown                                                                  | powerdown[2:0]      | I   | Pipe powerdown value      |
| Called every time the pipe signal powerdown changes.                             |                     |     |                           |
| UpdateDataBusWidth                                                               | data_bus_width[1:0] | I   | Pipe data bus width value |
| This function is called every time the pipe signal data_bus_width changes value. |                     |     |                           |

**Table B-9 PIPE callbacks (Continued)**

|                                                                                                                                                           |                   |     |                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----|-------------------------------|
| UpdateTxPipeLane<br><br>This function is called once per lane per pipe clock cycle and copies over all of the tx signals for 1 lane into class variables. | lane_number (int) |     | lane number to be updated     |
|                                                                                                                                                           | tx_data[31:0]     |     | transmit data                 |
|                                                                                                                                                           | tx_data_k[3:0]    |     | transmit data control bits    |
|                                                                                                                                                           | tx_compliance     |     | transmit compliance           |
|                                                                                                                                                           | tx_data_valid*    |     | data_valid                    |
|                                                                                                                                                           | tx_start_block*   |     | start block                   |
|                                                                                                                                                           | tx_sync_header*   |     | transmit sync header          |
|                                                                                                                                                           | tx_elec_idle      |     | transmit electrical idle      |
| UpdateRxPipeLane<br><br>This function is called once per lane per pipe clock cycle and copies over all of the rx signals for 1 lane into class variables. | rx_data[31:0]     |     | receive data                  |
|                                                                                                                                                           | rx_data_k[3:0]    |     | receive data control bits     |
|                                                                                                                                                           | rx_status[1:0]    |     | receive status                |
|                                                                                                                                                           | rx_valid          |     | receive data valid            |
|                                                                                                                                                           | rx_elec_idle      |     | receive electricle idle       |
|                                                                                                                                                           | rx_data_valid*    |     | receive data valid            |
|                                                                                                                                                           | rx_start_block*   |     | received start of a new block |
|                                                                                                                                                           | rx_sync_header*   |     | value of sync header          |
| SampleRate<br><br>Called immediately after UpdateRate()                                                                                                   | n/a               | n/a | n/a                           |
|                                                                                                                                                           |                   |     |                               |
| SamplePowerDown<br><br>Called immediately after SamplePowerDown()                                                                                         | n/a               | n/a | n/a                           |
|                                                                                                                                                           |                   |     |                               |
| SampleDataBusWidth<br><br>Called immediately after UpdateDataBusWidth().                                                                                  | n/a               | n/a | n/a                           |
|                                                                                                                                                           |                   |     |                               |
| SampleTxPipeLane<br><br>Called once per pipe clock after all tx lanes are updated                                                                         | n/a               | n/a | n/a                           |
|                                                                                                                                                           |                   |     |                               |
| SampleRxPipeLane<br><br>Called once per pipe clock after all rx lanes are updated.                                                                        | n/a               | n/a | n/a                           |
|                                                                                                                                                           |                   |     |                               |
| *These signals present in 8G models only                                                                                                                  |                   |     |                               |

## B.8 Mapping Legacy Covergroups to Corresponding New Covergroups

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| Legacy Covergroup                                   | Mapped New Unified Covergroup                                                        | Comments Mapped New Unified Covergroup                                                                                                                          |
|-----------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cg_tx_dllp                                          | dl_downstream_traveling_dllp_cg                                                      | Available from O-2018.06-2 release                                                                                                                              |
| cg_rx_dllp                                          | dl_upstream_traveling_dllp_cg                                                        | Available from O-2018.06-2 release                                                                                                                              |
| cg_tx_tlp                                           | tl_downstream_traveling_tlp_cg                                                       | Available from O-2018.06-2 release                                                                                                                              |
| cg_rx_tlp                                           | tl_upstream_traveling_tlp_cg                                                         | Available from O-2018.06-2 release                                                                                                                              |
| cg_tx_tc_vc_mapping                                 | tl_downstream_traveling_tlp_cg<br>tl_upstream_traveling_tlp_cg                       | Available from O-2018.06-2 release<br>TC TLP field is covered as part of TLP coverage in upstream/downstream direction instead of user programed TC-VC mapping. |
| cg_rx_tc_vc_mapping                                 |                                                                                      | Available from O-2018.06-2 release<br>TC TLP field is covered as part of TLP coverage in upstream/downstream direction instead of user programed TC-VC mapping. |
| cg_tx_tlp_prefix                                    | tl_tlp_prefix_cg                                                                     | Available from O-2018.06-2 release                                                                                                                              |
| cg_rx_tlp_prefix                                    |                                                                                      | Available from O-2018.06-2 release                                                                                                                              |
| cg_tx_ipg                                           | dl_tx_inter_packet_gap_cg                                                            | Available from O-2018.06-3 release                                                                                                                              |
| cg_rx_ipg                                           | dl_rx_inter_packet_gap_cg                                                            | Available from O-2018.06-3 release                                                                                                                              |
| cg_max_payload_size                                 | tl_downstream_traveling_tlp_cg::length_cp<br>tl_upstream_traveling_tlp_cg::length_cp | Available from O-2018.06-2 release<br>TLP length is covered on RX & TX Path instead of programed Max Payload Size Configuration attribute                       |
| cg_max_payload_size_cross_rate_cross_width          | NA                                                                                   |                                                                                                                                                                 |
| cg_negotiated_data_rate                             | pl_link_speed_cg                                                                     | Available from O-2018.06-2 release                                                                                                                              |
| cg_negotiated_link_width                            | pl_link_width_cg                                                                     | Available from O-2018.06-2 release                                                                                                                              |
| cg_negotiated_data_rate_cross_negotiated_link_width | pl_link_width_and_speed_cg                                                           | Available from O-2018.06-3 release                                                                                                                              |
| cg_disable_scrambling                               | pl_ts_os_type_lane*::symbol_5_ts_disable_scrambling_cp                               | Available from O-2018.06-2 release                                                                                                                              |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b>                                    | <b>Mapped New Unified Covergroup</b>                                                       | <b>Comments Mapped New Unified Covergroup</b>                                                                         |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| cg_disable_scrambling_cross_rate                            | NA                                                                                         |                                                                                                                       |
| cg_ltssm_state_transitions                                  | ltssm_state_transition_cg                                                                  | Available from O-2018.06-2 release                                                                                    |
| cg_ltssm_state_transitions_cross_rate_cross_width           | ltssm_state_transition_cross_speed_cg                                                      | Available from O-2018.06-3 release<br>Only LTSSM state transition that variable with speed will be crossed with rate. |
| cg_tx_10s_substate_transitions                              | ltssm_tx_10s_cg::tx_10s_state_cp                                                           | Available from O-2018.06-2 release                                                                                    |
| cg_cross_tx_10s_substate_transitions_cross_rate_cross_width | ltssm_tx_10s_cg::tx_10s_state_transition_current_speed_cc                                  | Available from O-2018.06-3 release                                                                                    |
| cg_rx_10s_substate_transitions                              | ltssm_rx_10s_cg                                                                            | Available from O-2018.06-2 release                                                                                    |
| cg_cross_rx_10s_substate_transitions_cross_rate_cross_width | ltssm_rx_10s_cg::rx_10s_state_transition_current_speed_cc                                  | Available from O-2018.06-3 release                                                                                    |
| cg_ltssm_10_exit_reasons                                    | ltssm_state_transition_with_reason_cg::L0_STATE_TRANS_CP                                   | Available from O-2018.06-2 release                                                                                    |
| cg_ltssm_10_exit_reasons_cross_rate                         | ltssm_state_transition_with_reason_cg::L0_STATE_TRANS_CURRENT_SPEED_CC                     | Available from O-2018.06-3 release                                                                                    |
| cg_rx_advertised_n_fts                                      | pl_ts_os_type_lane*_cg::symbol_3_n_fts_cp<br>pl_ts_os_advertised_n_fts_cross_rate_lane*_cg | Available from O-2018.06-3 release                                                                                    |
| cg_tx_advertised_n_fts                                      | pl_ts_os_type_lane*_cg::symbol_3_n_fts_cp<br>pl_ts_os_advertised_n_fts_cross_rate_lane*_cg | Available from O-2018.06-3 release                                                                                    |
| cg_skp_tx_between_fts                                       | pl_skp_tx_between_fts_cg                                                                   | Available from O-2018.06-3 release                                                                                    |
| cg_skp_rx_between_fts                                       | pl_skp_rx_between_fts_cg                                                                   | Available from O-2018.06-3 release                                                                                    |
| cg_num_eie_before_fts                                       | pl_num_eie_symbol_before_fts_cg                                                            | Available from O-2018.06-3 release                                                                                    |
| cg_num_eieos_after_fts                                      | pl_num_eieos_after_fts_cg                                                                  | Available from O-2018.06-3 release                                                                                    |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b>                  | <b>Mapped New Unified Covergroup</b>                                                                | <b>Comments Mapped New Unified Covergroup</b> |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------|
| cg_tx_skp_os_interval_in_symbol_times     | pl_tx_skp_interval_cg                                                                               | Available from O-2018.06-3 release            |
| cg_tx_skp_os_interval_in_blocks           | pl_tx_skp_interval_cg                                                                               | Available from O-2018.06-3 release            |
| cg_tx_lane_skew                           | pl_tx_lane_skew_cg                                                                                  | Available from O-2018.06-3 release            |
| cg_num_txdetectrx_in_detect_active        | LTSSM<br>DETECT_ACTIVE_STATE_TRANS_CP::TO_<br>DETECT QUIET_LTSSM_TRANSITION_RCV<br>R_DET_FAILED bin | Available from O-2018.06-2 release            |
| cg_num_tx_skp_symbols_in_sos_8b10b        | pl_tx_skp_os_lane*_cg::skp_8b_10b_length_cp                                                         | Available from O-2018.06-2 release            |
| cg_num_tx_skp_symbols_in_sos_128b130b     | pl_tx_skp_os_lane*_cg::skp_128b_130b_length_cp                                                      | Available from O-2018.06-2 release            |
| cg_num_tx_symbols_in_last_eios_8b10b      | pl_tx_eios_lane*_cg::eios_tx_8b10b_len_cp                                                           | Available from O-2018.06-2 release            |
| cg_num_tx_symbols_in_last_eios_128b130b   | pl_tx_eios_lane*_cg::eios_tx_128b130b_len_cp                                                        | Available from O-2018.06-2 release            |
| cg_tx_ui_skew                             | pl_tx_lane_ui_skew_cg                                                                               | Available from O-2018.06-3 release            |
| cg_eq_phase2_preset_request_accepted      | pl_equalization_phase2_requests_request_lane*_cg                                                    | Available from O-2018.06-3 release            |
| cg_eq_phase3_preset_request_accepted      | pl_equalization_phase3_requests_request_lane*_cg                                                    | Available from O-2018.06-3 release            |
| cg_eq_phase2_coefficient_request_accepted | pl_equalization_phase2_requests_request_lane*_cg                                                    | Available from O-2018.06-3 release            |
| cg_eq_phase3_coefficient_request_accepted | pl_equalization_phase3_requests_request_lane*_cg                                                    | Available from O-2018.06-3 release            |
| cg_tx_kchar                               | pl_8B10B_k_code_lane*_cg                                                                            | Available from O-2018.06-2 release            |
| cg_rx_kchar                               | pl_8B10B_k_code_without_stp_and_sdplane*_cg                                                         | Available from O-2018.06-2 release            |
| cg_tx_token                               | pl_128b130b_token_cg                                                                                | Available from O-2018.06-2 release            |
| cg_rx_token                               |                                                                                                     | Available from O-2018.06-2 release            |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b>      | <b>Mapped New Unified Covergroup</b>                                                                                                                                                                                               | <b>Comments Mapped New Unified Covergroup</b> |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| cg_tx_eqts_dc_balance         | pl_ts_os_type_lane*_cg::symbol_14_to_symbol_15_dc_balance_cp                                                                                                                                                                       | Available from O-2018.06-2 release            |
| cg_rx_eqts_dc_balance         |                                                                                                                                                                                                                                    | Available from O-2018.06-2 release            |
| cg_link_error_type            | Partially covered by<br>pipe_status_if_rx_status_lane*_cg                                                                                                                                                                          | Available from O-2018.06-2 release            |
| cg_link_error_type_cross_rate |                                                                                                                                                                                                                                    | Available from O-2018.06-2 release            |
| Not Available                 | pl_tx_lane_sub_ui_skew_cg                                                                                                                                                                                                          | Available from O-2018.06-3 release            |
| Not Available                 | tl_upstream_traveling_message_cg                                                                                                                                                                                                   | Available from O-2018.06-2 release            |
| Not Available                 | tl_downstream_traveling_message_cg                                                                                                                                                                                                 | Available from O-2018.06-2 release            |
| Not Available                 | d1_d1cmssm_cg                                                                                                                                                                                                                      | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_state_rc_cg /<br>ltssm_state_ep_cg                                                                                                                                                                                           | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_state_transition_with_reason_cg<br>ltssm_state_transition_with_reason_rc_cg /<br>ltssm_state_transition_with_reason_ep_cg                                                                                                    | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_tx_low_power_state_10s_cg                                                                                                                                                                                                    | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_rx_low_power_state_10s_cg                                                                                                                                                                                                    | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_low_power_state_11_cg                                                                                                                                                                                                        | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_low_power_state_12_rc_cg /<br>ltssm_low_power_state_12_ep_cg                                                                                                                                                                 | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_initial Bring_up_2_5_gts_cg<br>ltssm_initial Bring_up_5_gts_cg<br>ltssm_initial Bring_up_8_gts_rc_cg /<br>ltssm_initial Bring_up_8_gts_ep_cg<br>ltssm_initial Bring_up_16_gts_rc_cg /<br>ltssm_initial Bring_up_16_gts_ep_cg | Available from O-2018.06-2 release            |
| Not Available                 | ltssm_recovery_rc_cg /<br>ltssm_recovery_ep_cg                                                                                                                                                                                     | Available from O-2018.06-2 release            |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b> | <b>Mapped New Unified Covergroup</b>                                                                                                                                                | <b>Comments Mapped New Unified Covergroup</b> |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Not Available            | ltssm_polling_compliance_cg                                                                                                                                                         | Available from O-2018.06-2 release            |
| Not Available            | ltssm_disabled_cg                                                                                                                                                                   | Available from O-2018.06-2 release            |
| Not Available            | ltssm_hot_reset_cg                                                                                                                                                                  | Available from O-2018.06-2 release            |
| Not Available            | ltssm_loopback_cg                                                                                                                                                                   | Available from O-2018.06-2 release            |
| Not Available            | ltssm_idle_to_rlock_cg                                                                                                                                                              | Available from O-2018.06-2 release            |
| Not Available            | ltssm_speed_negotiation_rc_cg/lts<br>sm_speed_negotiation_ep_cg                                                                                                                     | Available from O-2018.06-2 release            |
| Not Available            | pl_speed_change_max_5_0gts_cg<br>pl_speed_change_max_8_0gts_cg<br>pl_speed_change_max_16_0gts_cg                                                                                    | Available from O-2018.06-2 release            |
| Not Available            | pl_link_width_change_x2_cg<br>pl_link_width_change_x4_cg<br>pl_link_width_change_x8_cg<br>pl_link_width_change_x12_cg<br>pl_link_width_change_x16_cg<br>pl_link_width_change_x32_cg | Available from O-2018.06-2 release            |
| Not Available            | pl_os_type_lane*_cg -<br>pl_os_type_lane32_cg                                                                                                                                       | Available from O-2018.06-2 release            |
| Not Available            | pl_ts_os_type_lane32_cg -<br>pl_ts_os_type_lane32_cg                                                                                                                                | Available from O-2018.06-2 release            |
| Not Available            | pl_8B10B_data_symbol_with_nrd_lan<br>e*_cg -<br>pl_8B10B_data_symbol_with_nrd_lan<br>e32_cg                                                                                         | Available from O-2018.06-2 release            |
| Not Available            | pl_8B10B_data_symbol_with_prd_lan<br>e*_cg -<br>pl_8B10B_data_symbol_with_prd_lan<br>e32_cg                                                                                         | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_sris_enable_lane*_cg                                                                                                                                                    | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_elasticity_buff_mode_<br>lane*_cg                                                                                                                                       | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_tx_detect_rx_loopback<br>_lane*_cg                                                                                                                                      | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_tx_elec_idle_lane*_cg<br>pipe_cmd_if_tx_elec_idle_lane*_4_4_cg                                                                                                          | Available from O-2018.06-2 release            |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b> | <b>Mapped New Unified Covergroup</b>                                                                                                                                                                   | <b>Comments Mapped New Unified Covergroup</b>                                                                                                                                              |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not Available            | pipe_cmd_if_tx_compliance_lane*_cg<br>pipe_cmd_if_tx_compliance_lane*_4_4_cg                                                                                                                           | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_tx_compliance_and_tx_elec_idl_e_lane*_cg<br>pipe_cmd_if_tx_compliance_and_tx_elec_idl_e_lane*_4_4_cg                                                                                       | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_rx_polarity_lane*_cg                                                                                                                                                                       | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_reset_n_lane*_cg                                                                                                                                                                           | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_power_down_lane*_cg                                                                                                                                                                        | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_phy_specific_power_dow_n_lane*_4_0_cg<br>pipe_cmd_if_phy_specific_power_dow_n_lane*_4_3_cg                                                                                                 | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_control_signal_decode_lane*_cg<br>pipe_cmd_if_control_signal_decode_lane*_4_4_cg                                                                                                           | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_rate_lane*_2_0_cg<br>pipe_cmd_if_rate_lane*_4_0_cg<br>pipe_cmd_if_rate_lane*_4_2_cg<br>pipe_cmd_if_rate_lane*_4_4_cg                                                                       | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_width_lane*_cg                                                                                                                                                                             | Available from O-2018.06-2 release                                                                                                                                                         |
| Not Available            | pipe_cmd_if_pclk_rate_lane*_4_0_cg<br>pipe_cmd_if_pclk_rate_lane*_4_3_cg<br>pipe_cmd_if_pclk_rate_lane*_4_4_cg<br>pipe_cmd_if_pclk_rate_lane*_5_1_cg<br>pipe_cmd_if_pclk_rate_serdes_arch_lane*_5_1_cg | Available from O-2018.06-2 release<br>Available from O-2018.06-2 release<br>Available from O-2018.06-2 release<br>Available from O-2018.12-3 release<br>Available from O-2018.12-3 release |
| Not Available            | pipe_cmd_if_rate_width_and_pclk_rate_lane*_4_0_cg<br>pipe_cmd_if_rate_width_and_pclk_rate_lane*_4_3_cg<br>pipe_cmd_if_rate_width_and_pclk_rate_lane*_4_4_cg                                            | Available from O-2018.06-2 release                                                                                                                                                         |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b> | <b>Mapped New Unified Covergroup</b>                                                                                                                                    | <b>Comments Mapped New Unified Covergroup</b> |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Not Available            | pipe_cmd_if_local_tx_coefficients_valid_lane*_4_0_cg                                                                                                                    | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_local_tx_preset_coefficients_lane*_4_0_cg<br>pipe_cmd_if_local_tx_preset_coefficients_lane*_4_2_cg<br>pipe_cmd_if_local_tx_preset_coefficients_lane*_4_4_cg | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_tx_deemph_lane*_4_0_cg<br>pipe_cmd_if_tx_deemph_lane*_4_2_cg<br>pipe_cmd_if_tx_deemph_lane*_4_4_cg                                                          | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_rx_preset_hint_lane*_cg                                                                                                                                     | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_local_fs_lane*_4_0_cg<br>pipe_cmd_if_local_fs_lane*_4_2_cg<br>pipe_cmd_if_local_fs_lane*_4_4_cg                                                             | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_local_lf_lane*_4_0_cg<br>pipe_cmd_if_local_lf_lane*_4_2_cg<br>pipe_cmd_if_local_lf_lane*_4_4_cg                                                             | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_local_preset_index_lane*_4_0_cg<br>pipe_cmd_if_local_tx_preset_coefficients_lane*_4_2_cg<br>pipe_cmd_if_local_preset_index_lane*_4_4_cg                     | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_get_local_preset_coefficients_lane*_4_0_cg                                                                                                                  | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_fs_lane*_4_0_cg<br>pipe_cmd_if_fs_lane*_4_2_cg<br>pipe_cmd_if_fs_lane*_4_4_cg                                                                               | Available from O-2018.06-2 release            |
| Not Available            | pipe_cmd_if_lf_lane*_4_0_cg<br>pipe_cmd_if_lf_lane*_4_2_cg<br>pipe_cmd_if_lf_lane*_4_4_cg                                                                               | Available from O-2018.06-2 release            |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b> | <b>Mapped New Unified Covergroup</b>                                                                                                                                                         | <b>Comments Mapped New Unified Covergroup</b>                            |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| Not Available            | pipe_cmd_if_rx_eq_eval_lane*_4_0_cg<br>pipe_cmd_if_rx_eq_eval_lane*_4_2_cg<br>pipe_cmd_if_rx_eq_eval_lane*_4_4_cg                                                                            | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_rx_eq_in_progress_lane*_4_2_cg<br>pipe_cmd_if_rx_eq_in_progress_lane*_4_4_cg                                                                                                     | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_link_eval_feedback_figure_of_merit_lane*_4_0_cg<br>pipe_cmd_if_link_eval_feedback_figure_of_merit_lane*_4_2_cg<br>pipe_cmd_if_link_eval_feedback_figure_of_merit_lane*_4_4_cg    | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_link_eval_feedback_direction_change_lane*_4_0_cg<br>pipe_cmd_if_link_eval_feedback_direction_change_lane*_4_2_cg<br>pipe_cmd_if_link_eval_feedback_direction_change_lane*_4_4_cg | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_invalid_request_lane*_4_0_cg<br>pipe_cmd_if_invalid_request_lane*_4_2_cg<br>pipe_cmd_if_invalid_request_lane*_4_4_cg                                                             | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_tx_margin_lane*_cg                                                                                                                                                               | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_tx_swing_lane*_cg                                                                                                                                                                | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_rx_standby_lane*_cg                                                                                                                                                              | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_cmd_if_rx_standby_status_lane*_cg                                                                                                                                                       | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_status_if_phy_status_lane*_cg                                                                                                                                                           | Available from O-2018.06-2 release                                       |
| Not Available            | pipe_status_if_rx_status_lane*_cg<br>pipe_status_if_rx_status_serdes_arch_lane*_cg                                                                                                           | Available from O-2018.06-2 release<br>Available from O-2018.12-3 release |
| Not Available            | pipe_status_if_pclk_change_ok_lane*_cg                                                                                                                                                       | Available from O-2018.06-2 release                                       |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| <b>Legacy Covergroup</b> | <b>Mapped New Unified Covergroup</b>                                                                                                                  | <b>Comments Mapped New Unified Covergroup</b>                                                                  |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| Not Available            | pipe_status_if_pclk_change_ack_lane*_cg                                                                                                               | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_if_data_bus_width_lane*_cg                                                                                                                   | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_if_rxidle_disable_lane*_cg<br>pipe_cmd_if_rxidle_disable_lane*_5_1_cg                                                                        | Available from O-2018.06-2 release<br>Available from O-2018.09-3 release                                       |
| Not Available            | pipe_cmd_if_txcommonmode_disable_lane*_cg<br>pipe_cmd_if_txcommonmode_disable_lane*_5_1_cg                                                            | Available from O-2018.06-2 release<br>Available from O-2018.09-3 release                                       |
| Not Available            | pipe_cmd_if_ref_clk_required_n_lane*_cg                                                                                                               | Available from O-2018.09-3 release                                                                             |
| Not Available            | pipe_cmd_if_serdes_arch_lane*_5_1_cg                                                                                                                  | Available from O-2018.12-3 release                                                                             |
| Not Available            | pipe_cmd_if_rx_width_lane*_5_1_cg                                                                                                                     | Available from O-2018.12-3 release                                                                             |
| Not Available            | pipe_mbi_m2p_lane*_cg                                                                                                                                 | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_mbi_p2m_lane*_cg                                                                                                                                 | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_status_if_async_power_change_ack_lane*_cg                                                                                                        | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_if_tx_block_align_control_lane*_4_0_cg<br>pipe_cmd_if_tx_block_align_control_lane*_4_2_cg<br>pipe_cmd_if_tx_block_align_control_lane*_4_4_cg | Available from O-2018.06-2 release<br>Available from O-2018.06-2 release<br>Available from O-2018.09-3 release |
| Not Available            | pipe_data_if_tx_data_k_lane*_cg                                                                                                                       | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_data_if_rx_data_k_lane*_cg                                                                                                                       | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_mbi_mac_reg_rx_margin_status_0_lane*_4_4_cg                                                                                                  | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_mbi_mac_reg_rx_margin_status_1_lane*_4_4_cg                                                                                                  | Available from O-2018.06-2 release                                                                             |
| Not Available            | pipe_cmd_mbi_mac_reg_rx_margin_status_2_lane*_4_4_cg                                                                                                  | Available from O-2018.06-2 release                                                                             |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| Legacy Covergroup | Mapped New Unified Covergroup                                              | Comments Mapped New Unified Covergroup |
|-------------------|----------------------------------------------------------------------------|----------------------------------------|
| Not Available     | pipe_cmd_mbi_mac_reg_elastic_buffer_status_lane*_4_4_cg                    | Available from O-2018.06-2 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_elastic_buffer_location_lane*_5_1_cg                  | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_rx_link_eval_status_0_lane*_5_1_cg                    | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_rx_link_eval_status_1_lane*_5_1_cg                    | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_rx_status_4_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_rx_status_5_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_tx_status_0_1_2_lane*_5_1_cg                          | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_tx_status_3_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_tx_status_4_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_tx_status_5_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_mac_reg_tx_status_6_lane*_5_1_cg                              | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_rx_margin_control_0_lane*_4_4_cg                      | Available from O-2018.06-2 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_rx_margin_control_1_lane*_4_4_cg                      | Available from O-2018.06-2 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_elastic_buffer_control_lane*_4_4_cg                   | Available from O-2018.06-2 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_rx_control_0_lane*_5_1_cg                             | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_rx_control_3_lane*_5_1_cg                             | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_elastic_buffer_location_update_frequency_lane*_5_1_cg | Available from O-2018.09-3 release     |

**Table B-10 Mapping Legacy Covergroups to Corresponding New Covergroups**

| Legacy Covergroup | Mapped New Unified Covergroup                      | Comments Mapped New Unified Covergroup |
|-------------------|----------------------------------------------------|----------------------------------------|
| Not Available     | pipe_cmd_mbi_phy_reg_rx_control_4_lane*_5_1_cg     | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_tx_control_2_3_4_lane*_5_1_cg | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_tx_control_5_lane*_5_1_cg     | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_tx_control_6_lane*_5_1_cg     | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_tx_control_7_lane*_5_1_cg     | Available from O-2018.09-3 release     |
| Not Available     | pipe_cmd_mbi_phy_reg_tx_control_8_lane*_5_1_cg     | Available from O-2018.09-3 release     |

# C Partition Compile and Precompiled IP

---

In design verification, every compilation and recompilation of the design and testbench contributes to the overall project schedule. A typical System-on-Chip (SoC) design may have one or more VIPs where changes are performed in the design or the testbench outside of VIPs. During the development cycle and the debug cycle, the complete design along with the VIP is recompiled, which leads to increased compilation time.

Verification Compiler offers the integration of VIPs with Partition Compile (PC) and Precompiled IP (PIP) flows. This integration offers a scalable compilation strategy that minimizes the VIP recompliations, and thus improves the compilation performance. This further reduces the overall time to market of a product during the development cycle and improves the productivity during the debug cycle.

The PC and PIP features in Verification Compiler provide the following solutions to optimize the compilation performance:

- ❖ The partition compile flow creates partitions (of module, testbench or package) for the design and recompiles only the changed or the modified partitions during the incremental compile.
- ❖ The PIP flow allows you to compile a self-contained functional unit separately in a design and a testbench. A shared object file and a debug database are generated for a self-contained functional unit. All of the generated shared object files and debug databases are integrated in the integration step to generate a simv executable. Only the required PIPs are recompiled with incremental changes in design or testbench.

For more information on the partition compile and Precompiled IP flows, see the VCS/VCS MX LCA Features Guide.

## C.1 Implementing Partition Compile in Testbench

To effectively utilize the partition compile technology, PCIe VIP internally creates multiple sub-packages under existing top package, `svt_PCIE_uvm_pkg`. The created multiple sub packages are compiled in parallel to improve the overall VIP compilation time. The compile time improvement depends on the number of cores selected for parallel execution. PCIe VIP sub-packages are mainly based on PCIe protocol layers like Transport, Data Link and Physical Layers along with separate package for coverage at each layer.

The partition compile feature is disabled by default. To enable the partition compile mode, you must perform the following functions:

- ❖ Include the file, `import_PCIE_svt_uvm_pkgs.svi` to import all individual sub-packages.
- ❖ Set the compile macro, `SVT_PCIE_OPTIMIZED_COMPILE` in the compilation command.

### C.1.1 High Level Architecture

The PCIe VIP creates multiple sub-packages for parallel compilation under existing PCIe UVM Package, `svt_PCIE_uvm_pkg`. Following is the list of multiple sub-packages required to enable parallel compilation:

- ❖ `svt_PCIE_common_uvm_pkg`
- ❖ `svt_PCIE_t1_uvm_pkg` (TL Layer Tx/Rx)
- ❖ `svt_PCIE_d1_uvm_pkg` (DL Layer TX/Rx)
- ❖ `svt_PCIE_pl_pkg_common_uvm_pkg` (PL Layer Common)
- ❖ `svt_PCIE_pl_uvm_pkg` (PL Layer Tx/Rx)
- ❖ `svt_PCIE_t1_coverage_uvm_pkg` (TL Coverage)
- ❖ `svt_PCIE_d1_coverage_uvm_pkg` (DL Coverage)
- ❖ `svt_PCIE_pl_coverage_uvm_pkg` (PL Coverage)
- ❖ `svt_PCIE_sequence_sequencer_collection_uvm_pkg` (Sequence Collection)

### C.1.2 Guidelines for Partition Compile Usages

PCIe VIP support for partition compile feature is mostly backward compatible with the default VIP flow. Following are the scenarios where changes may be required to support partition compile flow:

#### 1. Avoid explicit file import from package.

A conflict can occur in scenarios, where class data type is referenced along with the existing PCIe package name using scope resolution. For example,

```
import svt_PCIE_uvm_pkg::svt_PCIE_configuration;
```

This existing class may have been moved to a new sub-package to support multiple partitions. Therefore, it is required to either change the package of explicit import of class

```
`ifdef SVT_PCIE_OPTIMIZED_COMPILE
import svt_PCIE_common_uvm_pkg::svt_PCIE_configuration;
`elseif
import svt_PCIE_uvm_pkg::svt_PCIE_configuration
`endif
```

Or, export the class file in the top package itself

```
export svt_PCIE_common_uvm_pkg::svt_PCIE_configuration;
```

#### 2. Avoid accessing data class members using package name.

Example:

```
svt_PCIE_uvm_pkg::svt_PCIE_target_app_configuration::UNINIT_MEM_READ_RESP_BAAD;
```

This can cause an error because files might have been moved to a new package. If such access have been used at multiple places, then export the file in PCIe VIP top package, `svt_PCIE_uvm_pkg`.

Example:

```
export svt_PCIE_common_uvm_pkg::svt_PCIE_target_app_configuration;
```

## C.2 Use Model

You can use the three new simulation targets in the Makefiles of the VIP UVM examples to run the examples in the partition compile or the precompiled IP flow. In addition, Makefiles allow you to run the examples in back-to-back VIP configurations. The VIP UVM examples are located in the following directory:

```
$VC_HOME/examples/vl/vip/svt/vip_title/sverilog
```

For example,

```
/project/vc_install/examples/vl/vip/svt/pcie_svt/sverilog
```

Each VIP UVM example includes a configuration file called as the pc.optcfg file. This configuration file contains predefined partitions or precompiled IPs for the SystemVerilog packages that are used by VIP. The predefined partitions are created using the following heuristics:

- ❖ Separate partitions are created for packages that are common to multiple VIPs.
- ❖ The VIP level partitions are defined in a way that all of the partitions are compiled in the similar duration of time. This enables the optimal use of parallel compile with the -fastpartcomp option.

You can modify the pc.optcfg configuration file to include additional testbench or DUT level partitions.

### C.2.1 Parallel Partition Compile

You must perform these steps to enable the parallel partition compilation flow with SVT PCIe VIP:

1. Provide the VCS compile argument:

```
+define+SVT_PCIE_OPTIMIZED_COMPILE
```

2. Enable the partition compile flow using VCS partition compile options:

```
-partcomp -fastpartcomp=j<N> +optconfigfile+pc.optcfg
```

3. Import all the packages or sub-packages at user testbench Top file. It is recommended to include methodology specific import file, say for example,

```
`include "import_PCIE_SVT_UVM_pkgs.svi"
```



**Note** Use auto partition if you have less number of cores. When the number of available cores is less than 4, use the auto partitioning—that is, do not provide the pc.optcfg file with new packages because the partition compile on less cores with many partition degrades the compilation performance.

## C.3 The “vcspcvlog” Simulator Target in Makefiles

The vcspcvlog simulator target in the Makefiles of the VIP UVM examples enables compilation of the examples in the two-step partition compile flow. The following partition compile options are used:

```
-partcomp +optconfigfile+pc.optcfg -fastpartcomp=j4 -lca  
+define+SVT_PCIE_OPTIMIZED_COMPILE
```

One partition is created for each line specified in the pc.optcfg configuration file. The -fastpartcomp=j4 option enables parallel compilation of partitions on different cores of a multi-core machine. You can incorporate the partition compile options listed above into your existing vcs command line.

In the partition compile flow, changes in the testbench, VIP, or DUT source code trigger recompilation in only the required partitions. You must ensure that the Verification Compiler compilation database is not deleted between successive recompilations.

## C.4 The “vcsmxpcvlog” Simulator Target in Makefiles

The vcsmxpcvlog simulator target in the Makefiles of the VIP UVM examples enables compilation of the examples in the three-step partition compile flow. The following partition compile options are used:

```
-partcomp +optconfigfile+pc.optcfg -fastpartcomp=j4 -lca
+define+SVT_PCIE_OPTIMIZED_COMPILE
```

There is no change in the vlogan commands. One partition is created for each line specified in the pc.optcfg configuration file. The -fastpartcomp=j4 option enables parallel compilation of partitions on different cores of a multi-core machine. You can incorporate the partition compile options listed above into your existing vcs command line.

In the partition compile flow, changes in the testbench, VIP, or DUT source code trigger recompilation only in the required partitions. You must ensure that the Verification Compiler compilation database is not deleted between successive recompilations.

## C.5 The “vcsmxpipvlog” Simulator Target in Makefiles

The vcsmxpipvlog simulator target in the Makefiles of the VIP UVM examples enables compilation of the examples in the PIP flow. There is no change in the vlogan commands. One PIP compilation command with the -genip option is created for each line specified in the pc.optcfg configuration file. The -integ option is used in the integration step to generate the simv executable.

In the PIP flow, changes in the testbench, VIP, or DUT source code trigger recompilation in only the required PIPs. You must ensure that the Verification Compiler compilation database is not deleted between successive recompilations.

## C.6 Precompiled IP Implementation in Testbenches with Verification IPs

You can use the Makefiles in the VIP UVM examples as a template to set up the partition compile or PIP flow in your design and verification environment by performing the following steps:

- ❖ Modify the pc.optcfg configuration file to include the user-defined partitions. The recommendations are as follows:
  - ◆ Create four to eight overall partitions (DUT and VIP combined).
  - ◆ Some VIP packages may include separate packages for transmitter and receiver VIPs. If only a transmitter or a receiver VIP is required, then the unused package can be removed from the configuration file.
  - ◆ Continue to use separate partitions for common packages, such as uvm\_pkg and svt\_uvm\_pkg, as defined in the VIP configuration file.
- ❖ Incorporate the partition compile or precompiled IP command line options documented in previous sections or issued by the Makefile targets into the vcs command lines.

For more information on partition compile and precompiled IP options, such as, -sharedlib and -pcmakeprof, see the VCS/VCS MX LCA Features Guide.

## C.7 Example

The following are the steps to integrate VIPs into the partition compile and PIP flows:

1. Once you set the VC\_HOME variable, the VC\_VIP\_HOME variable is automatically set to the following location:

\$VC\_HOME/vl

2. Check the available VIP examples using the following command:

```
$VC_VIP_HOME/bin/dw_vip_setup -i home
```

3. Install the example.

For example, to install the PCIe UVM Unified Example, use the following command:

```
$VC_VIP_HOME/bin/dw_vip_setup -e pcie_svt/tb_PCIE_SVT_UVM_UNIFIED_VIP_SYS -svtb
```

```
cd examples/sverilog/pcie_svt/tb_PCIE_SVT_UVM_UNIFIED_VIP_SYS
```

4. Run the tests present in the tests directory in the example.

For example, to run the ts.base\_test.sv test in the VCS two-step flow with partition compile, use the following command:

```
gmake base_test USE_SIMULATOR=vcspcvlog
```

To run the ts.base\_test.sv test in the VCS UUM flow with partition compile, use the following command:

```
gmake base_test USE_SIMULATOR=vcsmxpcvlog
```

To run the ts.base\_test.sv test in the VCS UUM flow with precompiled IP, use the following command:

```
gmake base_test USE_SIMULATOR=vcsmxpipvlog
```

5. To modify or change the partitions, you must change the pc.optcfg file for the example.

# D Protocol Checks

---

A number of automatic protocol checks are built into the PCIe VIP, to test for compliance with the PCIe specification. The HTML class reference documentation includes the protocol checks of the following groups:

Active component protocol check groups:

- ❖ ACTIVE\_PL\_LANE\_ENDEC
- ❖ ACTIVE\_PL\_LANE\_OS
- ❖ ACTIVE\_PL\_LANE\_PCS
- ❖ ACTIVE\_PL\_PIPE8
- ❖ ACTIVE\_PIPE
- ❖ ACTIVE\_PL\_LANE\_SERDES
- ❖ ACTIVE\_PL
- ❖ ACTIVE\_DL
- ❖ ACTIVE\_TL
- ❖ ACTIVE\_TARGET\_APP
- ❖ ACTIVE\_REQUESTER\_APP
- ❖ ACTIVE\_DRIVER\_APP

For check description and PCIe specification version, see “Protocol Checks” tab in the HTML class reference documentation available at the following locations:

- ❖ PCIe SVT  
`$DESIGNWARE_HOME/vip/svt/pcie_svt/latest/doc/pcie_svt_uvm_class_reference/html/protocolChecks.html`

# E PCIe PIE-8 Interface

The PIE-8 specification is the "*PHY Interface Extensions Supporting 8GT/s PCIe*" (Revision 2.02 dated October 1, 2014). It is an extension of the PIPE 2.0 specification that supports 8.0GT/s and 16.0GT/s data rates and equalization at those rates.



**Attention** Synopsys supports only that portion of this PIE-8 specification as it relates to passing information to and from the PHY for equalization control and response.

## E.1 Supported Interface Signals

[Table E-1](#) lists the PIE-8 signals implemented to support equalization functionality.

**Table E-1 PIE-8 Control/Response Signals**

| Name         | Direction | Active Level | Description                                                                                                                                                                    |
|--------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MacDataEn    | Input     | High         | Used for 8.0 GT/s and 16.0 GT/s equalization and setting Lane numbers. When '1', a transfer to the PHY is in-progress. One signal per Lane.                                    |
| MacData[5:0] | Input     | N/A          | Used with MACDataEn for 8.0 GT/s and 16.0 GT/s equalization and setting Lane numbers. Control and data for equalization control and setting Lane numbers. One signal per Lane. |
| PhyDataEn    | Ouput     | High         | Used for 8.0 GT/s and 16.0 GT/s equalization. When '1', a transfer to the MAC is in-progress. One signal per Lane.                                                             |
| PhyData[5:0] | Ouput     | N/A          | Used with PhyDataEn for 8.0 GT/s and 16.0 GT/s equalization. Control and data for equalization control. One signal per Lane.                                                   |

All other signals are the same as the PIPE 4.3 specification (PCLK as PHY output) with the exception of those signals specified in the following table.

**Table E-2 PIPE 4.3 Equalization Signals Not Used**

| Name                       | Spipe Dir. | Lane 0 Mpipeline / Spipe Name                                              | Mpipeline / Spipe Task                   |
|----------------------------|------------|----------------------------------------------------------------------------|------------------------------------------|
| GetLocalPresetCoefficients |            |                                                                            |                                          |
|                            | Input      | get_local_preset_coefficients_0 / attached_get_local_preset_coefficients_0 | PipeSerdesEqControl / PipeSlaveEqControl |
| LocalTxCoefficientsValid   |            |                                                                            |                                          |
|                            | Output     | local_tx_coefficients_valid_0 / attached_local_tx_coefficients_valid_0     | PipeSerdesEqControl / PipeSlaveEqControl |
| LocalPresetIndex[3:0]      |            |                                                                            |                                          |
|                            | Input      | local_preset_index_0 / attached_local_preset_index_0                       | PipeSerdesEqControl / PipeSlaveEqControl |
| LocalTxPresetCoefficients  |            |                                                                            |                                          |
| [17:0]                     | Output     | local_tx_preset_coefficients_0 / attached_local_tx_preset_coefficients_0   | PipeSerdesEqControl / PipeSlaveEqControl |
| LocalFS[5:0]               |            |                                                                            |                                          |
|                            | Output     | local_fs_0 / attached_local_fs_0                                           | PipeSerdesEqControl / PipeSlaveEqControl |
| LocalLF[5:0]               |            |                                                                            |                                          |
|                            | Output     | local_lf_0 / attached_local_lf_0                                           | PipeSerdesEqControl / PipeSlaveEqControl |
| RxEqEval                   |            |                                                                            |                                          |
|                            | Input      | rx_eq_eval_0 / attached_rx_eq_eval_0                                       | PipeSerdesEqControl / PipeSlaveControl   |
| InvalidRequest             |            |                                                                            |                                          |
|                            | Input      | invalid_request_0 / attached_invalid_request_0                             | PipeSerdesEqControl / PipeSlaveEqControl |
| TxDeemph[17:0]             |            |                                                                            |                                          |
|                            | Input      | tx_deemph_0 / attached_tx_deemph_0                                         | PipeSerdesEqControl / PipeSlaveEqControl |
| FS[5:0]                    |            |                                                                            |                                          |
|                            | Input      | fs_0 / attached_fs_0                                                       | PipeSerdesEqControl / No connection      |

**Table E-2 PIPE 4.3 Equalization Signals Not Used (Continued)**

| Name                                        | Spipe Dir. | Lane 0 Mpipeline / Spipe Name                                                          | Mpipeline / Spipe Task                   |
|---------------------------------------------|------------|----------------------------------------------------------------------------------------|------------------------------------------|
| LF[5:0]                                     |            |                                                                                        |                                          |
|                                             | Input      | lf_0 / attached_lf_0                                                                   | PipeSerdesEqControl / No connection      |
| RxPresetHint[2:0]                           |            |                                                                                        |                                          |
|                                             | Input      | rx_preset_hint_0 / attached_rx_preset_hint_0                                           | PipeSerdesEqControl / PipeSlaveEqControl |
| LinkEvaluationFeedbackFigureMerit[7:0]      |            |                                                                                        |                                          |
|                                             | Output     | link_eval_feedback_figure_of_merit_0 / attached_link_eval_feedback_figure_of_merit_0   | PipeSerdesEqControl / PipeSlaveEqControl |
| LinkEvaluationFeedbackDirectionChange [5:0] |            |                                                                                        |                                          |
|                                             | Output     | link_eval_feedback_direction_change_0 / attached_link_eval_feedback_direction_change_0 | PipeSerdesEqControl / PipeSlaveEqControl |
| RxEqInProgress                              |            |                                                                                        |                                          |
|                                             | Input      | rx_eq_in_progress_0 / attached_rx_eq_in_progress_0                                     | PipeSerdesEqControl / PipeSlaveControl   |

## E.2 Configuration Parameters

The following table [Table E-3](#) lists configuration members for setting the PIE8 Interface in the class `svt_pcie_pl_configuration`. For additional information for the PHY layer configuration consult the HTML Reference documentation.

**Table E-3 PIE-8 Parameters**

| Configuration Name  | Description                                                                                                                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pie8_mode_en        | Enable PIE-8 mode (PHY Interface Extensions Supporting 8GT/s PCIe):<br>Enables the PIE-8 mode state machines (either as MAC master1dor PHY Slave based on <code>is_pie8_mode_master = SVT_PCIE_IS_PIE8_MODE_MASTER_DEFAULT;</code> ) |
| is_pie8_mode_master | Indicates whether the component is PIE8 master or PIE8 slave. When set to 1, acts as PIE8 master. When set to 0, acts as PIE8 slave.                                                                                                 |

**Table E-3 PIE-8 Parameters (Continued)**

| Configuration Name                            | Description                                                                                                                                                                                                                                           |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pie8_phy_delay_to_tx_cmd_out_min              | If performing as a PHY slave for the PIE-8 interface, This is the minimum number of PClk cycles that the PIE-8 slave state machine will wait in the PHY_RX_WAIT_TX_PHY_RESP state before asserting PHYDataEn signal and proceeding toward completion. |
| pie8_phy_delay_to_tx_cmd_out_max              | If performing as a PHY slave for the PIE-8 interface, This is the maximum number of PClk cycles that the PIE-8 slave state machine will wait in the PHY_RX_WAIT_TX_PHY_RESP state before asserting PHYDataEn signal and proceeding toward completion. |
| pie8_enable_equalization_checks               | When set to a 1, it enables the PIE-8 checks in the PIE8 PHY state machine. The checks performed are enabled individually as defined by pie8_enable_equalization_checks = SVT_PCIE_PIE8_ENABLE_EQUALIZATION_CHECKS_DEFAULT;                           |
| pie8_equalization_check_vector                | Enable PIE-8 checks when pie8_enable_equalization_checks is set to 1.                                                                                                                                                                                 |
| pie8_max_mac_wait_delay_to_phy_dataen_timeout | The maximum time (in ns) that a lane's Pie8MacStateMachine will wait in its TX_WAIT_RX_PHY_RESP state for the PHYDataEn signal to be received.                                                                                                        |

### E.3 Status Class PIE8 Members

The following table [Table E-4](#) lists all the status members for the PIE8 interface in the class svt\_PCIE\_pl\_status.

**Table E-4 PIE8 Members in Class svt\_PCIE\_pl\_status**

| PIE8 Member         | Description                                                                     |
|---------------------|---------------------------------------------------------------------------------|
| last_pie8_mac_state | Last state of the PIE-8 MAC master state machine. See list below for states.    |
| last_pie8_phy_state | Last state of the PIE-8 PHY slave state machine. See list below for states      |
| pie8_mac_state      | Current state of the PIE-8 MAC master state machine. See list below for states. |
| pie8_phy_state      | Current state of the PIE-8 PHY slave state machine. See list below for states.  |

These are the possible PIE8 PHY states:

- ❖ PHY\_RX\_IDLE
- ❖ PHY\_RX\_DATA

- ❖ PHY\_RX\_WAIT\_TX\_PHY\_RESP
- ❖ PHY\_TX\_CMD\_OUT
- ❖ PHY\_TX\_DATA
- ❖ PHY\_WAIT\_EVAL\_RESP
- ❖ PHY\_WAIT\_MAC\_DATA\_EN\_DROP

These are the possible PIE8 MAC states

- ❖ MAC\_TX\_IDLE
- ❖ MAC\_TX\_CMD\_OUT
- ❖ MAC\_TX\_DATA(`SVT\_PCIE\_STATE\_PIE8\_MAC\_TX\_DATA )
- ❖ MAC\_TX\_WAIT\_RX\_PHY\_RESP
- ❖ MAC\_RX\_DATA
- ❖ MAC\_WAIT\_PHY\_DATA\_EN\_DROP

## E.4 PHY PIE-8 ASCII Signals

The following table lists the ASCII signals on the PIE-8 PHY.

**Table E-5** **PHY PIE-8 ASCII Signals**

| Signal Name                  | Description                                                                  |
|------------------------------|------------------------------------------------------------------------------|
| ascii_pie8_lane<n>_mac_state | <n> = 0 to 31.<br>Current state of Lane <n>'s MAC PIE-8 Master state machine |
| ascii_pie8_lane<n>_phy_state | <n> = 0 to 31.<br>Current state of Lane <n>'s MAC PIE-8 Slave state machine  |

## E.5 PHY PIE-8 Internal Signals

The following signals may be helpful in debugging DUT issues (only one of these machines will be active in a given "root" or "endpoint" model). They are per lane and for both the MAC and PHY.

**Table E-6** **MAC Internal PIE-8 "per Lane" Signals**

| Signal Name         | Description                                                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pie8_mac_state      | Current state of a Lane's MAC PIE-8 Master state machine                                                                                                   |
| last_pie8_mac_state | Previous state of a Lane's MAC PIE-8 Master state machine                                                                                                  |
| pie8_cycle_en       | "Per bit" start of a Lane's MAC PIE-8 Master state machine                                                                                                 |
| pie8_command        | Current active command of a Lane's MAC PIE-8 Master state machine (if pie8_cycle_en[lane_num]" is a "1").                                                  |
| pie8_command_done   | Last command of a Lane's MAC PIE-8 Master state machine has completed.                                                                                     |
| pie8_num_tx_data    | Number of data cycles to be transmitted by a Lane's MAC PIE-8 Master state machine. Loaded when command starts and pre-decremented as data is transmitted. |

**Table E-6 MAC Internal PIE-8 "per Lane" Signals**

| Signal Name          | Description                                                                                                                                                                                                                                                                                                        |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pie8_phy_rx_control  | First datum received by a Lane's MAC PIE-8 Master state machine when the "PhyDataEn" for that lane is first asserted. Valid only when pie8_cycle_en[lane_num]" is a "1".                                                                                                                                           |
| pie8_exp_num_rx_data | Number of data cycles to be received by a Lane's MAC PIE-8 Master state machine. Will start out as greater than 0 for MAC commands that expect a PHY response. Loaded when "PhyDataEn" for that lane is first asserted and pre-decremented as data is received. Valid only when pie8_cycle_en[lane_num]" is a "1". |

**Table E-7 PHY Internal PIE-8 "per Lane" Signals**

| Signal Name          | Description                                                                                                                                                                                                                                                                 |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pie8_phy_state       | Current state of a Lane's PHY PIE-8 Slave state machine                                                                                                                                                                                                                     |
| last_pie8_phy_state  | Previous state of a Lane's PHY PIE-8 Slave state machine                                                                                                                                                                                                                    |
| pie8_num_tx_data     | Number of data cycles to be transmitted by a Lane's MAC PIE-8 Slave state machine. Loaded when command starts and pre-decremented as data is transmitted.                                                                                                                   |
| pie8_exp_num_rx_data | Number of data cycles to be received by a Lane's PHY PIE-8 Slave state machine from the MAC. Will start out as greater than 0 for MAC commands that expect a PHY response. Loaded when "MACDataEn" for that lane is first asserted and pre-decremented as data is received. |

## E.6 PIE-8 Protocol Check "MSGCODEs"

The following table list the "MSGCODEs" associated with PIE-8 protocol and data checking.

**Table E-8 PIE-8 MSGCODES**

| Signal Name                                        | Description                                                                                                                                                                                                                                                                    |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSGCODE_PCIESVC_PIE8_PHY_RX_PRESET_MISCOMPARE      |                                                                                                                                                                                                                                                                                |
|                                                    | The "Pie8PhyStateMachine" checks that the "preset" it received from the MAC in the "Set Initial Presets" command is the one expected based on what was saved by the VIP in its respective "upstream_preset_reg" or "downstream_preset_reg" at the 8.0 GT/s data rate.          |
| MSGCODE_PCIESVC_PIE8_PHY_RX_PRESET_MISCOMPARE_16G  |                                                                                                                                                                                                                                                                                |
|                                                    | The "Pie8PhyStateMachine" checks that the "preset" it received from the MAC in the "Set Initial Presets" command is the one expected based on what was saved by the VIP in its respective "upstream_preset_reg_16g" or "downstream_preset_reg_16g" at the 16.0 GT/s data rate. |
| MSGCODE_PCIESVC_PIE8_PHY_RX_PRESET_HINT_MISCOMPARE |                                                                                                                                                                                                                                                                                |

**Table E-8 PIE-8 MSGCODES (Continued)**

| <b>Signal Name</b>                                                 | <b>Description</b>                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                    | The "Pie8PhyStateMachine" checks that the "preset hint" it received from the MAC in the "Set Initial Presets" command is the one expected based on what was saved by the VIP in its respective "upstream_preset_hint_reg" or "downstream_preset_hint_reg" at the 8.0 GT/s data rate.                                                              |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX PRESET_HINT_MISCOMPARE_16G</b>     |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks that the "preset hint" it received from the MAC in the "Set Initial Presets" command is the one expected based on what was saved by the VIP in its respective "upstream_preset_hint_reg_16g" or "downstream_preset_hint_reg_16g" at the 16.0 GT/s data rate.                                                     |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX PRESET_TABLE_ENTRY_INVALID</b>     |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks that the "preset" it received from the MAC in the "Request Local Preset" command has a valid entry (checks the "VALID" bit - not the coefficient rules) in its respective "upstream_tx_preset_coefficient_mapping_table" or "downstream_tx_preset_coefficient_mapping_table" at the 8.0 GT/s data rate.          |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX PRESET_TABLE_ENTRY_INVALID_16G</b> |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks that the "preset" it received from the MAC in the "Request Local Preset" command has a valid entry (checks the "VALID" bit - not the coefficient rules) in its respective "upstream_tx_preset_coefficient_mapping_table_16g" or "downstream_tx_preset_coefficient_mapping_table_16g" at the 16.0 GT/s data rate. |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX MAC DATA LESS_THAN_EXP</b>         |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks in its "PHY_RX_DATA" state that it receives the expected number of datums from the MAC for any command that receives data (more than just the "control" byte). If "MACDataEn" de-asserts before the pie8_exp_num_rx_data" for the Lane reaches "0", this check will fire.                                        |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX INVALID_MAC_DATA_EN</b>            |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks in its "PHY_RX_WAIT_TX_PHY_RESP" state to see if the "MACDataEn" is driven to a "1" again. If it is, this check will fire.                                                                                                                                                                                       |
| <b>MSGCODE_PCIE SVC PIE8 PHY RX UNSUPPORTED_MAC_CONTROL</b>        |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks in its "PHY_RX_IDLE" state whether the "control" value sent when "MACDataEn" is driven to a "1" initially is a valid "command". If it is a "reserved" or "unsupported" command (such as "Set Lane Number"), this check will fire.                                                                                |
| <b>MSGCODE_PCIE SVC PIE8 PHY MAC DATA EN RESTARTED</b>             |                                                                                                                                                                                                                                                                                                                                                   |
|                                                                    | The "Pie8PhyStateMachine" checks in its "PHY_TX_CMD_OUT", "PHY_TX_DATA" and "PHY_WAIT_EVAL_RESP" states to see if the "MACDataEn" is driven to a "1" again. If it is, this check will fire.                                                                                                                                                       |
| <b>MSGCODE_PCIE SVC PIE8 MAC UNSUPPORTED_COMMAND</b>               |                                                                                                                                                                                                                                                                                                                                                   |

**Table E-8    PIE-8 MSGCODES (Continued)**

| <b>Signal Name</b>                                       | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                          | The "Pie8MacStateMachine" checks in its "MAC_TX_IDLE" state whether its "per Lane" command ("pie8_command[lane_num]") that it received from the LTSSM when its "pie8_command[lane_num]" bit was asserted is a valid PIE-8 MAC "Information Transfer". If it is not a valid MAC "Information Transfer", this check will fire and the state machine will remain in the "MAC_TX_IDLE" state, clearing the offending command.                                                            |
| <b>MSGCODE_PCIE SVC PIE8_MAC_RX_DATA_LESS_THAN_EXP</b>   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                          | The "Pie8MacStateMachine" checks in its "MAC_RX_DATA" state whether its "per Lane" expected number of datums for the currently active command (pie8_exp_num_rx_data[lane_num]) have been received (reached "0") before the "PHYDataEn" is de-asserted. If "PHYDataEn" is de-asserted before this value reaches "0", this check will fire. This means that the PHY did not send all the data required for the command sent to it.                                                     |
| <b>MSGCODE_PCIE SVC PIE8_MAC_RX_DATA_MORE_THAN_EXP</b>   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                          | The "Pie8MacStateMachine" checks in its "MAC_WAIT_PHY_DATA_EN_DROP" state that the "PHYDataEn" is de-asserted. If the "PHYDataEn" remains asserted, this check will fire. This means that the PHY is sending too much data for the command sent to it.                                                                                                                                                                                                                               |
| <b>MSGCODE_PCIE SVC PIE8_MAC_WAIT_PHY_DATAEN_TIMEOUT</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                          | The "Pie8MacStateMachine" checks in its "MAC_TX_WAIT_RX_PHY_RESP" state that the "PHYDataEn" is asserted before the timeout defined by the "PIE9_MAX_MAC_WAIT_DELAY_TO_PHY_DATAEN_TIMEOUT_VAR" (in nS). If "PHYDataEn" is not asserted within this timeout value, the MAC state machine will fire this check, clear the current command and return to its "MAC_TX_IDLE" state. This would be the result of the PHY not responding in time to the MAC "Information Transfer" command. |

# F Verilog Task/Parameter to SVT Class Mapping

This appendix provides mapping from SVC Verilog or SVT Verilog tasks and parameters to SVT UVM class members, for users who are migrating from the SVC or SVT Verilog PCIe VIP to the UVM PCIe.

This appendix contains the following sections:

- ❖ [Transaction Layer Verilog Tasks and Parameters to UVM Class Members Map](#)
- ❖ [Data Link Layer Verilog Tasks and Parameters to UVM Class Member Maps](#)

## F.1 Transaction Layer Verilog Tasks and Parameters to UVM Class Members Map

This section contains the following tables:

- ❖ [Transaction Layer Verilog Task to UVM Class Member Map](#)
- ❖ [Transaction Layer Verilog Parameters to UVM Class Members Map](#)

### F.1.1 Transaction Layer Verilog Task to UVM Class Member Map

Transaction Layer Verilog tasks are mapped to SVT class members in [Table F-1](#), listed alphabetically by Verilog task.

**Table F-1 Map of Transaction Layer Verilog tasks to UVM class members**

| Verilog Task              | UVM Class Member                                    |
|---------------------------|-----------------------------------------------------|
| AddATAddrApplIdMapEntry() | svt_PCIE_TL_Service::ADD_AT_ADDR_APPL_ID_MAP_EN_TRY |
| AddCfgBDFApplIdMapEntry() | svt_PCIE_TL_Service::ADD_CFG_BDF_APPL_ID_MAP_EN_TRY |
| AddIOAddrApplIdMapEntry() | svt_PCIE_TL_Service::ADD_IO_ADDR_APPL_ID_MAP_EN_TRY |

**Table F-1 Map of Transaction Layer Verilog tasks to UVM class members (Continued)**

| <b>Verilog Task</b>            | <b>UVM Class Member</b>                                                                                                            |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| AddMemAddrApplIdMapEntry()     | svt_PCIE_TL_SERVICE::ADD_MEM_ADDR_APPL_ID_MAP_ENTRY                                                                                |
| AddRequesterIdApplIdMapEntry() | svt_PCIE_TL_SERVICE::ADD_RID_APPL_ID_MAP_ENTRY                                                                                     |
| AddRidMsgCodeApplIdMapEntry()  | svt_PCIE_TL_SERVICE::ADD_RID_MSG_CODE_APPL_ID_MAP_ENTRY                                                                            |
| CheckFinalCredits()            | svt_PCIE_TL_SERVICE::CHECK_FINAL_CREDITS                                                                                           |
| ClearStats()                   | svt_PCIE_TL_SERVICE::CLEAR_STATS                                                                                                   |
| DisplayATAddrApplidMap()       | svt_PCIE_TL_SERVICE::DISPLAY_AT_ADDR_APPL_ID_MAP                                                                                   |
| DisplayCfgBDFApplidMap()       | svt_PCIE_TL_SERVICE::DISPLAY_CFG_BDF_APPL_ID_MAP                                                                                   |
| DisplayIOAddrApplidMap()       | svt_PCIE_TL_SERVICE::DISPLAY_IO_ADDR_APPL_ID_MAP                                                                                   |
| DisplayMemAddrApplidMap()      | svt_PCIE_TL_SERVICE::DISPLAY_MEM_ADDR_APPL_ID_MAP                                                                                  |
| DisplayRidApplidMap()          | svt_PCIE_TL_SERVICE::DISPLAY_RID_APPL_ID_MAP                                                                                       |
| DisplayRidMsgCodeApplidMap()   | svt_PCIE_TL_SERVICE::DISPLAY_RID_MSG_CODE_APPL_ID_MAP                                                                              |
| DisplayStats()                 | svt_PCIE_TL_SERVICE::DISPLAY_STATS                                                                                                 |
| IsTransactionLayerIdle()       | svt_PCIE_TL_SERVICE::IS_TL_IDLE                                                                                                    |
| IsVcEnabled                    | svt_PCIE_TL_STATUS::vc_enabled                                                                                                     |
| IsVcInitFinished()             | svt_PCIE_TL_STATUS::vc_initialized                                                                                                 |
| QueryCreditCounts()            | svt_PCIE_TL_STATUS::credits_allocated::credit_limit::credits_consumed::credits_received::init_credits_allocated::init_credit_limit |
| QueryRxCreditsAvailable()      | svt_PCIE_TL_STATUS::rx_credits_available[48]                                                                                       |
| QueryTxCreditsAvailable()      | svt_PCIE_TL_STATUS::tx_credits_available[48]                                                                                       |
| ResetTL()                      | svt_PCIE_TL_SERVICE::RESET_TL                                                                                                      |
| SetCreditThreshold()           | svt_PCIE_TL_SERVICE::SET_CREDIT_THRESHOLD                                                                                          |
| SetTrafficClassMap()           | svt_PCIE_TL_SERVICE::SET_TRAFFIC_CLASS_MAP                                                                                         |
| SetVcEnable()                  | svt_PCIE_TL_SERVICE::SET_VC_ENABLE                                                                                                 |

### F.1.2 Transaction Layer Verilog Parameters to UVM Class Members Map

Transaction Layer Verilog parameters are mapped to UVM class members in [Table F-2](#), listed alphabetically by Verilog parameter.

**Table F-2 Map of Transaction Layer class members to parameters**

| Verilog Parameter                  | UVM Class Member                                              |
|------------------------------------|---------------------------------------------------------------|
| ATOMIC_OPS_SUPPORTED               | svt_PCIE_TL_Configuration::atomic_ops_supported               |
| AUTO_ENABLE_VC0_AT_STARTUP         | svt_PCIE_TL_Configuration::auto_enable_vc0_at_startup         |
| BYPASS_TX_FLOW_CONTROL_GATE        | svt_PCIE_TL_Configuration::bypass_tx_flow_control_gate        |
| CCIX_VC                            | svt_PCIE_TL_Configuration::ccix_vc                            |
| CREDIT_STARVATION_TIMEOUT_NS       | svt_PCIE_TL_Configuration::credit_starvation_timeout_ns       |
| DEFAULT_ROUTE_AT_APPL_ID           | svt_PCIE_TL_Configuration::default_route_at_appl_id           |
| DEFAULT_ROUTE_CCIX_APPL_ID         | svt_PCIE_TL_Configuration::default_route_ccix_appl_id         |
| DEFAULT_ROUTE_CFG_TYPE0_APPL_ID    | svt_PCIE_TL_Configuration::default_route_cfg_type0_appl_id    |
| DEFAULT_ROUTE_CFG_TYPE1_APPL_ID    | svt_PCIE_TL_Configuration::default_route_cfg_type1_appl_id    |
| DEFAULT_ROUTE_IO_APPL_ID           | svt_PCIE_TL_Configuration::default_route_at_appl_id           |
| DEFAULT_ROUTE_MEM_APPL_ID          | svt_PCIE_TL_Configuration::default_route_mem_appl_id          |
| DEFAULT_ROUTE_MSG_APPL_ID          | svt_PCIE_TL_Configuration::default_route_msg_appl_id          |
| DISPLAY_VC_QUEUES_PERIOD_NS        | svt_PCIE_TL_Configuration::display_vc_queues_period_ns        |
| ENABLE_ARI                         | svt_PCIE_TL_Configuration::enable_ari                         |
| ENABLE_CCIX_OPTIMIZED_TLP          | svt_PCIE_TL_Configuration::enable_ccix_optimized_tlp          |
| ENABLE_INIT_CREDIT_CHECK           | svt_PCIE_TL_Configuration::enable_init_credit_check           |
| ENABLE_MULTI_ENDPOINT_MODE         | svt_PCIE_TL_Configuration::enable_multi_endpoint_mode         |
| ENABLE_REORDER_VC_QUEUES           | svt_PCIE_TL_Configuration::enable_reorder_vc_queues           |
| ENABLE_ROUTE_AT_TO_FUNCTION        | svt_PCIE_TL_Configuration::enable_route_at_to_function        |
| ENABLE_ROUTE_CFG_TYPE0_TO_FUNCTION | svt_PCIE_TL_Configuration::enable_route_cfg_type0_to_function |
| ENABLE_ROUTE_CFG_TYPE1_TO_FUNCTION | svt_PCIE_TL_Configuration::enable_route_cfg_type1_to_function |
| ENABLE_ROUTE_IO_TO_FUNCTION        | svt_PCIE_TL_Configuration::enable_route_io_to_function        |
| ENABLE_ROUTE_MEM_TO_FUNCTION       | svt_PCIE_TL_Configuration::enable_route_mem_to_function       |
| ENABLE_ROUTE_MSG_TO_FUNCTION       | svt_PCIE_TL_Configuration::enable_route_msg_to_function       |
| IS_CCIX_TRANSACTION_LAYER          | svt_PCIE_TL_Configuration::is_ccix_transaction_layer          |
| IS_SWITCH                          | svt_PCIE_TL_Configuration::is_switch                          |

| Verilog Parameter                     | UVM Class Member                                                |
|---------------------------------------|-----------------------------------------------------------------|
| MAX_DMWR_SUPPORTED_SIZE               | svt_PCIE_TL_Configuration::max_dmem_wr_supported_size           |
| MAX_VC[0-7]_[P/NP/CPL]_UPDATEFC_DELAY | svt_PCIE_TL_Configuration::max_vc[0-7]_[p n cpl]_updatefc_delay |
| MIN_VC[0-7]_[P/NP/CPL]_UPDATEFC_DELAY | svt_PCIE_TL_Configuration::min_vc[0-7]_[p n cpl]_updatefc_delay |
| NUM_VC_[P/NP/CPL]_DATA_INIT_CREDITS   | svt_PCIE_TL_Configuration::init_[p n cpl]_data_tx_credits       |
| NUM_VC_[P/NP/CPL]_HDR_INIT_CREDITS    | svt_PCIE_TL_Configuration::init_[p n cpl]_hdr_tx_credits        |
| REMOTE_EXTENDED_TAG_FIELD_ENABLED     | svt_PCIE_TL_Configuration::remote_extended_tag_field_enabled    |
| REMOTE_IS_SWITCH                      | svt_PCIE_TL_Configuration::remote_is_switch                     |
| REMOTE_MAX_PAYLOAD_SIZE               | remote_max_payload_size::remote_max_payload_size                |
| REMOTE_MAX_READ_REQUEST_SIZE          | svt_PCIE_TL_Configuration::remote_max_read_request_size         |
| REMOTE_RC_PEER_TO_PEER_SUPPORTED      | svt_PCIE_TL_Configuration::remote_rc_peer_to_peer_supported     |

## F.2 Data Link Layer Verilog Tasks and Parameters to UVM Class Member Maps

- ❖ Data Link Layer Verilog Task to UVM Class Member Map
- ❖ Data Link Layer Verilog Parameter to UVM Class Member Map

### F.2.1 Data Link Layer Verilog Task to UVM Class Member Map

Data Link Layer Verilog tasks are mapped to UVM class members in [Table F-3](#), listed alphabetically by Verilog task.

**Table F-3 Map of Data Link Layer Verilog tasks to UVM class members**

| Verilog Task                           | UVM Class Member                                                 |
|----------------------------------------|------------------------------------------------------------------|
| clearstats                             | svt_PCIE_DL_Service::CLEAR_STATS                                 |
| displayattachedacknaklatencytolerances | svt_PCIE_DL_Service::DISPLAY_ATTACHED_ACK_NAK_LATENCY_TOLERANCES |
| displayattachedreplaytimeouttolerances | svt_PCIE_DL_Service::DISPLAY_ATTACHED_REPLY_TIMER_TOLERANCES     |
| displaystats                           | svt_PCIE_DL_Service::DISPLAY_STATS                               |
| gatetxacknak                           | svt_PCIE_DL_Service::GATE_TX_ACKNAK                              |
| gatetxinitfc1                          | svt_PCIE_DL_Service::GATE_TX_INITFC1                             |

| Verilog Task                         | UVM Class Member                                                                                     |
|--------------------------------------|------------------------------------------------------------------------------------------------------|
| gatetxinitfc2                        | svt_PCIE_DL_SERVICE::GATE_TX_INITFC2                                                                 |
| gatetxupdatefc                       | svt_PCIE_DL_SERVICE::GATE_TX_UPDATEFC                                                                |
| initiateaspmexit                     | svt_PCIE_DL_SERVICE::INITIATE_ASPM_EXIT                                                              |
| initiateaspmL0sentry                 | svt_PCIE_DL_SERVICE::INITIATE_ASPM_L0S_ENTRY                                                         |
| initiateaspmL1entry                  | svt_PCIE_DL_SERVICE::INITIATE_ASPM_L1_ENTRY                                                          |
| initiatepmexit                       | svt_PCIE_DL_SERVICE::INITIATE_PM_EXIT                                                                |
| initiatepml1entry                    | svt_PCIE_DL_SERVICE::INITIATE_PM_L1_ENTRY                                                            |
| initiatepml23entry                   | svt_PCIE_DL_SERVICE::INITIATE_PM_L23_ENTRY                                                           |
| pauselinkperformancemonitoring       | svt_PCIE_DL_SERVICE::PAUSE_LINK_PERFORMANCE_MONITORING                                               |
| receiveddllp                         | svt_PCIE_DL::RECEIVED_DLLP_OBSERVED_PORT                                                             |
| receivedtlp                          | svt_PCIE_DL::RECEIVED_TLP_OBSERVED_PORT                                                              |
| resetduetodlinactive                 | svt_PCIE_DL_SERVICE::RESET_DL                                                                        |
| resetlinkperformancestats            | svt_PCIE_DL_SERVICE::RESET_LINK_PERFORMANCE_STATS                                                    |
| resumelinkperformancemonitoring      | svt_PCIE_DL_SERVICE::RESUME_LINK_PERFORMANCE_MONITORING                                              |
| sentdllp                             | svt_PCIE_DL::SENT_DLLP_OBSERVED_PORT                                                                 |
| senttlp                              | svt_PCIE_DL::SENT_TLP_OBSERVED_PORT                                                                  |
| setackfactor                         | svt_PCIE_DL_SERVICE::SET_ACK_FACTOR                                                                  |
| setattachedacknaklatencytolerance    | svt_PCIE_DL_CONFIGURATION::ATTACHED_ACK_NAK_LATENCY_TOLERANCE_XN WHERE N IS 1, 2, 34, 8, 12, 16, 32. |
| setattachedreplayextendedsynctimeout | svt_PCIE_DL_CONFIGURATION::ATTACHED_REPLAY_EXTENDED_SYNC_TIMEOUT                                     |
| setattachedreplaytimeout             | svt_PCIE_DL_CONFIGURATION::ATTACHED_REPLAY_TIMEOUT                                                   |
| setattachedreplaytimeouttolerance    | svt_PCIE_DL_CONFIGURATION::ATTACHED_REPLAY_TIMEOUT_TOLERANCE_XN WHERE N IS 1, 2, 4, 8, 12, 16, 32.   |
| setlinkenable                        | svt_PCIE_DL_SERVICE::SET_LINK_ENABLE                                                                 |
| setmaxacknaklatency                  | svt_PCIE_DL_CONFIGURATION::MAX_ACK_NAK_LATENCY                                                       |
| setmaxattachedacknaklatency          | svt_PCIE_DL_CONFIGURATION::MAX_ATTACHED_ACK_NAK_LATENCY                                              |
| setmaxattachednaklatency             | svt_PCIE_DL_CONFIGURATION::MAX_ATTACHED_NAK_LATENCY                                                  |

| Verilog Task                 | UVM Class Member                                       |
|------------------------------|--------------------------------------------------------|
| setminacknaklatency          | svt_PCIE_DL_Configuration::min_ack_nak_latency         |
| setminattachedacknaklatency  | svt_PCIE_DL_Configuration::minAttachedAckNakLatency    |
| setreplayextendedsynctimeout | svt_PCIE_DL_Configuration::replay_ExtendedSyncTimeout  |
| setreplaytimeout             | svt_PCIE_DL_Configuration::replay_timeout              |
| setpostdllptxinterpacketgap  | svt_PCIE_DL_Service::SET_POST_TX_DLLP_INTER_PACKET_GAP |

## F.2.2 Data Link Layer Verilog Parameter to UVM Class Member Map

Data Link Layer Verilog parameters are mapped to UVM class members in [Table F-4](#), listed alphabetically by Verilog parameter.

**Table F-4 Map of Data Link Layer class members to tasks**

| Verilog Parameter                       | UVM Class Member                                             |
|-----------------------------------------|--------------------------------------------------------------|
| ASPM_TIMEOUT_CNT_LIMIT                  | svt_PCIE_DL_Configuration::aspm_timeout_cnt_limit            |
| ATTACHED_INTERNAL_DELAY_2_5G            | svt_PCIE_DL_Configuration::attachedInternalDelay2_5g         |
| ATTACHED_INTERNAL_DELAY_5G              | svt_PCIE_DL_Configuration::attachedInternalDelay5g           |
| ATTACHED_INTERNAL_DELAY_8G              | svt_PCIE_DL_Configuration::attachedInternalDelay8g           |
| ATTACHED_INTERNAL_DELAY_16G             | svt_PCIE_DL_Configuration::attachedInternalDelay16g          |
| DL_FEATURE_ACK_TIMEOUT_NS               | svt_PCIE_DL_Configuration::dlFeatureAckTimeoutNs             |
| DL_FEATURE_INTERVAL_NS                  | svt_PCIE_DL_Configuration::dlFeatureIntervalNs               |
| ENABLE_ASPM_L0S_ENTRY                   | svt_PCIE_DL_Configuration::enableAspmL0sEntry                |
| ENABLE_ASPM_L1_1_ENTRY                  | svt_PCIE_DL_Configuration::enableAspmL1_1Entry               |
| ENABLE_ASPM_L1_2_ENTRY                  | svt_PCIE_DL_Configuration::enableAspmL1_2Entry               |
| ENABLE_ASPM_L1_ENTRY                    | svt_PCIE_DL_Configuration::enableAspmL1Entry                 |
| ENABLE_DL_FEATURE_HANDSHAKE             | svt_PCIE_DL_Configuration::enableDlFeatureHandshake          |
| ENABLE_EI_TX_TLP_ON_RETRY               | svt_PCIE_DL_Configuration::enableEiTlpOnRetry                |
| ENABLE_GEN3_REPLAY_TIMEOUT_CALC_IN_GEN4 | svt_PCIE_DL_Configuration::enableGen3ReplayTimeoutCalcInGen4 |
| ENABLE_PM_L1_1_ENTRY                    | svt_PCIE_DL_Configuration::enablePmL1_1Entry                 |
| ENABLE_PM_L1_2_ENTRY                    | svt_PCIE_DL_Configuration::enablePmL1_2Entry                 |
| ENABLE_TX_TLP_REPORTING                 | svt_PCIE_DL_Configuration::enableTxTlpReporting              |

| Verilog Parameter                     | UVM Class Member                                                |
|---------------------------------------|-----------------------------------------------------------------|
| ENTER_RECOVERY_ON_INFERRRED_ELEC_IDLE | svt_PCIE_DL_Configuration::enter_recovery_on_inferred_elec_idle |
| INITFC_TIMEOUT_NS                     | svt_PCIE_DL_Configuration::initfc_timeout_ns                    |
| INITIAL_RECEIVE_SEQUENCE_VALUE        | svt_PCIE_DL_Configuration::initial_receive_sequence_value       |
| INITIAL_TRANSMIT_SEQUENCE_VALUE       | svt_PCIE_DL_Configuration::initial_transmit_sequence_value      |
| INTERNAL_DELAY_2_5G                   | svt_PCIE_DL_Configuration::internal_delay_2_5g                  |
| INTERNAL_DELAY_5G                     | svt_PCIE_DL_Configuration::internal_delay_5g                    |
| INTERNAL_DELAY_8G                     | svt_PCIE_DL_Configuration::internal_delay_8g                    |
| INTERNAL_DELAY_16G                    | svt_PCIE_DL_Configuration::internal_delay_16g                   |
| LOS_IDLE_TIMER_LIMIT_NS               | svt_PCIE_DL_Configuration::los_idle_timer_limit_ns              |
| LOCAL_DL_FEATURE_SUPPORTED            | svt_PCIE_DL_Configuration::local_dl_feature_supported           |
| LTR_L1_2_THRESHOLD_SCALE              | svt_PCIE_DL_Configuration::ltr_l1_2_threshold_scale             |
| LTR_L1_2_THRESHOLD_VALUE              | svt_PCIE_DL_Configuration::ltr_l1_2_threshold_value             |
| MAX_INITFC_DELAY                      | svt_PCIE_DL_Configuration::max_initfc_delay                     |
| MAX_NAK_LATENCY                       | svt_PCIE_DL_Configuration::max_nak_latency                      |
| MAX_NUM_REPLAYS                       | svt_PCIE_DL_Configuration::max_num_replays                      |
| MAX_NUM_RETRY_BUFFER_DWORDS           | svt_PCIE_DL_Configuration::max_num_retry_buffer_dwords          |
| MAX_PAYLOAD_SIZE                      | svt_PCIE_DL_Configuration::max_payload_size                     |
| MAX_PM_ACK_LATENCY                    | svt_PCIE_DL_Configuration::max_pm_ack_latency                   |
| MAX_SIZE_PACKET                       | svt_PCIE_DL_Configuration::max_size_packet                      |
| MAX_TX_IPG                            | svt_PCIE_DL_Configuration::max_tx_ipg                           |
| MAX_TX_NULLIFIED_TLP_LEN              | svt_PCIE_DL_Configuration::max_tx_nullified_tlp_len             |
| MAX_TX_PM_IPG                         | svt_PCIE_DL_Configuration::max_tx_pm_ipg                        |
| MAX_TX_TLP_IPG                        | svt_PCIE_DL_Configuration::max_tx_tlp_ipg                       |
| MAX_UPDATEFC_DELAY                    | svt_PCIE_DL_Configuration::max_updatefc_delay                   |
| MIN_INITFC_DELAY                      | svt_PCIE_DL_Configuration::min_initfc_delay                     |
| MIN_NAK_LATENCY                       | svt_PCIE_DL_Configuration::min_nak_latency                      |
| MIN_NUM_TX_INITFC1_CPL                | svt_PCIE_DL_Configuration::min_num_tx_initfc1_cpl               |
| MIN_NUM_TX_INITFC2_CPL                | svt_PCIE_DL_Configuration::min_num_tx_initfc2_cpl               |

| <b>Verilog Parameter</b>     | <b>UVM Class Member</b>                                 |
|------------------------------|---------------------------------------------------------|
| MIN_NUM_TX_INITFC1_NP        | svt_PCIE_DL_Configuration::min_num_tx_initfc1_np        |
| MIN_NUM_TX_INITFC2_NP        | svt_PCIE_DL_Configuration::min_num_tx_initfc2_np        |
| MIN_NUM_TX_INITFC1_P         | svt_PCIE_DL_Configuration::min_num_tx_initfc1_p         |
| MIN_NUM_TX_INITFC2_P         | svt_PCIE_DL_Configuration::min_num_tx_initfc2_p         |
| MIN_PM_ACK_LATENCY           | svt_PCIE_DL_Configuration::min_pm_ack_latency           |
| MIN_TX_IPG                   | svt_PCIE_DL_Configuration::min_tx_ipg                   |
| MIN_TX_NULLIFIED_TLP_LEN     | svt_PCIE_DL_Configuration::min_tx_nullified_tlp_len     |
| MIN_TX_PM_IPG                | svt_PCIE_DL_Configuration::min_tx_pm_ipg                |
| MIN_TX_TLP_IPG               | svt_PCIE_DL_Configuration::min_tx_tlp_ipg               |
| MIN_UPDATEFC_DELAY           | svt_PCIE_DL_Configuration::min_updatefc_delay           |
| PM_TIMEOUT_CNT_LIMIT         | svt_PCIE_DL_Configuration::pm_timeout_cnt_limit         |
| RECEIVED_DLLP_INTERFACE_MODE | svt_PCIE_DL_Configuration::received_dllp_interface_mode |
| RECEIVED_TLP_INTERFACE_MODE  | svt_PCIE_DL_Configuration::received_tlp_interface_mode  |
| RX_CREDIT_LATENCY_IN_SYMBOLS | svt_PCIE_DL_Configuration::rx_credit_latency_in_symbols |
| RX_TLP_LATENCY_IN_SYMBOLS    | svt_PCIE_DL_Configuration::rx_tlp_latency_in_symbols    |
| SENT_DLLP_INTERFACE_MODE     | svt_PCIE_DL_Configuration::sent_dllp_interface_mode     |
| SENT_TLP_INTERFACE_MODE      | svt_PCIE_DL_Configuration::sent_tlp_interface_mode      |
| TX_NULLIFIED_TLP_HDR0_VALUE  | svt_PCIE_DL_Configuration::tx_nullified_tlp_hdr0_value  |
| TX_NULLIFIED_TLP_HDR1_VALUE  | svt_PCIE_DL_Configuration::tx_nullified_tlp_hdr1_value  |
| TX_NULLIFIED_TLP_HDR2_VALUE  | svt_PCIE_DL_Configuration::tx_nullified_tlp_hdr2_value  |
| TX_NULLIFIED_TLP_HDR3_VALUE  | svt_PCIE_DL_Configuration::tx_nullified_tlp_hdr3_value  |
| UPDATEFC_TIMEOUT_NS          | svt_PCIE_DL_Configuration::updatefc_timeout_ns          |
| VC[0:7]_UPDATEFC_INTERVAL_NS | svt_PCIE_DL_Configuration::vc[0:7]_updatefc_interval_ns |

# G Multi End Point Mode

---

PCIe VIP supports the representation of multiple end-points such that there is an entire hierarchy of buses, devices, and functions connected to the DUT. The multiple end-point feature enables you to

- ❖ View the requests and the completions from multiple devices, that is, multiple requester IDs and multiple completer IDs.
- ❖ Control the address ranges associated with completer IDs through Base Address Register (BAR) configurations.

## G.1 Feature Specifications

The PCIe VIP supports the representation of multiple requesters using independent set of tags for each requester. The multiple end-point feature enables you with the following capabilities:

- ❖ User control of default BAR size through configuration object
- ❖ User configuration of BARs, via both link (value only, by either CFG type 0 or CFG type 1 accesses) and service request (value and size)
- ❖ User association of a completer ID with each BAR, via both link and service request
- ❖ User control over memory and I/O, enabled via both link and service request
- ❖ Automatic disabling of memory and I/O, enabled when link goes down
- ❖ Automatic setting of completion status for inbound requests depending on whether the address of a received request is in range; requests that do not hit a BAR will generate Unsupported Request status.
- ❖ User association of tag format with each completer ID in the AC
- ❖ Automatic checking in the AC of tags in received transactions for expected format

## G.2 Implementation

To enable the Multi-Endpoint Mode to set up multiple completer IDs, you must perform the following functions:

- ❖ (Optional) Set the default BAR size in the configuration object.

- ❖ Set up the size for each BAR via service request and configure BAR address using configuration write over the link, or
- ❖ Configure each BAR size and address via service request.



You can also use the combination of both the approaches as suggested.

This allows an arbitrary number of configuration spaces, with six BARs per configuration space. There are no changes in the VC or credit handling.

## G.3 Configurations

You can refer the configurations listed in the following table for enabling the feature:

**Table G-1 Related Configurations**

| Configuration Attribute    | Class Name                      | Description                                                                                                                                                                                                                                                                                                                               |
|----------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| enable_multi_endpoint_mode | svt_PCIE_Configuration          | <p>You can enable the support for completers in the AC by setting the configuration.</p> <p>Example:</p> <pre>bit enable_multi_endpoint_mode = 1;</pre>                                                                                                                                                                                   |
| default_bar_ro_map         | svt_PCIE_TargetAppConfiguration | <p>You can control the default size of the BAR by setting this configuration.</p> <p>Example:</p> <pre>rand bit [31:0] default_bar_ro_map = 32'h0000_ffff;</pre> <p>The setting of the bit to 1 results in the setting of the bits of all bars to be read-only by default. The default is 16-bits read-only, that is, 64 KB BAR size.</p> |

**Table G-1 Related Configurations**

| Configuration Attribute                                  | Class Name                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| multi_ep_mode_resp_ctrl_en um<br>multi_ep_mode_resp_ctrl | svt_PCIE_TARG ET_APP_CONFIGURATION | <p>You can control the response of the multi-endpoint model when there is a mismatch in the BAR size.</p> <p>Example:</p> <pre>rand multi_ep_mode_resp_ctrl_enum multi_ep_mode_resp_ctrl = NO_RESP_IF_NO_FUNCTIONS_CONFIGURED;</pre> <p>Supported values:</p> <ul style="list-style-type: none"> <li>• NO_RESP_NEVER: Respond to all requests with UR if the conditions above for SC are not met.</li> <li>• NO_RESP_IF_NO_FUNCTIONS_CONFIGURED: No response if no BDF combinations have been set up (either via service request to set up BARs or the command register, or by configuration write). Respond with UR if at least one BDF combination has been set up.</li> <li>• NO_RESP_IF_NO_SPACE_ENABLED: No response if at least one BDF configuration space has been set up but none has been configured to enable either memory or I/O space. Respond with UR if at least one BDF combination has been configured to enable either type of space.</li> <li>• NO_RESP_IF_NO_MATCHING_SPACE_ENABLED: No response if at least one BDF configuration space has been set up but none has been configured to enable the request type, that is, no function has memory space enabled if it is a memory request, or no function has I/O space enabled if it is an I/O request. Respond with UR if at least one BDF combination has been configured to enable the request type.</li> </ul> |

**Example G-1 Example Code Illustrating VIP Configurations**

```
vip_cfg.pcie_cfg.enable_multi_endpoint_mode = 1;
vip_cfg.target_cfg[0].default_bar_ro_map = 32'h0000_ffff;
vip_cfg.target_cfg[0].multi_ep_mode_resp_ctrl =
    svt_PCIE_TARGET_APP_CONFIGURATION::NO_RESP_NEVER;
```

The feature behavior is controlled using either of the following:

- ❖ Service request (using the sequences), or
- ❖ Configuration write request on the link

**Table G-2 Service Request**

| Request Type                  | Class Name                   | Description                                                                  |
|-------------------------------|------------------------------|------------------------------------------------------------------------------|
| MULTI_EP_MODE_SET_BAR_RO_M AP | svt_PCIE_TARG ET_APP_SERVICE | Used to determine BAR size by controlling which bits of a BAR are read-only. |
| MULTI_EP_MODE_GET_BAR_RO_M AP | svt_PCIE_TARG ET_APP_SERVICE | Used to check BAR size.                                                      |

**Table G-2 Service Request**

| Request Type                              | Class Name                  | Description                                                                                                                                                    |
|-------------------------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MULTI_EP_MODE_WRITE_ADDR                  | svt_PCIE_target_app_service | Used to write to a register for a specific BDF. The address uses the ECAM format. For Multi Endpoint Mode, only the Command Register and BARs are supported.   |
| MULTI_EP_MODE_READ_ADDR                   | svt_PCIE_target_app_service | Used to read a register for a specific BDF.                                                                                                                    |
| MULTI_EP_MODE_SET_COMPLETE_R_SPACE_ENABLE | svt_PCIE_target_app_service | Used to enable or disable all memory or I/O space. This is equivalent to writing the Command Register Memory or I/O enable bits for all configured BDF spaces. |
| MULTI_EP_MODE_SET_EXP_TAG_TYPE_FOR_CPL_ID | svt_PCIE_target_app_service | Used to set the expected tag type for a completer ID.                                                                                                          |

The PCIe VIP invokes the service request using the following sequences:

- ❖ svt\_PCIE\_target\_app\_service\_set\_bar\_ro\_map\_sequence
- ❖ svt\_PCIE\_target\_app\_service\_get\_bar\_ro\_map\_sequence
- ❖ svt\_PCIE\_target\_app\_service\_write\_addr\_sequence
- ❖ svt\_PCIE\_target\_app\_service\_read\_addr\_sequence
- ❖ svt\_PCIE\_target\_app\_service\_set\_completer\_space\_enable\_sequence
- ❖ svt\_PCIE\_target\_app\_service\_set\_exp\_tag\_type\_for\_cpl\_id\_sequence

#### Example G-2 Example Illustrating Service Request Configurations

- ❖ Configuring BAR2 for BDF==16'h0102 with address 32'h0ad00000:

```
Configuring BAR2 for BDF==16'h0102 with address 32'h0ad00000:
svt_PCIE_target_app_service_write_addr_sequence    write_addr_seq;
    write_addr_seq =
svt_PCIE_target_app_service_write_addr_sequence::type_id::create("write_addr_seq");
    write_addr_seq.randomize() with {ecam_addr == 28'h0102018; // The BAR2 offset is h'18
        bit_mask == 32'hffff_ffff;
        data == 32'h0ad00000;};
    write_addr_seq.start(p_sequencer.vip_virt_seqr.target_seqr[0]);
```

- ❖ Configuring BAR1 size to 1 MB:

```
svt_PCIE_target_app_service_set_bar_ro_map_sequence    set_bar_map_seq;
    set_bar_map_seq =
svt_PCIE_target_app_service_set_bar_ro_map_sequence::type_id::create("set_bar_map_seq");
    set_bar_map_seq.randomize() with {bdf_num == 16'h0102;
        bar_num == 1;
        data == 32'h000f_ffff;};
    set_bar_map_seq.start(p_sequencer.vip_virt_seqr.target_seqr[0]);
```

You can use the feature once all the configurations as suggested in this section are configured based on the requirement.



# H SolvNetPlus PCIe VIP Articles

---

The following table lists and links to all the SolvNetPlus articles published on the PCIe VIP. The articles are organized by the following categories:

- ❖ [Application Layer](#)
- ❖ [Transaction Layer](#)
- ❖ [Data Link Layer](#)
- ❖ [PHY Layer](#)
- ❖ [Methodology Testbench and Debug](#)
- ❖ [Miscellaneous](#)

## H.1 Application Layer

### H.1.1 Driver App

See the following articles:

- ❖ [VC VIP: Configuring PCIe for Sending Packets Back-to-Back](#)
- ❖ [VC VIP: Generating MSG TLPs with the PCIe VIP](#)
- ❖ [PCIe SVT VIP: Memory Read Transactions Causing an Uninitialized Memory Error](#)
- ❖ [PCIE SVT: Setting the EP Bit in a Driver Application Transaction for MemRd TLPs](#)
- ❖ [VC VIP: Setting the PCIe VIP to Expect CRS Status on Received Completions](#)
- ❖ [PCIE SVT VIP : svt\\_PCIE\\_driver\\_app\\_transaction : Config Write](#)
- ❖ [PCIe SVT svt\\_PCIE\\_driver\\_app\\_transaction transaction\\_type](#)
- ❖ [PCIE SVT VIP: svt\\_PCIE\\_driver\\_app\\_transaction, Config Read](#)
- ❖ [VC VIP: Generating Type0/Type1 Configuration Transactions in PCIe](#)
- ❖ [VC VIP: Generating Memory Write and Memory Read Transactions in PCIe](#)
- ❖ [VC VIP: Understanding PCIe EI\\_CODEs and Their Usage](#)
- ❖ [PCIe SVC Verilog VIP: Injecting Various Types of ERRORS at the Transactional Level of the Model](#)

- ❖ VC VIP: Fields of `svt_PCIE_driver_app_transaction` Class Used in Configuration Transactions in PCIe
- ❖ VC VIP: Usage Examples for `svt_PCIE_driver_app_cfg_request_sequence` (PCIe)
- ❖ VC VIP: Configuring the PCIe VIP to Not Expect a Completion for a Read Request
- ❖ VC VIP: Setting the Correct `COMPLETION_TIMEOUT_NS` Value to Avoid `APPL_DRIVER_COMMAND_TIMEOUT` Error in PCIe

### H.1.2 Target App

See the following articles:

- ❖ PCIE SVT: Create out of order completions (CPL/CPLDs) of TLP packets
- ❖ VC VIP: Generating Poisoned Completions in PCIe
- ❖ VC VIP: Sending Different Size Completion Packets
- ❖ VC VIP: Configuring PCIe to Send Completions on Second RCB
- ❖ VC VIP: Generating PCIe Error Poisoned Completions
- ❖ VC VIP: Creating Out of Order Completions with the UVM PCIe VIP
- ❖ VC VIP: Emulating a PCIe Completion Timeout Error Using the PCIe VIP
- ❖ VC VIP: Varying Completion Response Latencies in the PCIe VIP
- ❖ VC VIP: Setting Read Completion Boundaries in the PCIe VIP
- ❖ VC VIP: Updating/Setting a PCIe TLP Digest Field While Corrupting ECRC
- ❖ VC VIP: How to Control the Read Request Completion Latency in PCIe
- ❖ VC VIP: Corrupting Completions Using Target Application Callback in PCIe
- ❖ VC VIP: Guidelines for Using `max_read_cpl_data_size_in_bytes` in PCIe Target App Configuration
- ❖ VP VIP: Setting Completion Latency Values and Generating Out of Order Completions in PCIe
- ❖ VC VIP: Generating and Setting the Percentage of Error Poisoned Completions in PCIe

### H.1.3 Requester App

See the following articles:

- ❖ The SetRequestID Verilog task of the ExpertIO PCIE SVC

## H.2 Transaction Layer

See the following articles:

- ❖ VC VIP: Resolving Memory Read Error (MemRd accessed uninitialized memory) in PCIe
- ❖ VC VIP: Setting the PCIe VIP FC Credit Starvation Timeout
- ❖ VC VIP: Retrieving Final Credit Information in PCIe
- ❖ VC VIP PCIe: Traffic Class and Virtual Channels
- ❖ VC VIP: Application Routing with an Upstream Port in the PCIe VIP

- ❖ VC VIP: Updating TLP Reserved Fields During a PCIe CFG Request
- ❖ VC VIP: Notes about PCIe VIP Handling of Duplicate TLPs
- ❖ VC VIP: Using various EI\_CODEs at Transaction Layer level in PCIe
- ❖ VC VIP: Creating Spurious Completion TLPs in the PCIe Model
- ❖ VC VIP: Displaying TLP Payload in a Transaction Log in PCIe
- ❖ VC VIP: Avoid Automatic Corruption of a TLP Packet Generated from PCIe VIP
- ❖ VC VIP: Transmitting Nullified TLP Packet From PCIe
- ❖ VC VIP: Setting Transaction Ordering Rule in PCIe
- ❖ VC VIP: Resolving UVM Error (Received duplicate TLP) in PCIe
- ❖ VC VIP: Resolving UVM ERROR (HandleCfgReq: Wrong Bus# 0x00 for Function# 0 - Bus#) in PCIe
- ❖ VC VIP: Stop Sending ACK or NAK in Response to TLPs in PCIe
- ❖ VC VIP: Resolving Memory Allocation Issues in the PCIe SVT VIP
- ❖ VC VIP: Controlling the Number of Completions Sent in Response to a Read Request in the PCIe VIP
- ❖ VC VIP: Malformed TLP Error Related to Extended Tag in PCIe
- ❖ VC VIP: Retaining ECRC After TLP Corruption in PCIe
- ❖ VC VIP: Configuration Error When 10-Bit Tag Is Not Enabled in PCIe
- ❖ VC VIP: User-Defined Tag Field of a Memory Read/Write Transaction in PCIe
- ❖ VC VIP: Enable PASID for MRd/MWr Packets Driven by PCIe
- ❖ VC VIP: Reading From an Unallocated Memory in BuildMemCpl in PCIe
- ❖ VC VIP: Probably Cause for the PCIe VIP Not to Release Posted Credits
- ❖ VC VIP: Controlling the Vendor ID Field of a Msg TLP in PCIe
- ❖ VC VIP: Setting the VIP to Expect Cfg Read to Have a Competition as Config Retry Status
- ❖ VC VIP: Preventing the Generation of ECRCs in PCIe.
- ❖ VC VIP: Understanding How the PCIe Model Manages the Transmission Order of TLPs
- ❖ VC VIP: Initializing PCIe Memory Space with Random Data
- ❖ VC VIP: Discarding AtomicOPs Transactions When EP DUT Does Not Support AtomicOPs in PCIe
- ❖ VC VIP: DUT Response to ECRC Check Failure in PCIe
- ❖ VC VIP: Vendor Message With Multiple Data Payload in PCIe
- ❖ VC VIP: Maximum Allowable Payload Size in PCIe
- ❖ VP VIP: Configuring PCIe VIP to Send Read Completions of Required Size

### H.3 Data Link Layer

See the following articles:

- ❖ VC VIP: PCIe VIP Retry Support for CFG TLPs
- ❖ VC VIP: Using the PCIe VIP to Block INITFCs and Then Sending Out User-Defined and/or Vendor Specific DDLPS

- ❖ VC VIP: Programming the PCIe VIP to Send a Single ACK for Multiple TLP Packets
- ❖ VC VIP: Making the PCIe VIP Wait Until initFC2 Packets Complete Before Sending TLPs
- ❖ VC VIP: Injecting Errors Randomly Using the PCIe VIP
- ❖ VC VIP: Using Link Layer Callbacks of the Verilog Version of the PCIe VIP model
- ❖ VC VIP: PCIe Data Link Layer Enable Sequence
- ❖ PCIE SVC / SVT VIP : Initiating L1 Entry
- ❖ VC VIP: Enabling Simplified Replay Timer in PCIe
- ❖ VC VIP: Example for LCRC Error Injection in PCIe
- ❖ VC VIP: Enabling Flow Control Credit Scaling in PCIe
- ❖ VC VIP: Instructing the PCIe To Not Send an ACK or NAK for a Received TLP
- ❖ VC VIP: Resolving EI Timeout Error from DL in PCIe
- ❖ VC VIP: Check Data Link Layer Is Idle Before Initiating Speed Change in PCIe
- ❖ VC VIP: Scaled Flow Control Error in PCIe
- ❖ VC VIP: How to Achieve DUT Retry Buffer Testing in PCIe?
- ❖ VC VIP: PCIe Simulation Hangs with DL\_Inactive in loopback.active

## H.4 PHY Layer

See the following articles:

- ❖ PCIe SVC: Negotiating on Lower Link Width than VIP Actually Supports
- ❖ VC VIP: Testing the Taking Down of a Link Using the PCIe VIP
- ❖ VC VIP: PCIe VIP Issues RxStandby Error Messages in Recovery.Speed
- ❖ VC VIP: PCIe VIP Not Sending User TS1s
- ❖ VC VIP: Some Issues to Consider When Connecting the PCIe VIP SERDES to the Synopsys PCIe IIP.
- ❖ VC VIP PCIe: Lane Reversal Testing
- ❖ VC VIP: Corrupting the 'COM' Symbol in a Skip Ordered-Set Using the PCIe SVT VIP
- ❖ Handling DUT port reset with the PCIe SVT VIP
- ❖ VC VIP PCIe: Polarity Inversion
- ❖ VC VIP: Resolving Why the PCIe Model Does Not Enter L1 Through ASPM
- ❖ Why is the Discovery pcie\_svt VIP stuck in the CONFIGURATION\_LINK\_WIDTH\_START state when link number is not zero?
- ❖ VC VIP: Setting Valid FS, LF and Equalization/Coefficient Values in the UVM PCIe VIP
- ❖ VC VIP: PCIe UVM Attributes to Change to Support a 500MHZ PCLK Frequency in Gen3
- ❖ VC VIP: Active and Passive Components and Scrambling in PCIe
- ❖ VC VIP: Enabling the PCIe VIP PHY
- ❖ VC VIP: Critical Points about PCIe Link Width Settings
- ❖ VC VIP: Setting the Target & Expected Link Speeds in the PCIe VIP

- ❖ VC VIP: Example Showing Multiple Iterations on PCIe L1 Sub-States
- ❖ VC VIP: BIT\_FLIP Error Injection in PCIe
- ❖ VC VIP: Checking the Presence of Retimer in PCIe
- ❖ VC VIP: Initiating Redo Equalization for RC DUT in PCIe
- ❖ VC VIP: Enabling eq\_eval During RECOVERY\_EQUALIZATION in the PCIe SVT Model
- ❖ VC VIP: Enabling PCIe VIP to Detect the Presence of a Retimer
- ❖ VC VIP: Reconfiguring the Link Width of the PCIe Model During Run Time
- ❖ VC VIP: Achieving Non-Zero Error Count in Response to Timing Margining Command in PCIe
- ❖ VC VIP: Enabling EIEOS Pattern for 16GT in PCIe
- ❖ VC VIP: Lane-to-Lane Skew in Transmit/Receive Path in PCIe
- ❖ VC VIP: Controlling the Number of Garbage Symbols to be Sent After an EIOS Is Transmitted in PCIe
- ❖ VC VIP: Updating Symbols During User Defined TS1 OS Using the PCIe VIP
- ❖ VC VIP: Software Initiated Gen4 Equalization in PCIe
- ❖ VC VIP: Possible Scenario for FIFO Overflow Issues in PCIe
- ❖ VC VIP: Disabling Scrambling in the PCIE SVT VIP
- ❖ VC VIP: Entering/Exiting Low Power States in PCIe
- ❖ VC VIP: Configuring SKP Symbols in a SKP Order Set in the PCIe VIP Model
- ❖ VC VIP: Controlling the Number of EIOS Before L1 State in PCIe Gen3
- ❖ PCIe UVM VMT: An Example Showing How to Bring the Link to a DISABLE State and Then Back to DETECT
- ❖ PCIe VMT VIP: Example for Generating Hot Reset
- ❖ PCIE VMT: Performing Speed Changes From Gen1-to-Gen2-to-Gen1 from a RC PCIe VIP
- ❖ VC VIP: Available Configuration Settings for Changing Link Width in PCIe
- ❖ VC VIP: Bringing up the Link When Lane0 is Disabled in PCIe - Lane Reversal Mode Usage
- ❖ VC VIP: Error "TX L0s status after 20000 symbols" in PCIe
- ❖ VC VIP: Sending a Specific Number of TS1s in RECOVERY.EQUALIZATION\_1 State in PCIe
- ❖ VC VIP: Lane Reversal Using Symbol Log in PCIe
- ❖ VC VIP: PCLK Frequency Is Not Aligned With PCLK Rate Driven by MAC DUT in SPIPE Interface in PCIe
- ❖ VC VIP: Initiating Polling Compliance by Load Board Pattern in PCIe
- ❖ VC VIP: PCIe Gen3 Link Up Failure in PIPE Mode
- ❖ VC VIP: Changing link\_eval\_feedback\_figure\_of\_merit in PCIe
- ❖ VC VIP: Checking Compliance Pattern Received by PCIe VIP
- ❖ VC VIP: Check Data Link Layer Is Idle Before Initiating Speed Change in PCIe
- ❖ VC VIP: Link Up Issue Due to phy\_status Not Working Correctly in PCIe
- ❖ VC VIP: Directed LTSSM State Transition to Loopback in PCIe

- ❖ VC VIP: Valid Preset Value Is Rejected by PCIe
- ❖ VC VIP: Using Real Values for LTSSM Timeouts in the PCIe Model
- ❖ VC VIP: Controlling the Count of TS1 OS Transmitted in Polling.Active State in PCIe
- ❖ VC VIP: Expected UVM\_ERROR During Mid-Simulation Reset in PCIe
- ❖ VC VIP: Understanding Why VIP Initiated ASPML1 Entry Might Not Be Working (PCIe)
- ❖ VC VIP: Negotiated Link Width Does Not Match With the Expected Link Width in PCIe
- ❖ VC VIP: Does the PCIe VIP Support D States?
- ❖ VC VIP: Using PIPE Signals for Error Scenarios in PCIe
- ❖ VC VIP: Skipping Link Training in PCIe
- ❖ VC VIP: Controlling the Step Command Behavior in Rx Margining
- ❖ VC VIP: Forced Assertion of tx\_data\_vaild PIPE Signal Using PIPE Data Callback in PCIe
- ❖ VC VIP: LTSSM State Changed to Recovery When Training Is Skipped in PCIe
- ❖ VC VIP: Assertion of Rx\_status in SPIPE Model in PCIe
- ❖ VC VIP: Lane Skew Status in PCIe
- ❖ VC VIP: Inserting/Deleting a Bit From a Serial Bit Stream Using PL Callback in PCIe
- ❖ Configuring the ExpertIO Verilog SVC PCIe VIP for 8-bits PIPE
- ❖ VC VIP: Illegal Pipe Interface Request in PCI Express
- ❖ VC VIP: Avoiding FIFO Underflow Errors from the PCIe VIP
- ❖ VC VIP: Using the PIPE InvalidRequest Signal in the PCIe VIP
- ❖ VC VIP: Avoiding FIFO Overflow Errors from the PCIe VIP
- ❖ VC VIP: Sending Payload Over PCIe Serial Link (Big Endian or Little Endian)
- ❖ VC VIP: Blocking and Transmitting SKP Ordered Sets in the PCIe VIP
- ❖ VC VIP: Sampling Order Sets in PCIe Active Component
- ❖ VC VIP: Resolving the Decoder Error in PCIe
- ❖ VP VIP: Guidelines to Configure recovery\_speed\_electrical\_idle\_time\_ns Value in PCIe

## H.5 Methodology Testbench and Debug

See the following articles:

- ❖ VC VIP: Native PA FSDB dump for PCIe
- ❖ VC VIP: Understanding Why the PCIe VIP Issues Null Object Acess (NOA) Errors After Initial Model Reset
- ❖ VC VIP: Writing to PCIe Configuration Space Using Backdoor Methods
- ❖ VC VIP: Verifying the DUT Dropped Received Packet With EP=1 in PCIe
- ❖ VC VIP: Calculating Delays for Sending Queued Packets on the PCIe VIP Link
- ❖ VC VIP: Message Demotion is Not Working as Expected in the Pcie VIP
- ❖ VMT PCIe VIP: Installing the VMT-PCIe VIP into a VC Installation

- ❖ DesignWare Memory Models Overview (DWMM)
- ❖ VC VIP: Configuring the PCIe Transaction Log to Show TLP Payload Data
- ❖ VC VIP: Configuring the PCIe SVT VIP in EP Mode to Support More Than One Function
- ❖ VC VIP: Resolving "Undefined System Task Call " Error Message in the PCIe VIP
- ❖ VC VIP: License Warning for VIP-PCIE-VDB-SVT Key in PCIe
- ❖ VC VIP: Viewing PCIe SVT Functional Coverage Information
- ❖ PCIe SVT:Setting Up and Showcasing Global Shadow
- ❖ VC VIP: Creating an Unprotected Install Version of the PCIe SVT VIP.
- ❖ VC VIP: PCIe Configuration and Scoreboarding
- ❖ MSI/MSI-X with the PCIe SVT VIP
- ❖ VC VIP: Getting a Fatal Error Stating 8G is Not Supported
- ❖ VC VIP: Getting a Handle to Packets with Errors off a PCIe TLP Analysis Port
- ❖ VC VIP: VCS Compilation Flows with the PCIe VIP
- ❖ VC VIP: Understanding PLL Recovery Reset Messages From the PCIe SVT VIP.
- ❖ VC VIP: PCIe VIP Encryption Preventing VCS from Collecting Code Coverage
- ❖ All VC VIPs: Model Not Installing into DESIGNWARE\_HOME
- ❖ VC VIP: PCIe VIP Compile and Work Around for VCS's -debug\_pp Switch
- ❖ VC VIP: User-Defined UVM Testbench Configuration Is Not Used by PCIe
- ❖ VC VIP: Displaying All Payload Data in the PCIe VIP Transaction Log File
- ❖ What is causing the Null object access [NoA] error in my pcie\_svt UVM test bench?
- ❖ VC VIP: Resolving SLI UVM ERROR (SLI: Detected older SLISERV version) in PCIe
- ❖ VC VIP: Disabling Shadow Memory Checking in the PCIe VIP
- ❖ VC VIP: Flagging UVM\_ERROR Data Mismatch Errors Using the PCIe VIP
- ❖ VC VIP: What is the Purpose of the PCIe VIP's Active/ Passive Setting?
- ❖ VC VIP: PCIe Gen4 and PIPE 4.4
- ❖ VC VIP: PCIe Gen4 Installation and Documentation Video
- ❖ VC VIP: PCIe Gen4 Simplified Replay Timer
- ❖ VC VIP: PCIe Gen4 Flow Control Scaling
- ❖ VC VIP: Interfacing a PCIe UVM Agent to a DUT via model\_instance\_scope
- ❖ VC VIP: Fixing PCIe Fatal Error -- Exceeding Number of 32-bit Pages
- ❖ VC VIP for PCIe : Configuring a Model Video
- ❖ PCIe SVT VIP: Detecting if the VIP is Idle
- ❖ VC VIP: PCIe Gen4 EIEOS Format Change
- ❖ PCIE SVT VIP : DISPLAY\_NAME vs. instance name
- ❖ VC VIP: Checking Out a Gen4 License in PCIe
- ❖ Discovery PCIe SVT: Selecting PIPE clock rate and width

- ❖ VC VIP: PCIe Gen4 Multiple Endpoint Mode
- ❖ VC VIP: PCIe Gen4 Overview Video
- ❖ VC VIP: PCIe Gen4 10-Bit Tags
- ❖ VC VIP: Options for Controlling PCIe Logging Verbosity from the Command Line
- ❖ VC VIP: PCIe Gen4 Licensing, Compilation, Speed Change Video
- ❖ VC VIP : Reducing License Checkout Time for the PCIe VIP
- ❖ VC VIP: Using the PCIe SPEC\_VER Setting
- ❖ PCIe SVT VIP: PIPE 4/4.2 Wiring for Gen1/2/3
- ❖ VC VIP: PCIe Gen4 Up and Down Configure
- ❖ VC VIP for PCIe : VIP to DUT Interconnect (Unified)
- ❖ VC VIP: PCIe Product Training and Support Videos
- ❖ VC VIP for PCIe : Logging and Debug Video
- ❖ Pcie VMT: UVM examples give compilation errors
- ❖ VC VIP: Specifying PCIe Transaction and Symbol Log Name and Path
- ❖ VC VIP: Setting the Number of DWORD's Printed in a PCIe VIP Transaction Log
- ❖ VC VIP: Creating Filters To Exclude Non-Relevant Coverage Reports in the PCIe VIP
- ❖ VC VIP: Basic Compilation Errors During Initial Setup in PCIe
- ❖ ExpertIO VIP: Printing Complete Payload in Transaction Log in PCIe
- ❖ VC VIP: Resolving Uninitialized Memory Access Error in PCIe
- ❖ VC VIP: Addressing Timescale Issues in the PCIe VIP
- ❖ VC VIP: Resolving SERDES Locking Error in PCIe
- ❖ All VIP: Using DW\_LICENSE\_OVERRIDE in DesignWare Verification IP
- ❖ VC VIP: Avoiding PCIe DRIVER\_COMMAND\_TIMEOUT Errors (Verilog)
- ❖ VC VIP: Disabling/Demoting Protocol Checks Using svt\_err\_check in PCIe
- ❖ VC VIP: Enabling PCIe Gen4 Support in Verilog
- ❖ VC VIP: Avoiding SetCPTPointer Related Error Caused When Reset Is Applied to PCIe VIP
- ❖ VC VIP: Resolving pli.tab and msglog.o Errors in PCIe
- ❖ VC VIP: Steps for Demoting UVM\_ERROR Messages to UVM\_WARNING or UVM\_INFO Messages in PCIe
- ❖ VC VIP: PCIe Controls for Scrambling for Active Components
- ❖ VC VIP: Resolving PCIe License Issue "UVM\_ERROR: Encountered SLI error 'PCIE' followed by UVM\_FATAL : License checkout failure. Authorization not granted for suite 'PCIE' "
- ❖ VC VIP: Resolving the PCIe Integration Compile Error
- ❖ VC VIP: Suppressing Demoted Messages in PCIe Log Files
- ❖ VC VIP: Understanding UVM Warning Message Regarding Shadow Memory Configuration in the PCIe VIP

## H.6 Miscellaneous

See the following articles:

- ❖ [VC VIP: Performing Backdoor Write to Memory in PCIe](#)
- ❖ [VC VIP: Tuning Presets and Coefficients in Equalization in PCIe](#)
- ❖ [VC VIP: Preserving the Memory When the PCIe VIP is Reset](#)
- ❖ [Spread Spectrum Clocking with ExpertIO PCIe SVC VIP](#)
- ❖ [Configuring the PCIe SVT SerDes VIP model to transmit 0's in its disabled state.](#)
- ❖ [VC VIP: Keeping the PCIe Model in the L0S State](#)
- ❖ [VC VIP: Programming a Mid-Sim Reset in PCIe VIP](#)
- ❖ [VC VIP: Generating Backpressure in PCIe](#)
- ❖ [VC VIP: Enabling Extended Tag Support in PCIe](#)
- ❖ [VC VIP: Using Status Classes in PCIe](#)
- ❖ [VC VIP: PCIE Redo-Equalization in the L0 state](#)
- ❖ [VC VIP: Controlling pipe\\_reset\\_n driven by MAC in PCIe](#)
- ❖ [VC VIP: Setting the Version of Your PCIe VIP PIPE Interface](#)
- ❖ [VC VIP: Preloading Memory in the PCIe Model](#)
- ❖ [VC VIP: Controlling SVC VIP From C Testbench Using DPI in PCIe](#)
- ❖ [VC VIP: Enabling Spread Spectrum Clocking in PCIe](#)
- ❖ [VC VIP: Accessing Expansion ROM in PCIe](#)
- ❖ [VC VIP: PLL Tolerance Adjustment When pll\\_lock Is Not Achieved in PCIe](#)
- ❖ [VC VIP: Enabling Transaction Ordering Support in PCIe](#)
- ❖ [VC VIP: Disabling Expansion ROM in PCIe](#)
- ❖ [PCIe VMT VIP: Initiating Various Types of Messages Using ASSERT\\_INTA as an Example](#)
- ❖ [VC VIP: Steps to Enter into and Exit from ASPM L1\\_2 sub-state \(Low Power State\) in PCIe](#)
- ❖ [VC VIP: Data Monitoring Options in PCIe](#)
- ❖ [VC VIP: Spread Spectrum Clocking in PCIe](#)
- ❖ [VC VIP: Resolving the Memory Error \(ncelab: \\*E,CUVNPL: An argument list has been applied to an inappropriate object\) in PCIe](#)
- ❖ [VC VIP: Toolbox Randomization Error in PCIe](#)
- ❖ [VC VIP: Simulation Run Failure on Questa Simulator in PCIe](#)



# I Reporting Problems

## I.1 Introduction

This chapter outlines the process for working through and reporting VIP transactor issues encountered in the field. It describes the data you must submit when a problem is initially reported to Synopsys. After a review of the initial information, Synopsys may decide to request adjustments to the information being requested, which is the focus of the next section. This section outlines the process for working through and reporting problems. It shows how to use Debug Automation to enable all the debug capabilities of any VIP. In addition, the VIP provides a case submittal tool to help you pack and send all pertinent debug information to Synopsys Support.

## I.2 Debug Automation

Every Synopsys model contains a feature called “debug automation”. It is enabled through *svt\_debug\_opts* plusarg. The Debug Automation feature allows you to enable all relevant debug information. The following are critical features of debug automation:

- ❖ Enabled by the use of a command line run-time plusarg.
- ❖ Can be enabled on individual VIP instances or multiple instances using regular expressions.
- ❖ Enables debug or verbose message verbosity:
  - ◆ The timing window for message verbosity modification can be controlled by supplying *start\_time* and *end\_time*.
- ❖ Enables at one time any, or all, standard debug features of the VIP:
  - ◆ Transaction Trace File generation
  - ◆ Transaction Reporting enabled in the transcript
  - ◆ PA database generation enabled
  - ◆ Debug Port enabled
  - ◆ Optionally, generates a file name *svt\_model\_out.fsdb* when Verdi libraries are available

When the Debug feature is enabled, then all VIP instances that are enabled for debug will have their messages routed to a file named *svt\_debug.transcript*.

## I.3 Enabling and Specifying Debug Automation Features

Debug Automation is enabled through the use of a run-time plusarg named *+svt\_debug\_opts*. This plusarg accepts an optional string-based specification to control various aspects Debug Automation. If this

command control specification is not supplied, then the feature will default to being enabled on all VIP instances with the default options listed as follows:

Note the following about the plusarg:

- ❖ The command control string is a comma separated string that is split into the multiple fields.
- ❖ All fields are optional and can be supplied in any order.

The command control string uses the following format (white space is disallowed):

```
inst:<inst>, type:<string>, feature:<string>, start_time:<longint>, end_time:<longint>, verbosity:<string>
```

The following table explains each control string:

**Table I-1 Control Strings for Debug Automation plusarg**

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inst       | Identifies the VIP instance to apply the debug automation features. Regular expressions can be used to identify multiple VIP instances. If this value is not supplied, and if a type value is not supplied, then the debug automation feature will be enabled on all VIP instances.                                                                                                                                                                                                                                                               |
| type       | Identifies a class type to apply the debug automation features. When this value is supplied then debug automation will be enabled for all instances of this class type.                                                                                                                                                                                                                                                                                                                                                                           |
| feature    | Identifies a sub-feature that can be defined by VIP designers to identify smaller grouping of functionality that is specific to that title. The definition and implementation of this field is left to VIP designers, and by default it has no effect on the debug automation feature. (Specific to VIP titles)                                                                                                                                                                                                                                   |
| start_time | Identifies when the debug verbosity settings will be applied. The time must be supplied in terms of the timescale that the VIP is compiled. If this value is not supplied, then the verbosity settings will be applied at time zero.                                                                                                                                                                                                                                                                                                              |
| end_time   | Identifies when the debug verbosity settings will be removed. The time must be supplied in terms of the timescale that the VIP is compiled. If this value is not supplied, then the debug verbosity remains in effect until the end of the simulation.                                                                                                                                                                                                                                                                                            |
| verbosity  | Message verbosity setting that is applied at the <code>start_time</code> . Two values are accepted in all methodologies: DEBUG and VERBOSE. UVM and OVM users can also supply the verbosity that is native to their respective methodologies (UVM_HIGH/UVM_FULL and OVM_HIGH/OVM_FULL). If this value is not supplied then the verbosity defaults to DEBUG/UVM_HIGH/OVM_HIGH. When this feature is enabled, then all VIP instances that are enabled for debug will have their messages routed to a file named <code>svt_debug.transcript</code> . |

### Examples:

Enable on all VIP instances with default options:

```
+svt_debug_opts
```

Enable on all instances:

- ❖ containing the string "endpoint" with a verbosity of UVM\_HIGH
- ❖ starting at time zero (default) until the end of the simulation (default):

```
+svt_debug_opts=inst:/.*endpoint.*/, verbosity:UVM_HIGH
```

Enable on all instances:

- ❖ starting at time 1000 until time 1500:

```
+svt_debug_opts=start_time:1000,end_time:1500,verbosity:VERBOSE
```

Enable debug feature on all instances using default options:

- ❖ By setting the macro DEBUG\_OPTS to 1 in the command line, the debug feature is enabled on all instances using default options. The macro will enable the XMLs and Trace files.

```
gmake <testname> DEBUG_OPTS=1 PA=FSDB
```



**Note** The DEBUG\_OPTS option is available through the installed VIP examples, but if required, in customer environments, then a similar feature should be added to their environment.

The PA=FSDB option is available in public examples and is required to enable Verdi libraries, and that when this option is used, then the Debug Opts file will record VIP activity to a file named `svt_model_log.fsdb`.

In addition, the SVT Automated Debug feature will enable waveform generation to an FSDB file, if the Verdi libraries are available. When enabled this feature, it should cause the simulator to dump waveform information only for the VIP interfaces.

When this feature is enabled then all VIP instances that have been enabled for debug will have their messages routed to a file named `svt_debug.transcript`.

## I.4 Debug Automation Outputs

The Automated Debug feature generates a `svt_debug.out` file. It records important information about the debug feature itself, and data about the environment that the VIPs are operating in. This file records the following information:

- ❖ The compiled timeunit for the SVT package
- ❖ The compiled timeunit for each SVT VIP package
- ❖ Version information for the SVT library
- ❖ Version information for each SVT VIP
- ❖ Every SVT VIP instance, and whether the VIP instance has been enabled for debug
- ❖ For every SVT VIP enabled for debug, a list of configuration properties that have been modified to enable debug will be listed
- ❖ A list of all methodology phases will be recorded, along with the start time for each phase

The following are the output files generated:

- ❖ `svt_debug.out`: It records important information about the debug feature itself, and data about the environment that the VIPs are operating. One file is optionally created when this feature is enabled, depending on if the Verdi libraries are available.
- ❖ `svt_debug.transcript`: Log files generated by the simulation run.
- ❖ `transaction_trace`: Log files that records all the different transaction activities generated by VIPs.
- ❖ `svt_model_log.fsdb`: Contains PA FSDB information (if the VIP supports this), and which contains other recorded activity. The additional information records signal activity associated with the VIP interface, TLM input (through SIPP ports), other TLM output activity, configurations applied to the VIP, and all callback activity (recorded by before and after callback execution).

## I.5 FSDB File Generation

To enable FSDB writing capabilities, the simulator compile-time options and environment must be updated to enable this. The steps to enable this are specific to the simulator being used (the {LINUX/LINUX64} label needs to be replaced based on the platform being used). The ability to write to an FSDB file requires that the user supplies the Verdi dumper libraries when they compile their testbench. If these are not supplied then the VIP will not be enabled to generate the *svt\_model\_log.fsdb* file.

### I.5.1 VCS

The following must be added to the compile-time command:

```
-debug_access
```

For more information on how to set the FSDB dumping libraries, see “Appendix B” section in *Linking Novas Files with Simulators and Enabling FSDB Dumping* guide available at \$VERDI\_HOME/doc/linking\_dumping.pdf.

### I.5.2 Questa

The following must be added to the compile-time command:

```
+define+SVT_FSDB_ENABLE -pli novas_fli.so
```

### I.5.3 Incisive

The following must be added to the compile-time command:

```
+define+SVT_FSDB_ENABLE -access +r
```

## I.6 Initial Customer Information

Follow these steps when you call the Synopsys Support Center:

1. Before you contact technical support, be prepared to provide the following:
  - ◆ A description of the issue under investigation.
  - ◆ A description of your verification environment.

Enable the Debug Opts feature. For more information, see the [Debug Automation](#).

## I.7 Sending Debug Information to Synopsys

To help you debug testing issues, follow the given instructions to pack all pertinent debug information into one file which you can send to Synopsys (or to other users in your company):

1. Create a description of the issue under investigation. Include the simulation time and bus cycle of the failure, as well as any error or warning messages that are part of the failure.
2. Create a description of your verification environment. Assemble information about your simulation environment, making sure to include:
  - ◆ OS type and version
  - ◆ Testbench language (SystemVerilog or Verilog)
  - ◆ Simulator and version
  - ◆ DUT languages (Verilog)
3. Use the VIP case submittal tool to pack a file with the appropriate debug information. It has the following usage syntax:

```
$DESIGNWARE_HOME/bin/snps_vip_debug [-directory <path>]
```

The tool will generate a “<username>. <unqid>.svd” file in the current directory. The following files are packed into a single file:

- ❖ FSDB
- ❖ HISTL
- ❖ MISC
- ❖ SLID
- ❖ SVTO
- ❖ SVTX
- ❖ TRACE
- ❖ VCD
- ❖ VPD
- ❖ XML

If any one of the above files are present, then the files will be saved in the "<username>. <unqid>.svd" in the current directory. The simulation transcript file will not be part of this and it will be saved separately.

The -directory switch can be specified to select an alternate source directory.

4. You will be prompted by the case submittal tool with the option to include additional files within the SVD file. The simulation transcript files cannot be automatically identified and it must be provided during this step.



For SVT, you must set the verbosity to UVM\_HIGH/OVM\_HIGH.

5. The case submittal tool will display options on how to send the file to Synopsys.

## I.8 Limitations

Enabling DEBUG or VERBOSE verbosity is an expensive operation, both in terms of runtime and disk space utilization. The following steps can be used to minimize this cost:

- ❖ Only enable the VIP instance necessary for debug. By default, the +svt\_debug\_opts command enables Debug Opts on all instances, but the 'inst' argument can be used to select a specific instance.
- ❖ Use the start\_time and end\_time arguments to limit the verbosity changes to the specific time window that needs to be debugged.

